Circle’s APIs align with guidance issued by FinCEN pertaining to the applicability of the Travel Rule to ERC-20 transfers on Ethereum (which includes USDC transfers on Ethereum).

The Travel Rule mandates that funds transfers of $3,000 or more (or equivalent in cryptocurrency) require the originating institution to transmit KYC information about the originator of a transaction to the beneficiary institution.

For more information on these requirements and how data is securely collected and shared, please see our <a href="" target="_blank">FAQ</a>.

## Sending Transfers (Non-Business Account)

When sending non-business account transfers on the Ethereum or Bitcoin chain that have a value that meets or exceeds $3,000 in value, the originator’s identity will be required. If you are sending a transfer on behalf of your end-user, you need to provide the identity of your end-user. Otherwise, you need to provide your company’s identity.

In technical terms, the originator’s identity is required for `POST /v1/transfers` when:

  1. `destination.type: "blockchain"`

  2. `destination.chain: "ETH" or "BTC"`

  3. `amount.amount` >= $3,000 in value

If the `POST /v1/transfers` request requires an originator's identity and the transfer does not contain an originator's identity, the transfer will fail. You will receive a webhook notification with `data.status: fail`, `riskEvaluation.decision: denied`, and `riskEvaluation.reason: 3220`.

## Sending Transfers (Business Account)

Although 1st party transfers are required to comply with the Travel Rule, we do not require you to provide your company’s identity each time you make a business account transfer `POST /v1/businessAccount/transfers`. Instead, Circle will use your company’s identity stored on file and provide it to the receiving institution as required.

## Receiving Transfers

Certain regulated financial institutions also face additional Travel Rule compliance requirements when receiving transfers. For this reason, we will provide the originator’s identity for webhook notifications of type transfer in addition to `GET /v1/transfers` and `GET /v1/transfers/{id}` for these institutions. Originator data will not be associated with a transfer until it is marked with a status of complete. At this time, not all sending institutions are participating in the on-chain Travel Rule requirement. Therefore, not all transfers valued at $3,000 or more will have the originating person associated.

If you are a financial institution and do not see the originator’s identity, please reach out to a Circle representative.

Non-bank financial institutions will not see the originator’s identity for received transfers.


To maintain API functionality, you must comply with sending KYC information about the originator for ERC-20 transfers on Ethereum by **June 30th, 2022**.

## Identities Schema

Identities.type [REQUIRED]String [enum]: `individual`, `business`individual - A uniquely distinguishable individual. business - Any entity other than a natural person that can establish a permanent customer relationship with an affected entity or otherwise own property. This can include companies, foundations, anstalt, partnerships, associations and other relevantly similar entities [REQUIRED]String [max length 1024]Full name of the originator.
Identities.addresses.line1 [REQUIRED]String [max length 1024]Line one of the street address. Note: If the originator is a business, this is the principal place of business address. If the originator is an individual, this is the current residential address.
identities.addresses.line2String [max length 1024]Line two of the street address. [REQUIRED]String [max length 1024]City portion of the address.
identities.addresses.districtString [max length 16]State / County / Province / Region portion of the address. If the country is US or Canada district is required and should use the two-letter code for the subdivision. [REQUIRED]String [max length 2]Country portion of the address. Formatted as a two-letter country code specified in ISO 3166-1 alpha-2.
identities.addresses.postalCode [REQUIRED]String [max length 16]Postal / ZIP code of the address.

## Example: POST /v1/transfers

## Example: GET /v1/transfers?returnIdentities=true

**returnIdentities[boolean]:** Specify if you would like to see identities in the response. Restricts maximum returned items to 5. By default returnIdentities is false, resulting in the response not returning `data.source.identities`.

## Example: GET /v1/transfers/{id}?returnIdentities=true

**returnIdentities[boolean]:** Specify if you would like to see identities in the response. Restricts maximum returned items to 5. By default returnIdentities is false, resulting in the response not returning `data.source.identities`.

## Example: Webhook Notification