cosmos-sdk/x/accounts
fudancoder 433e3fd6d9
chore: make function comment match function names (#20666)
Signed-off-by: fudancoder <fudancoder@icloud.com>
2024-06-13 21:45:49 +00:00
..
accountstd feat(core): add coretest package (#20487) 2024-06-05 22:11:33 +00:00
cli feat(accounts): add genesis account initialization (#20642) 2024-06-12 14:19:13 +00:00
defaults chore: make function comment match function names (#20666) 2024-06-13 21:45:49 +00:00
interfaces/account_abstraction/v1 perf!: Make slashing not write sign info every block (#19458) 2024-02-20 16:51:02 +00:00
internal feat(core): add coretest package (#20487) 2024-06-05 22:11:33 +00:00
proto feat(accounts): add genesis account initialization (#20642) 2024-06-12 14:19:13 +00:00
testing chore: migrate sdk.Msg to transaction.type (#20273) 2024-05-10 10:23:22 +00:00
v1 feat(accounts): add genesis account initialization (#20642) 2024-06-12 14:19:13 +00:00
account_test.go feat(accounts): use gogoproto API instead of protov2. (#18653) 2023-12-08 13:17:48 +00:00
CHANGELOG.md feat(x/accounts): On-chain multisig (#19988) 2024-05-06 11:26:49 +00:00
coin_transfer.go refactor(accounts): Remove UserOperation in favour of using Tx for abstracted accounts (#19395) 2024-02-15 12:24:33 +00:00
depinject.go test(accounts): add multisig e2e tests (#20310) 2024-05-13 12:53:15 +00:00
genesis_test.go fix (x/accounts): Fix genesis condition check (#20645) 2024-06-12 16:25:02 +00:00
genesis.go fix (x/accounts): Fix genesis condition check (#20645) 2024-06-12 16:25:02 +00:00
go.mod build(deps): Bump google.golang.org/protobuf from 1.34.1 to 1.34.2 (#20632) 2024-06-13 08:57:14 +00:00
go.sum build(deps): Bump google.golang.org/protobuf from 1.34.1 to 1.34.2 (#20632) 2024-06-13 08:57:14 +00:00
keeper_account_abstraction.go refactor(accounts): Remove UserOperation in favour of using Tx for abstracted accounts (#19395) 2024-02-15 12:24:33 +00:00
keeper_test.go feat(x/accounts): use router service from env (#20003) 2024-04-15 15:41:11 +00:00
keeper.go feat(accounts): add genesis account initialization (#20642) 2024-06-12 14:19:13 +00:00
module.go refactor: rename core.registry.LegacyRegistry -> core.registry.InterfaceRegistrar (#19758) 2024-03-14 17:53:31 +00:00
msg_server_test.go feat(x/accounts): use router service from env (#20003) 2024-04-15 15:41:11 +00:00
msg_server.go feat(accounts): add genesis account initialization (#20642) 2024-06-12 14:19:13 +00:00
query_server_test.go feat(x/accounts): Add schema caching feature and corresponding test case (#20055) 2024-05-17 05:11:45 +00:00
query_server.go feat(x/accounts): Add schema caching feature and corresponding test case (#20055) 2024-05-17 05:11:45 +00:00
README.md feat(accounts): add genesis account initialization (#20642) 2024-06-12 14:19:13 +00:00
sonar-project.properties chore: force reload sonar cloud (#20480) 2024-05-29 11:12:09 +00:00
utils_test.go feat(core): add coretest package (#20487) 2024-06-05 22:11:33 +00:00

x/accounts

The x/accounts module provides module and facilities for writing smart cosmos-sdk accounts.

Genesis

Creating accounts on genesis

In order to create accounts at genesis, the x/accounts module allows developers to provide a list of genesis MsgInit messages that will be executed in the x/accounts genesis flow.

The init messages are generated offline. You can also use the following CLI command to generate the json messages: simd accounts tx init [account type] [msg] --from me --genesis. This will generate a jsonified init message wrapped in an x/accounts MsgInit.

This follows the same initialization flow and rules that would happen if the chain is running. The only concrete difference is that this is happening at the genesis block.

For example, given the following genesis.json file:

{
  "app_state": {
    "accounts": {
      "init_account_msgs": [
        {
          "sender": "account_creator_address",
          "account_type": "lockup",
          "message": {
            "@type": "cosmos.accounts.defaults.lockup.MsgInitLockupAccount",
            "owner": "some_owner",
            "end_time": "..",
            "start_time": ".."
          },
          "funds": [
            {
              "denom": "stake",
              "amount": "1000"
            }
          ]
        }
      ]
    }
  }
}

The accounts module will run the lockup account initialization message.