Fordefi API (0.2.0)

Download OpenAPI description
Languages
Servers
Production
https://api.fordefi.com/

Users

This resource collection represents users.

User types and roles

There are several types of user in the Fordefi platform:
  • Person: A human user of the platform. Only a person can have an admin role.
  • API User: An API client key that is trying to interact with the platform.See Create an API user and token.
  • API Signer: Used to auto-sign transactions. See Automate Signing with API Signer.
  • End user: For Consumer Wallets. It represents the user of a third-party platform.
In addition, for all users (except end users in WaaS solutions) there are three possible user 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 them.

Operations

Authorization Tokens

This resource collection represents authorization tokens.

These tokens allow end users to authenticate with Fordefi. Each end user can have a maximum of ten active authorization tokens at any time. Each token is valid for 24 hours only.

Instructions for creating an API user and token are provided here: Create an API user and token.

Operations

Blockchains

This resource collection represents blockchains.

Operations

Webhooks

This resource collection represents webhooks.

Use Webhooks describes how to configure webhooks, validate them, and resend them.

Operations

Address Book

This resource collection represents an address book.

Address Book is an object that represents a contact (saved blockchain address and its alias) in the platform. The Address Book object can either be queried directly or returned as part of a transaction.

Operations

Transactions

This resource collection represents a transaction.

A transaction is any object that can be signed cryptographically (with a private key).

In general, it can be one of the following types:

  • EVM Transaction: A native currency transfer or a smart contract call on an EVM-based chain.
  • EVM Message: In which a message is signed for off-chain use on an EVM-based chain.
  • Solana Transaction: A list of instructions to invoke on a Solana-based chain.
  • Cosmos Transaction: A transaction in the Cosmos ecosystem on Cosmos Hub or one of the supported app chains.
  • Black Box Signature: In which a payload is signed for use, external to the Fordefi platform.
  • Cosmos Message
  • Solana Message
For more information, see Transaction Types.

Monitor transactions

As transactions progress from creation through completion, they can follow several workflows, during which they take on various statuses. Status is returned in the state field of the Get Transaction and List Transaction requests.

For a list of possible statuses, see Transaction Lifecycle.

Operations

Batch Transactions

This resource collection represents a batch transaction.

Operations

Vaults

This resource collection represents a vault.

The vault is the basic unit to manage funds. A vault has a single public address but is multi-chain, meaning you can use it across all chains that are compatible with the address and are supported by Fordefi.

Operations

Vault Groups

This resource collection represents a vault group.

Operations

Assets

This resource collection represents assets.

  • 'Assets', in general, refer to the assets that are supported by Fordefi and can be held by an organization. The Fetch Asset Prices API, for example, returns the current prices of all the assets that are recognized by the system.
  • 'Owned assets' reflects the balance of specific assets that are owned by an organization.

Operations

End Users

This resource collection represents end users.

End users are the users of a third-party app that embeds cryptographic technology provided by Fordefi. Each end user's mobile device can have a unique key-share, where Fordefi holds the matching key-share.

Operations

List End Users

Request

Get a list of end users in the organization.

Query
sort_byArray of strings
Items Enum"created_asc""created_desc""end_user_last_login_asc""end_user_last_login_desc"
include_countboolean
Default false
pageinteger>= 1

The page number to fetch.

Default 1
sizeinteger[ 0 .. 100 ]

The number of items per page.

Default 50
user_idsArray of strings(uuid)

The unique identifiers of the users.

external_idsArray of strings

The external IDs of the users.

curl -i -X GET \
  'https://api.fordefi.com/api/v1/end-users?external_ids=string&include_count=false&page=1&size=50&sort_by=created_asc&user_ids=497f6eca-6276-4993-bfeb-53cbbbba6f08' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'

Responses

Successful Response

Bodyapplication/json
totalinteger
pageintegerrequired
sizeintegerrequired
end_usersArray of objectsrequired
Response
application/json
{ "total": 0, "page": 0, "size": 0, "end_users": [ { … } ] }

Create End User

Request

Create a new end user.

Bodyapplication/jsonrequired
external_idstringrequired

The ID that you assign to an end user.

curl -i -X POST \
  https://api.fordefi.com/api/v1/end-users \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "external_id": "string"
  }'

Responses

Successful Response

Bodyapplication/json
idstring(uuid)required

The unique identifier of the object in the Fordefi platform.

created_atstring(date-time)required

The date and time when the object was created.

modified_atstring(date-time)required

The date and time when the object was last modified. Any change to any field of the resource is considered a modification.

external_idstringrequired

The ID that you assigned to the end user.

Example: "user|1234"
last_login_atstring(date-time)required

The timestamp when the end user last logged into the mobile SDK.

desired_key_typesArray of strings

Desired key types. This field is populated by the user during keyset generation.

Items Enum"ecdsa_secp256k1""eddsa_ed25519""ecdsa_stark""schnorr_secp256k1"
keyset_idstring(uuid)required

The unique identifier of the keyset.

ecdsaobject

ECDSA key. The key is used to generate ECDSA-based vaults (for example, EVM vaults).

eddsaobject

EdDSA key. The key is used to generate EdDSA-based vaults (for example, Solana vaults).

ecdsa_starkobject

ECDSA-Stark key. The key is used to generate ECDSA-Stark-based vaults (for example, Stark Blackbox vaults).

schnorr_secp256k1object

Schnorr Secp256k1 key. The key is used to generate Schnorr-Secp256k1-based vaults.

auth_public_keystring

The public key of the user's auth-key.

Example: "SGVsbG8="
encrypted_device_shares_backupsArray of objects

Encrypted device shares backups.

last_backup_atstring(date-time)required

The last time backup was intitated.

export_allowedbooleanrequired

Whether the user is allowed to export the keyset.

last_export_atstring(date-time)required

The last time the keyset was exported.

encrypted_device_auth_keystringDeprecated

An encrypted backup of the user's auth-key.

Example: "SGVsbG8="
Response
application/json
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "external_id": "user|1234", "last_login_at": "2019-08-24T14:15:22Z", "desired_key_types": [ "ecdsa_secp256k1" ], "keyset_id": "0fd01f45-0fa7-45d1-9121-c431104386a5", "ecdsa": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "eddsa": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "ecdsa_stark": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "schnorr_secp256k1": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "auth_public_key": "SGVsbG8=", "encrypted_device_auth_key": "SGVsbG8=", "encrypted_device_shares_backups": [ { … } ], "last_backup_at": "2019-08-24T14:15:22Z", "export_allowed": true, "last_export_at": "2019-08-24T14:15:22Z" }

Get Current End User

Request

Gets the current end user.

curl -i -X GET \
  https://api.fordefi.com/api/v1/end-users/current \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'

Responses

Successful Response

Bodyapplication/json
idstring(uuid)required

The unique identifier of the object in the Fordefi platform.

created_atstring(date-time)required

The date and time when the object was created.

modified_atstring(date-time)required

The date and time when the object was last modified. Any change to any field of the resource is considered a modification.

external_idstringrequired

The ID that you assigned to the end user.

Example: "user|1234"
last_login_atstring(date-time)required

The timestamp when the end user last logged into the mobile SDK.

desired_key_typesArray of strings

Desired key types. This field is populated by the user during keyset generation.

Items Enum"ecdsa_secp256k1""eddsa_ed25519""ecdsa_stark""schnorr_secp256k1"
keyset_idstring(uuid)required

The unique identifier of the keyset.

ecdsaobject

ECDSA key. The key is used to generate ECDSA-based vaults (for example, EVM vaults).

eddsaobject

EdDSA key. The key is used to generate EdDSA-based vaults (for example, Solana vaults).

ecdsa_starkobject

ECDSA-Stark key. The key is used to generate ECDSA-Stark-based vaults (for example, Stark Blackbox vaults).

schnorr_secp256k1object

Schnorr Secp256k1 key. The key is used to generate Schnorr-Secp256k1-based vaults.

auth_public_keystring

The public key of the user's auth-key.

Example: "SGVsbG8="
encrypted_device_shares_backupsArray of objects

Encrypted device shares backups.

last_backup_atstring(date-time)required

The last time backup was intitated.

export_allowedbooleanrequired

Whether the user is allowed to export the keyset.

last_export_atstring(date-time)required

The last time the keyset was exported.

encrypted_device_auth_keystringDeprecated

An encrypted backup of the user's auth-key.

Example: "SGVsbG8="
Response
application/json
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "external_id": "user|1234", "last_login_at": "2019-08-24T14:15:22Z", "desired_key_types": [ "ecdsa_secp256k1" ], "keyset_id": "0fd01f45-0fa7-45d1-9121-c431104386a5", "ecdsa": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "eddsa": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "ecdsa_stark": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "schnorr_secp256k1": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "auth_public_key": "SGVsbG8=", "encrypted_device_auth_key": "SGVsbG8=", "encrypted_device_shares_backups": [ { … } ], "last_backup_at": "2019-08-24T14:15:22Z", "export_allowed": true, "last_export_at": "2019-08-24T14:15:22Z" }

Get End User

Request

Gets the end user that corresponds to the given ID.

Path
idstring(uuid)required

ID of the end user to retrieve.

curl -i -X GET \
  'https://api.fordefi.com/api/v1/end-users/{id}' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'

Responses

Successful Response

Bodyapplication/json
idstring(uuid)required

The unique identifier of the object in the Fordefi platform.

created_atstring(date-time)required

The date and time when the object was created.

modified_atstring(date-time)required

The date and time when the object was last modified. Any change to any field of the resource is considered a modification.

external_idstringrequired

The ID that you assigned to the end user.

Example: "user|1234"
last_login_atstring(date-time)required

The timestamp when the end user last logged into the mobile SDK.

desired_key_typesArray of strings

Desired key types. This field is populated by the user during keyset generation.

Items Enum"ecdsa_secp256k1""eddsa_ed25519""ecdsa_stark""schnorr_secp256k1"
keyset_idstring(uuid)required

The unique identifier of the keyset.

ecdsaobject

ECDSA key. The key is used to generate ECDSA-based vaults (for example, EVM vaults).

eddsaobject

EdDSA key. The key is used to generate EdDSA-based vaults (for example, Solana vaults).

ecdsa_starkobject

ECDSA-Stark key. The key is used to generate ECDSA-Stark-based vaults (for example, Stark Blackbox vaults).

schnorr_secp256k1object

Schnorr Secp256k1 key. The key is used to generate Schnorr-Secp256k1-based vaults.

auth_public_keystring

The public key of the user's auth-key.

Example: "SGVsbG8="
encrypted_device_shares_backupsArray of objects

Encrypted device shares backups.

last_backup_atstring(date-time)required

The last time backup was intitated.

export_allowedbooleanrequired

Whether the user is allowed to export the keyset.

last_export_atstring(date-time)required

The last time the keyset was exported.

encrypted_device_auth_keystringDeprecated

An encrypted backup of the user's auth-key.

Example: "SGVsbG8="
Response
application/json
{ "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "created_at": "2019-08-24T14:15:22Z", "modified_at": "2019-08-24T14:15:22Z", "external_id": "user|1234", "last_login_at": "2019-08-24T14:15:22Z", "desired_key_types": [ "ecdsa_secp256k1" ], "keyset_id": "0fd01f45-0fa7-45d1-9121-c431104386a5", "ecdsa": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "eddsa": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "ecdsa_stark": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "schnorr_secp256k1": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "xpub": "string", "encrypted_shares": { … }, "chain_code": "SGVsbG8=" }, "auth_public_key": "SGVsbG8=", "encrypted_device_auth_key": "SGVsbG8=", "encrypted_device_shares_backups": [ { … } ], "last_backup_at": "2019-08-24T14:15:22Z", "export_allowed": true, "last_export_at": "2019-08-24T14:15:22Z" }

Delete End User

Request

Delete an end user.

Path
idstring(uuid)required

ID of the end user to delete.

curl -i -X DELETE \
  'https://api.fordefi.com/api/v1/end-users/{id}' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>'

Responses

Successful Response

Bodyapplication/json
any
Response
application/json
null

Set Export End User Keys Permissions

Request

Allow or disable export of a keyset for an end user.

Path
idstring(uuid)required

ID of the end user to allow export.

Bodyapplication/jsonrequired
allowbooleanrequired

Allow or disable export

curl -i -X PUT \
  'https://api.fordefi.com/api/v1/end-users/{id}/set-export-end-user-keys-permissions' \
  -H 'Authorization: Bearer <YOUR_JWT_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "allow": true
  }'

Responses

Successful Response

Response
No content

User Groups

This resource collection represents user groups.

Operations

Exports

This resource collection represents asynchronous export states.

Operations

Organizations

Operations