- Self-hosted wallets: the customer controls the private key. Register with a signed proof-of-ownership message. For customers in the US and Rest of World who cannot sign from their custody UI (e.g. Fireblocks), register with a self-attested declaration instead, with no signature.
- Hosted wallets: the wallet is custodied by another VASP (e.g. Coinbase, Kraken). Registration requires the VASP’s DID so Iron can exchange travel-rule data with the custodian.
Verify a self-hosted crypto address
Submit a signature proving ownership of your cryptocurrency wallet. The verification process requires signing a specific message with your wallet’s private key.Format the proof message:
{customer_id}with your customer ID{wallet_address}with your wallet address{date}with today’s date in DD/MM/YYYY format using UTC timezone
The date must be today in DD/MM/YYYY using the UTC timezone (not your local timezone, not a stale year from a template). If you sign before UTC midnight and submit after, re-sign.
The message must be byte-identical between sign-time and POST-time (no rewording, no trailing newline, no whitespace edits), and the
customer_id inside the message must equal the customer_id in the request body. EVM signatures use standard EIP-191 personal_sign (the default for cast wallet sign, ethers signMessage, viem signMessage); smart-contract wallets verify via EIP-1271. You can add additional text before or after the required message and verification still succeeds.Register a self-attested crypto address
For direct customers who cannot produce a signature from their custody UI (e.g. Fireblocks), register a self-hosted wallet by declaring ownership instead of signing a proof-of-ownership message. The wallet is still registered as self-hosted and carries the same Travel Rule obligations as the signed flow.Self-attestation is available only to customers in the US and Rest of World jurisdictions. Customers in the UK, EEA, Canada, and Australia must use the signed self-hosted flow and will receive a
403 from this endpoint. The sandbox skips this region check, so the example below works for any sandbox customer.customer_id: The customer’s UUIDaddress: The wallet address the customer declares they controlblockchain: The blockchain the address is on (e.g.Ethereum,Solana,Polygon,Base,Arbitrum)name: Optional display name for this wallet
The
Idempotency-Key header is required so the address is only registered once on retries. Pass the optional X-Sub-Partner-Id header to register the wallet under a specific sub-partner.address_type: "SelfHosted" and the sentinel proof_signature: "SELF_ATTESTED", which marks them as declared rather than cryptographically signed:
Error response
A409 is returned when the wallet address is already registered. These address endpoints return the error as a plain string body, not a structured object:
Register a hosted wallet
When the recipient wallet is custodied by another institution (VASP), for example Coinbase, Kraken, or Binance, you need to register the wallet address along with the institution’s DID so Iron can exchange travel-rule data with the custodian.Search for the VASP (wallet provider):
First, find the DID (Decentralized Identifier) of the institution that hosts the wallet:Response:
customer_id: The customer’s UUIDwallet_address: The wallet address at the institutionvasp_did: The DID (Decentralized Identifier) of the institution hosting the wallet (obtained from the VASP search)blockchain: The blockchain the address is on (e.g.Ethereum,Solana,Polygon,Base,Arbitrum)
The wallet must be registered in your name at the hosting institution. Iron will use the VASP DID to exchange travel rule information with the institution.
List verified addresses
Retrieve all verified cryptocurrency addresses for a customer:filter query parameter:
?filter=Hosted: Only hosted wallet addresses?filter=SelfHosted: Only self-hosted wallet addresses?filter=Allor no filter: All addresses (default)
id: Address IDwallet_address: The wallet addressaddress_type: “Hosted” or “SelfHosted”blockchain: The blockchain (e.g. “Ethereum”, “Solana”)created_at: Registration timestampdisabled: Whether the address is disabledvasp_did: (For hosted wallets only) The VASP’s DIDproof_message: (For self-hosted wallets only) The verification messageproof_signature: (For self-hosted wallets only) The signature
Self-attested wallets are returned with
address_type: "SelfHosted", so ?filter=SelfHosted includes them. To tell them apart from cryptographically signed wallets, check proof_signature: attested wallets carry the sentinel value "SELF_ATTESTED" and a proof_message that marks the wallet as self-attested rather than signed.- Invalid proof message format
- Incorrect date in proof message (must be today’s date in DD/MM/YYYY format)
- Invalid signature
- Wallet address already registered
- Invalid blockchain/address format mismatch
- Customer ID does not belong to your partner
Disable or enable an address
You can disable or enable a verified crypto address. Disabled addresses cannot be used for transactions.Addresses that were automatically disabled due to high risk (e.g., flagged by Chainalysis) cannot be re-enabled.

