sov-accounts
module
The sov-accounts
module is responsible for managing accounts on the rollup.
Account is represented by an Address
and a Nonce
.
Warning
The accounts module implements TxHooks
which must be wired into your state transition function! Be sure that your Runtime
implementation for TxHooks
delegates to the sov-accounts.
The sov-accounts
module offers the following functionality:
-
When a sender sends their first message, the
sov-accounts
module will create a new address by deriving it from the sender's public key. The module will then add a mapping between the public key and the address to its state. For all subsequent messages that include the sender's public key, the module will retrieve the sender's address from the mapping and pass it along with the original message to an intended module. -
It is possible to update the public key associated with a given address using the
CallMessage::UpdatePublicKey(..)
message. To do so, the sender must prove that they possess the private key that corresponds to the new public key. -
Each processed message increases the account nonce. This serves to protect against double-spending attacks and ensures proper transaction ordering.
-
It is possible to query the
sov-accounts
module using theget_account
method and get the account corresponding to the given public key.
The sov-accounts
module makes the following guarantees:
-
At some point in time, the sender has provided proof that they possessed the private key corresponding to the public key associated with the address.
-
The account nonce is increased on every processed message by 1.