Multisignature transactions
Status | DECIDED |
---|---|
Stakeholders | |
Outcome | Error rendering macro 'jira' : null |
Due date | |
Owner |
Background
At the time of writing Iroha works with single-signature transactions which are accepted by the peers signed only by one signatory. However in some cases it is not enough.
Problem
There is a need for transactions that should be signed by several signatories from the same account for security purposes when dealing with large sums of money. Also it is planned to support conditional multisig (for example to support typical scenarios as two tellers should sign or one manager should sign). The detailed description of conditional multisig can be found in the whitepaper.
Requirements
From Iroha 1:
A transaction which has the quorum greater than one is considered as multisignature (also called mst). To achieve stateful validity the confirmation is required by the signatories of the creator account. These participants need to send the same transaction with their signature.
And from Iroha 1 again:
Multisignature Transactions Processor
It is an internal gRPC service that sends and receives messages from other peers through Gossip protocol. Its mission is to send out multisignature transactions that have not received enough signatures to reach the quorum until it is reached.
From Vadim Reutskiy
1. To have quorum in each account and possibility to change it by the command (+ corresponding permissions)
2. To have possibility to configure list of signatories for the current account (+ corresponding permissions)
3. To have possibility to get list of pending transactions waiting for the additional signatures (related to the current account or in network in general + corresponding permissions)
4. Configuration of the time, while pending transactions will be in the pending list before being rejected
5. Corresponding checks in stateful validation to check all these rules
6. Corresponding checks and sync in the block proposal algorithm, consensus and mechanism of syncing the list of pending MST transactions between all nodes.
7. Place for future insertion of the conditional logic for MST checkups
Conditional multisignature
From the whitepaper: https://github.com/hyperledger/iroha/blob/iroha2-dev/iroha_2_whitepaper.md#conditional-multisignature
Let's consider a situation where a bank wants to allow either 2 tellers or 1 manager to sign off on any transfer transaction over $500 and under $1000. In this case, the condition will be: Condition.asset("usd@nbc").qty(500).comparison(">").qty(1000).comparison("<") and the signatory_sets for the tellers and manager will be OR unioned, so that either the m-of-n signatues from the tellers or the single signature from the manager will be acceptable for transaction signing.
Solution
Second version of Iroha evolved the design of Iroha 1.x and can't use the same approach while it works to address requirements.
Conditional mutlisig
The conditional multisig is planned to be implemented with the support of the Expressions that let the user to define their own conditions. An example implementation of the whitepaper scenario is given in one of the expression tests.
Transaction Pipeline
In Iroha2 there will not be a strict division between a multisig and a simple transaction. Instead transactions will be collected on the leader peer in a queue until the moment its account's `signature_condition` (in the form of Expressions) is true for this transaction or dropped when its TTL is reached.
Client Side Interaction
Iroha 1.x Approach
It was considered to use the same approach as in Iroha 1.x and to send the same transaction several times with different signatures from the client. But there is a following problem with this approach:
Transaction hash incorporates the timestamp of transaction creation in Iroha2. So even if transaction were sent with the same contents, the hash because of the timestamp will be different, and therefore it would be impossible to aggregate signatures (which have hash as a payload).
Iroha 2 Approach
Therefore in Iroha2 the following approach is planned to be used.
- First client to submit the MST transactions, submits it normally as any other transaction
- Other clients that want to add signatures to this tx request this pending tx from the Iroha peer and sign it with their signature and resubmit it.
But the UX does not need to change for the end user. For example:
- User wants to submit a transaction
- Client library requests if there are any transactions waiting for signatures from this account
- If there are, it acquires them and compares to the one that user wants to submit
- If contents of transaction match excluding the timestamp
- Client library asks if the user wants to add a signature to already existing transaction
Therefore users may submit MST asynchronously without the knowledge of who submitted it first.