Skip to content

Latest commit

 

History

History
114 lines (81 loc) · 9.84 KB

Auth.md

File metadata and controls

114 lines (81 loc) · 9.84 KB

The auth Module

The auth module is responsible for authenticating accounts and transactions. auth is active on Cosmos Hub 3 and currently has five parameters that may be modified by governance proposal:

  1. MaxMemoCharacters - 512
  2. TxSigLimit - 7
  3. TxSizeCostPerByte - 10
  4. SigVerifyCostED25519 - 590
  5. SigVerifyCostSecp256k1 - 1000

The value for each launch parameter is outlined below, but you can verify them yourself.

If you're technically-inclined, these are the technical specifications. If you're looking to create a proposal to change one or more of these parameters, check out this section for formatting.

1. MaxMemoCharacters

The character limit for each transaction memo.

cosmoshub-3 default: 512

There is an option to include a "memo," or additional information (data) to Cosmos Hub transactions, whether sending funds, delegating, voting, or other transaction types. This parameter limits the number of characters that may be included in the memo line of each transaction.

Potential implications

Decreasing the value of MaxMemoCharacters

Decreasing the value of MaxMemoCharacters will decrease the character limit for each transaction memo. This may break the functionality of applications that rely upon the data in the memo field. For example, an exchange may use a common deposit address for all of its users, and then individualize account deposits using the memo field. If the memo field suddenly decreased, the exchange may no longer automatically sort its users' transactions.

Increasing the value of MaxMemoCharacters

Increasing the value of MaxMemoCharacters will increase the character limit for each transaction memo. This may enable new functionality for applications that use transaction memos. It may also enable an increase in the amount of data in each block, leading to an increased storage need for the blockchain and state bloat.

2. TxSigLimit

The max number of signatures per transaction

cosmoshub-3 default: 7

Users and applications may create multisignature (aka multisig) accounts. These accounts require more than one signature to generate a transaction. This parameter limits the number of signatures in a transaction.

Potential implications

Decreasing the value of TxSigLimit

Decreasing the value of TxSigLimit will decrease the maximum number of signatures possible. This may constrain stakeholders that want to use as many as seven signatures to authorize a transaction. It will also break the functionality of entities or applications dependent upon up to seven transactions, meaning that those transactions will no longer be able to be authorized. In this case, funds and functions controlled by a multisignature address will no longer be accessible, and funds may become stranded.

Increasing the value of TxSigLimit

Increasing the value of TxSigLimit will increase the maximum number of signatures possible. As this value increases, the network becomes more likely to be susceptible to attacks that slow block production, due to the burden of computational cost when verifying more signatures (since signature verification is costlier than other operations).

3. TxSizeCostPerByte

Sets the cost of transactions, in units of gas.

cosmoshub-3 default: 10

TxSizeCostPerByte is used to compute the gas-unit consumption for each transaction.

Potential implications

Decreasing the value of TxSizeCostPerByte

Decreasing the value of TxSizeCostPerByte will reduce the number of gas units used per transaction. This may also reduce the fees that validators earn for processing transactions. There may be other effects that have not been detailed here.

Increasing the value of TxSizeCostPerByte

Increasing the value of TxSizeCostPerByte will raise the number of gas units used per transaction. This may also increase the fees that validators earn for processing transactions. There may be other effects that have not been detailed here.

4. SigVerifyCostED25519

The cost for verifying ED25519 signatures, in units of gas.

cosmoshub-3 default: 590

Ed25519 is the EdDSA cryptographic signature scheme (using SHA-512 (SHA-2) and Curve25519) that is used by Cosmos Hub validators. SigVerifyCostED25519 is the gas (ie. computational) cost for verifying ED25519 signatures, and ED25519-based transactions are not currently accepted by the Cosmos Hub.

Potential implications

Decreasing the value of SigVerifyCostED25519

Decreasing the value of SigVerifyCostED25519 will decrease the amount of gas that is consumed by transactions that require Ed25519 signature verifications. Since Ed25519-signed transactions are not currently accepted by Cosmos Hub, changing this parameter is unlikely to affect stakeholders at this time.

Increasing the value of SigVerifyCostED25519

Increasing the value of SigVerifyCostED25519 will increase the amount of gas that is consumed by transactions that require Ed25519 signature verifications. Since Ed25519 signature transactions are not currently accepted by Cosmos Hub, changing this parameter is unlikely to affect stakeholders at this time.

Notes

Ed25519 signatures are not currently being accepted by the Cosmos Hub. Ed25519 signatures will be verified and can be considered valid, so the gas to verify them will be consumed. However, the transaction itself will be rejected. It could be that these signatures will be used for transactions a later time, such as after inter-blockchain communication (IBC) evidence upgrades happen.

5. SigVerifyCostSecp256k1

The cost for verifying Secp256k1 signatures, in units of gas.

cosmoshub-3 default: 1000

Secp256k1 is an elliptic curve domain parameter for cryptographic signatures used by user accounts in the Cosmos Hub. SigVerifyCostSecp256k1 is the gas (ie. computational) cost for verifying Secp256k1 signatures. Practically all Cosmos Hub transactions require Secp256k1 signature verifications.

Potential implications

Decreasing the value of SigVerifyCostSecp256k1

Decreasing the value of SigVerifyCostSecp256k1 will decrease the amount of gas that is consumed by practically all Cosmos Hub transactions, which require Secp256k1 signature verifications. Decreasing this parameter may have unintended effects on how the Cosmos Hub operates, since the computational cost of verifying a transaction may be greater than what the system's assumption is.

Increasing the value of SigVerifyCostSecp256k1

Increasing the value of SigVerifyCostSecp256k1 will increase the amount of gas that is consumed by practically all Cosmos Hub transactions, which require Secp256k1 signature verifications. Increasing this parameter may have unintended effects on how the Cosmos Hub operates, since the computational cost of verifying a transaction may be less than what the system's assumption is.

Notes

There should be a better understanding of what the potential implications are for changing SigVerifyCostSecp256k1. For example, gas calculations are important because blocks have a gas limit. Transactions could be rejected for exceeding the block gas limit, breaking application functionality or perhaps preventing addresses controlled by multiple signatures from moving funds.

Verify Parameter Values

Genesis (ie. most recent launch) Parameters

This is useful if you don't have gaiacli installed and don't have a reason to believe that the parameter has changed since the chain launched.

Each parameter may be verified in the chain's genesis file, found here. These are the parameters that the latest Cosmos Hub chain launched with, and will remain so, unless a governance proposal changes them. I've outlined those original values in the Technical Specifications section.

The genesis file is text-based and large. The genesis parameter naming scheme isn't identical to those listed above, so when I search, I put one underscore between upper and lowercase characters, then convert all characters to lowercase.

For example, if I want to search for MaxMemoCharacters, I'll search the genesis file for max_memo_characters.

Current Parameters

You may verify the current parameter values (in case they were modified via governance proposal post-launch) with the gaiacli command-line application. Here are the commands for each:

  1. MaxMemoCharacters - gaiacli q .. --> to do <--
  2. TxSigLimit -
  3. TxSizeCostPerByte -
  4. SigVerifyCostED25519 -
  5. SigVerifyCostSecp256k1

Technical Specifications

The auth module is responsible for specifying the base transaction and account types for an application, since the SDK itself is agnostic to these particulars. It contains the ante handler, where all basic transaction validity checks (signatures, nonces, auxiliary fields) are performed, and exposes the account keeper, which allows other modules to read, write, and modify accounts.

The auth module contains the following parameters:

Key Type cosmoshub-3 genesis setting
MaxMemoCharacters string (uint64) "512"
TxSigLimit string (uint64) "7"
TxSizeCostPerByte string (uint64) "10"
SigVerifyCostED25519 string (uint64) "590"
SigVerifyCostSecp256k1 string (uint64) "1000"