These endpoints allow you to get information about blockchains supported by Fordefi.
Fordefi API (0.2.0)
https://api.fordefi.com/
Users
These endpoints allow you to get information about users in your Fordefi organization.
There are several types of users in the Fordefi platform:
- Person: A human user of the platform.
- API User, also commonly known as a service account. See Create an API user.
- API Signer: Used to auto-sign transactions. See Automate Signing with API Signer.
Users can have one of three possible roles, which define the permissions that the user is given:
- Admin: A user with high privileges in the organization. Only admins have permission to manage the policy, set up the backup, manage the address book, and add or remove users in the organization. Only a person can have an admin role.
- Trader: A user who can create vaults and transactions.
- Viewer: A user who has full view of the organization's users, addresses, and policies, as well as of the vaults and transactions, but does not have permissions to create or modify them.
The Users API is currently read-only. To add/remove users, visit the Fordefi web console.
Webhooks
These endpoints allow you to manually trigger your pre-configured webhooks.
Use Webhooks describes how to configure webhooks, validate them, and resend them. 
There are two webhook types. Webhook V1 and Webhook V2. 
- Webhook V1 contains minimal details about the transaction. It is deprecated and will be removed in the future. It is recommended to use Webhook V2 instead.
- Webhook V2 delivers the full set of details about the transaction as retrieved by a call to the Get Transaction endpoint.
Address Book
These endpoints allow you to list the contacts in your address book.
To add/remove contacts, visit the Fordefi web console. See the user guide for more info.
Transactions
These endpoints allow you to manage transactions on the Fordefi platform. 
 A transaction represents an operation that can be one of the following:
- An on-chain action that modifies blockchain state
- An off-chain cryptographically signed message or data
The filter applies both to transactions that have been signed by the vault and also to transactions that have interacted with the vault.
Transaction hashes to filter by. Will return transactions with any of the specified hashes. The format of the hash depends on the blockchain type.
- Productionhttps://api.fordefi.com/api/v1/transactions/export 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X GET \
  https://api.fordefi.com/api/v1/transactions/export \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "creation_time": "2019-08-24T14:15:22Z", "type": "csv", "state": "created", "organization_id": "7c60d51f-b44e-4682-87d6-449835ea4de6", "user_id": "string", "resource_type": "transaction", "successful_items_count": 0, "failed_items_count": 0, "total_items_count": 0, "request_id": "string", "download_url": "string", "expiration_time": "2019-08-24T14:15:22Z" }
- Productionhttps://api.fordefi.com/api/v1/transactions/{id} 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X GET \
  'https://api.fordefi.com/api/v1/transactions/{id}' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'Successful Response
The date and time when the object was last modified. Any change to any field of the resource is considered a modification.
Whether the transaction was signed by an external user (for example in case of imported vault).
Aptos message type.
- aptos_message
- aptos_transaction
- black_box_signature
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
The original message that was requested to be signed, encoded in base64.
The full message to be signed, encoded in base64.
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "managed_transaction_data": { "created_by": { … }, "aborted_by": { … }, "device_signing_request": { … }, "approval_request": { … }, "aml_policy_match": { … }, "policy_match": { … }, "signer_type": "initiator", "risks": [ … ], "error_pushing_to_blockchain_message": "string", "original_error_pushing_to_blockchain_message": "string", "vault": { … }, "idempotence_id": "20a3c79f-f547-44b3-bdfc-d8aea82ad496", "has_current_user_vault_permissions": true, "batch_data": { … }, "push_mode": "auto", "last_pushed_at": "2019-08-24T14:15:22Z", "sign_mode": "auto" }, "signatures": [ { … } ], "note": "string", "spam_state": "unset", "direction": "outgoing", "signed_externally": false, "interacted_vaults": [ { … } ], "related_transactions": [ { … } ], "state": "waiting_for_approval", "state_changes": [ { … } ], "type": "aptos_message", "aptos_message_type": "personal_message_type", "raw_original_message_to_sign": "SGVsbG8=", "string_original_message_to_sign": "string", "raw_full_message_to_sign": "SGVsbG8=", "string_full_message_to_sign": "string", "chain": { "chain_type": "aptos", "unique_id": "aptos_mainnet", "name": "string", "native_currency_symbol": "ETH", "native_currency_name": "Ether", "blockchain_explorer": { … }, "logo_url": "http://example.com", "is_testnet": true, "is_enabled": true }, "sender": { "vault": { … }, "explorer_url": "http://example.com", "contact": { … }, "type": "aptos", "address": "0x3300c18e7b931bdfc73dccf3e2d043ad1c9d120c777fff5aeeb9956224e5247a" } }
The filter applies both to transactions that have been signed by the vault and also to transactions that have interacted with the vault.
Transaction hashes to filter by. Will return transactions with any of the specified hashes. The format of the hash depends on the blockchain type.
State of the transaction. Can be one of the following:aborted aborting accelerated accelerating approved canceling cancelled completed completed_reverted dropped error_processing_by_exchange error_pushing_to_blockchain error_signing error_submitting_to_exchange error_submitting_to_provider insufficient_funds mined mined_reverted pending_exchange pushed_to_blockchain queued sent_to_provider signed stuck waiting_for_approval waiting_for_signing_trigger, or an aggregation of states:
- error, which can be one of:
- completed_reverted
- dropped
- error_processing_by_exchange
- error_pushing_to_blockchain
- error_signing
- error_submitting_to_exchange
- error_submitting_to_provider
- insufficient_funds
- finalized, which can be one of:
- aborted
- accelerated
- cancelled
- completed
- completed_reverted
- dropped
- error_processing_by_exchange
- error_pushing_to_blockchain
- error_signing
- error_submitting_to_exchange
- error_submitting_to_provider
- insufficient_funds
- pending, which can be one of:
- aborting
- accelerating
- approved
- canceling
- mined
- mined_reverted
- pending_exchange
- pushed_to_blockchain
- queued
- sent_to_provider
- signed
- stuck
- waiting_for_approval
- waiting_for_signing_trigger
- Productionhttps://api.fordefi.com/api/v1/transactions 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X GET \
  https://api.fordefi.com/api/v1/transactions \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'{ "total": 0, "page": 0, "size": 0, "transactions": [ { … } ] }
Signature of the body. Base64 encoded string. If the request is made programatically by an API user, signing of the request is required and is intended to protect you from malicious backends.
Timestamp of the signature. Integer. Specify an Epoch date. If the request is made programatically by an API user, the timestamp of the request is required and is intended to protect you from replay attacks.
Aptos message type.
- aptos_message
- aptos_transaction
- black_box_signature
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
- Productionhttps://api.fordefi.com/api/v1/transactions 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  https://api.fordefi.com/api/v1/transactions \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "vault_id": "432b199b-1f71-42bf-ba0b-33d512afa9de",
    "note": "string",
    "signer_type": "initiator",
    "sign_mode": "auto",
    "dapp_info": {
      "url": "string",
      "name": "string"
    },
    "type": "aptos_message",
    "details": {
      "type": "personal_message_type",
      "should_include_address": true,
      "application": "string",
      "should_include_application": true,
      "chain": "aptos_mainnet",
      "should_include_chain": true,
      "message_to_sign": "SGVsbG8=",
      "nonce": "string"
    }
  }'Successful Response
The date and time when the object was last modified. Any change to any field of the resource is considered a modification.
Whether the transaction was signed by an external user (for example in case of imported vault).
Aptos message type.
- aptos_message
- aptos_transaction
- black_box_signature
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
The original message that was requested to be signed, encoded in base64.
The full message to be signed, encoded in base64.
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "managed_transaction_data": { "created_by": { … }, "aborted_by": { … }, "device_signing_request": { … }, "approval_request": { … }, "aml_policy_match": { … }, "policy_match": { … }, "signer_type": "initiator", "risks": [ … ], "error_pushing_to_blockchain_message": "string", "original_error_pushing_to_blockchain_message": "string", "vault": { … }, "idempotence_id": "20a3c79f-f547-44b3-bdfc-d8aea82ad496", "has_current_user_vault_permissions": true, "batch_data": { … }, "push_mode": "auto", "last_pushed_at": "2019-08-24T14:15:22Z", "sign_mode": "auto" }, "signatures": [ { … } ], "note": "string", "spam_state": "unset", "direction": "outgoing", "signed_externally": false, "interacted_vaults": [ { … } ], "related_transactions": [ { … } ], "state": "waiting_for_approval", "state_changes": [ { … } ], "type": "aptos_message", "aptos_message_type": "personal_message_type", "raw_original_message_to_sign": "SGVsbG8=", "string_original_message_to_sign": "string", "raw_full_message_to_sign": "SGVsbG8=", "string_full_message_to_sign": "string", "chain": { "chain_type": "aptos", "unique_id": "aptos_mainnet", "name": "string", "native_currency_symbol": "ETH", "native_currency_name": "Ether", "blockchain_explorer": { … }, "logo_url": "http://example.com", "is_testnet": true, "is_enabled": true }, "sender": { "vault": { … }, "explorer_url": "http://example.com", "contact": { … }, "type": "aptos", "address": "0x3300c18e7b931bdfc73dccf3e2d043ad1c9d120c777fff5aeeb9956224e5247a" } }
Signature of the body. Base64 encoded string. If the request is made programatically by an API user, signing of the request is required and is intended to protect you from malicious backends.
Timestamp of the signature. Integer. Specify an Epoch date. If the request is made programatically by an API user, the timestamp of the request is required and is intended to protect you from replay attacks.
Aptos message type.
- aptos_message
- aptos_transaction
- black_box_signature
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
The maximum time in seconds to wait for the transaction to reach the specified state. For states that require more than 50 seconds, using webhooks or polling is preferable.
- Productionhttps://api.fordefi.com/api/v1/transactions/create-and-wait 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  https://api.fordefi.com/api/v1/transactions/create-and-wait \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "vault_id": "432b199b-1f71-42bf-ba0b-33d512afa9de",
    "note": "string",
    "signer_type": "initiator",
    "sign_mode": "auto",
    "dapp_info": {
      "url": "string",
      "name": "string"
    },
    "type": "aptos_message",
    "details": {
      "type": "personal_message_type",
      "should_include_address": true,
      "application": "string",
      "should_include_application": true,
      "chain": "aptos_mainnet",
      "should_include_chain": true,
      "message_to_sign": "SGVsbG8=",
      "nonce": "string"
    },
    "timeout": 10,
    "wait_for_state": "waiting_for_approval"
  }'Successful Response
The date and time when the object was last modified. Any change to any field of the resource is considered a modification.
The state of the transaction.
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "signatures": [ "SGVsbG8=" ], "state": "waiting_for_approval", "has_timed_out": true }
- Productionhttps://api.fordefi.com/api/v1/transactions/{id}/approve 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  'https://api.fordefi.com/api/v1/transactions/{id}/approve' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'Request
Abort a transaction.
Abort is possible only for a transaction that is in one of the following states:
- Waiting for approval
- Approved
The aborting user must be one of the following:
- The user who created the transaction
- An admin
- A legitimate approver
API users can abort only the transactions they created.
- Productionhttps://api.fordefi.com/api/v1/transactions/{id}/abort 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  'https://api.fordefi.com/api/v1/transactions/{id}/abort' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'Signature of the body. Base64 encoded string. If the request is made programatically by an API user, signing of the request is required and is intended to protect you from malicious backends.
True if transaction creation should fail in case prediction failed, False otherwise. 
 In case simulation has failed upon continuation, the expected result of the transaction will be partial and policy will be applied on information that can be extracted statically from the transaction only. This might result in falling back to the default policy rule.
Using the Custom Gas Request option, you specify gas_limit, as well as the following gas details: 
- If you choose legacy(meaning a chain where gas price can be specified exactly), you must specify only thepriceof a gas unit.
- If you choose dynamic(meaning a chain where gas price can be determined dynamically), you must specify two additional values:- max_priority_fee_per_gas, the maximum tip amount for mining your transaction
- max_fee_per_gas, the maximum amount you are willing to pay for the fee (ultimately, either you'll pay this amount, or less, depending on the network base fee).
 
Note that the Legacy gas price setting is allowed on dynamic (EIP-1559) networks as well.
You can get information on gas fees for different chains by examining the response to a call to List Chains. More information is provided in EVM chains and their fee mechanisms.
- Productionhttps://api.fordefi.com/api/v1/transactions/{id}/release 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  'https://api.fordefi.com/api/v1/transactions/{id}/release' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "release_type": "cancel",
    "signer_type": "initiator",
    "note": "string",
    "type": "evm_transaction",
    "fail_on_prediction_failure": true,
    "gas": {
      "gas_limit": "1000000000000000000",
      "type": "custom",
      "details": {
        "type": "legacy",
        "price": "1000000000000000000"
      }
    }
  }'Successful Response
The date and time when the object was last modified. Any change to any field of the resource is considered a modification.
Whether the transaction was signed by an external user (for example in case of imported vault).
Aptos message type.
- aptos_message
- aptos_transaction
- black_box_signature
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
The original message that was requested to be signed, encoded in base64.
The full message to be signed, encoded in base64.
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "managed_transaction_data": { "created_by": { … }, "aborted_by": { … }, "device_signing_request": { … }, "approval_request": { … }, "aml_policy_match": { … }, "policy_match": { … }, "signer_type": "initiator", "risks": [ … ], "error_pushing_to_blockchain_message": "string", "original_error_pushing_to_blockchain_message": "string", "vault": { … }, "idempotence_id": "20a3c79f-f547-44b3-bdfc-d8aea82ad496", "has_current_user_vault_permissions": true, "batch_data": { … }, "push_mode": "auto", "last_pushed_at": "2019-08-24T14:15:22Z", "sign_mode": "auto" }, "signatures": [ { … } ], "note": "string", "spam_state": "unset", "direction": "outgoing", "signed_externally": false, "interacted_vaults": [ { … } ], "related_transactions": [ { … } ], "state": "waiting_for_approval", "state_changes": [ { … } ], "type": "aptos_message", "aptos_message_type": "personal_message_type", "raw_original_message_to_sign": "SGVsbG8=", "string_original_message_to_sign": "string", "raw_full_message_to_sign": "SGVsbG8=", "string_full_message_to_sign": "string", "chain": { "chain_type": "aptos", "unique_id": "aptos_mainnet", "name": "string", "native_currency_symbol": "ETH", "native_currency_name": "Ether", "blockchain_explorer": { … }, "logo_url": "http://example.com", "is_testnet": true, "is_enabled": true }, "sender": { "vault": { … }, "explorer_url": "http://example.com", "contact": { … }, "type": "aptos", "address": "0x3300c18e7b931bdfc73dccf3e2d043ad1c9d120c777fff5aeeb9956224e5247a" } }
Aptos message type.
- aptos_message
- aptos_transaction
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
- Productionhttps://api.fordefi.com/api/v1/transactions/predict 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  https://api.fordefi.com/api/v1/transactions/predict \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "should_run_policy_check": true,
    "vault_id": "432b199b-1f71-42bf-ba0b-33d512afa9de",
    "note": "string",
    "type": "aptos_message",
    "details": {
      "type": "personal_message_type",
      "should_include_address": true,
      "application": "string",
      "should_include_application": true,
      "chain": "aptos_mainnet",
      "should_include_chain": true,
      "message_to_sign": "SGVsbG8=",
      "nonce": "string"
    }
  }'Successful Response
Aptos message type.
- aptos_message
- aptos_transaction
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
{ "policy_match": { "is_default": true, "rule_id": "728c1541-d6d1-4290-9a53-cdf01dd32d60", "rule_name": "string", "action_type": "allow" }, "matched_policies": [ { … } ], "approval_request": { "state": "created", "required_groups": 0, "approval_groups": [ … ], "error_message": "string" }, "risks": [ { … } ], "note": "string", "type": "aptos_message", "chain": { "chain_type": "aptos", "unique_id": "aptos_mainnet", "name": "string", "native_currency_symbol": "ETH", "native_currency_name": "Ether", "blockchain_explorer": { … }, "logo_url": "http://example.com", "is_testnet": true, "is_enabled": true }, "sender": { "vault": { … }, "explorer_url": "http://example.com", "contact": { … }, "type": "aptos", "address": "0x3300c18e7b931bdfc73dccf3e2d043ad1c9d120c777fff5aeeb9956224e5247a" }, "aptos_message_type": "personal_message_type", "message_to_display": "string" }
- Productionhttps://api.fordefi.com/api/v1/transactions/{id}/push 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  'https://api.fordefi.com/api/v1/transactions/{id}/push' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "push_data": {
      "type": "cosmos_transaction",
      "transaction_body": "SGVsbG8="
    }
  }'Successful Response
The date and time when the object was last modified. Any change to any field of the resource is considered a modification.
Whether the transaction was signed by an external user (for example in case of imported vault).
Aptos message type.
- aptos_message
- aptos_transaction
- black_box_signature
- cosmos_message
- cosmos_transaction
- evm_message
- evm_transaction
- exchange_transaction
- solana_message
- solana_transaction
- stacks_transaction
- starknet_message
- starknet_transaction
- sui_message
- sui_transaction
- ton_message
- ton_transaction
- tron_transaction
- utxo_message
- utxo_transaction
The original message that was requested to be signed, encoded in base64.
The full message to be signed, encoded in base64.
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "managed_transaction_data": { "created_by": { … }, "aborted_by": { … }, "device_signing_request": { … }, "approval_request": { … }, "aml_policy_match": { … }, "policy_match": { … }, "signer_type": "initiator", "risks": [ … ], "error_pushing_to_blockchain_message": "string", "original_error_pushing_to_blockchain_message": "string", "vault": { … }, "idempotence_id": "20a3c79f-f547-44b3-bdfc-d8aea82ad496", "has_current_user_vault_permissions": true, "batch_data": { … }, "push_mode": "auto", "last_pushed_at": "2019-08-24T14:15:22Z", "sign_mode": "auto" }, "signatures": [ { … } ], "note": "string", "spam_state": "unset", "direction": "outgoing", "signed_externally": false, "interacted_vaults": [ { … } ], "related_transactions": [ { … } ], "state": "waiting_for_approval", "state_changes": [ { … } ], "type": "aptos_message", "aptos_message_type": "personal_message_type", "raw_original_message_to_sign": "SGVsbG8=", "string_original_message_to_sign": "string", "raw_full_message_to_sign": "SGVsbG8=", "string_full_message_to_sign": "string", "chain": { "chain_type": "aptos", "unique_id": "aptos_mainnet", "name": "string", "native_currency_symbol": "ETH", "native_currency_name": "Ether", "blockchain_explorer": { … }, "logo_url": "http://example.com", "is_testnet": true, "is_enabled": true }, "sender": { "vault": { … }, "explorer_url": "http://example.com", "contact": { … }, "type": "aptos", "address": "0x3300c18e7b931bdfc73dccf3e2d043ad1c9d120c777fff5aeeb9956224e5247a" } }
- Productionhttps://api.fordefi.com/api/v1/transactions/{id}/update-spam-state 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X PUT \
  'https://api.fordefi.com/api/v1/transactions/{id}/update-spam-state' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "is_spam": true
  }'- Productionhttps://api.fordefi.com/api/v1/transactions/{id}/trigger-signing 
- curl
- Python
- JavaScript
- Go
- C#
- Payload
curl -i -X POST \
  'https://api.fordefi.com/api/v1/transactions/{id}/trigger-signing' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'Batch Transactions
These endpoints allow you to manage batch transactions on the Fordefi platform. 
 Batch transactions are currently supported only on Solana, for the purpose of supporting the signAllTransactions flow used by certain Solana DApps. Batch transactions undergo policy evaluation as a whole:  the policy is applied to a “virtual transaction” whose list of instructions is the union of the instructions of the individual transactions in the batch, and whose balance changes are the aggregation of balance changes of the individual transactions.
Vaults
These endpoints allow you to manage vaults. 
 A vault is the basic unit to manage funds. Each vault supports a single "chain family", such as EVM, Bitcoin, Solana, Cosmos, etc., determined by the vault's type. A vault supports all the chains within the chain family (e.g., an EVM vault supports all EVM chains).
Vault Groups
These endpoints allow you to view your vault groups. 
 Vault Groups are used to collectively manage policies and view permissions for a group of vaults. 
 The API is read-only. To manage vault groups, visit the Fordefi web console. See more info in the user guide.
Assets
These endpoints allow you to get information about the assets in your organization, including metadata, balances, and prices. 
 Fordefi supports native assets and fungible tokens on each of the supported blockchains, and on many chains also non-fungible tokens. 
 Assets are chain-specific, meaning that USDC on Ethereum is different from USDC on Polygon.
User Groups
These endpoints allow you to view your user groups. 
 User Groups are used to collectively manage policies and view permissions for a group of users. 
 The API is read-only. To manage user groups, visit the Fordefi web console. See more info in the user guide.