Configuring Multiple API Co-signers in High Availability

Overview

You can configure multiple API Co-signers to operate in an active-active state, ensuring transaction operations align with your business continuity requirements. If one API Co-signer fails or becomes impaired, the remaining Co-signer(s) will continue signing transactions seamlessly.



Configuring multiple Co-Signers to work in parallel

Upon completing the Co-signer's setup and configuration, you can configure them to work in parallel using the Transaction Authorization Policy (TAP).

Each API Co-signer must have at least one API user assigned the Signer role. These API users should be added to the Designated Signers / Groups field in the TAP for the transaction types the Co-signers are authorized to sign. You can add API users individually or as part of a user group. All designated signers for the rule must be API users. A combination of API users and Fireblocks Console users is not permitted. Refer to the following article to learn more about creating and modifying your TAP.

Once the Owner and Admin Quorum approve the TAP update, multiple Co-signers operate in parallel. Now, the transaction signing process follows these steps:

  1. A transaction is initiated using the Console or APIs.
  2. Fireblocks evaluates the transaction against the workspace's TAP to match it with the appropriate rule. The rule includes API users in the Designated Signers/Groups field.
  3. Fireblocks calls all the Co-signers that are paired with the API users listed in the TAP rule's Designated Signers/Groups field to confirm their availability for signing.
  4. Fireblocks identifies the first available API user with a paired Co-signer and sends the transaction to that Co-signer for signing.
  5. If a Callback Handler is configured for the API Co-signer, it determines whether the transaction is signed or rejected based on the defined callback logic. If no Callback Handler is configured, the API user signs the transaction automatically.


Configuring TAP rules for a group of API Co-signers

Exchange or fiat accounts

You cannot add multiple API users or a user group to the Designated Signers/Groups field in rules in which the Source field contains an exchange or fiat account. Doing so causes transactions that match that rule to fail automatically. You must assign a single API user in TAP rules for exchange and fiat accounts.


TAP Configuration

Depending on how you want to customize the TAP (i.e., whether you create inclusionary or exclusionary rules), you can use different methods to ensure transactions match the correct rule. In the following examples, Group 1 members are the API Co-Signers.

Method 1: Including API Co-Signers only for supported sources

RuleInitiatorTypeSourceDest.Whitelisted / OTAAmountTime PeriodAssetActionApproved ByDesignated Signers / Group
1AnyTxAny VAAnyWhitelisted + OTA$0Single TxAnyAllow-Group 1
2AnyTxAnyAnyWhitelisted + OTA$0Single TxAnyApproved ByTywin-

The rules in the table above state:

  • Rule 1: This rule allows any single transaction from any vault account to any whitelisted destination or one-time address with an amount greater than $0 from any asset. However, all transactions that match this rule must be signed by one of the Group 1 members.
  • Rule 2: This rule allows any single transaction from any source to any whitelisted destination or one-time address with an amount greater than $0 from any asset. However, all transactions that match this rule must be approved by Tywin.

Therefore, according to the first match principle, the API Co-signers only sign single transactions in which the source is a vault account.


Method 2: Excluding API Co-Signers from unsupported sources

RuleInitiatorTypeSourceDest.Whitelisted / OTAAmountTime PeriodAssetActionApproved ByDesignated Signers / Group
1AnyTxAny Exchange, Any FiatAnyWhitelisted + OTA$0Single TxAnyApproved ByTywin-
2AnyTxAnyAnyWhitelisted + OTA$0Single TxAnyApproved ByTywinGroup 1

The rules in the table above state:

  • Rule 1: This rule allows any single transaction from any exchange or any fiat account to any whitelisted destination or one-time address with an amount greater than $0 from any asset. However, all transactions that match this rule must be approved by Tywin.
  • Rule 2: This rule allows any single transaction from any source to any whitelisted destination or one-time address with an amount greater than $0 from any asset. However, all transactions that match this rule must be approved by Tywin and then signed by one of the members from Group 1.

Therefore, according to the first match principle, the API Co-Signers only sign single transactions in which the source is not an exchange or a fiat account.



Multiple API Co-signers deployment options

Co-signers can be deployed either in the cloud or on-premise, depending on your requirements. For example, you can implement a cluster with three Co-signers in an active-active-passive architecture as follows:

  • Active-Active Co-signers: Two API Co-signers are deployed in separate availability zones within a cloud service provider. This configuration eliminates a single point of failure and ensures continuous operation without downtime.
  • Passive Co-signer: A third API Co-signer is deployed on-premise as a failover. This on-premise Co-signer ensures redundancy, allowing for uninterrupted operation during updates or maintenance of the cloud-based Co-signers.