feat(accounts): make x/accounts more depinject friendly (#21928)
This commit is contained in:
parent
7c6e0388a3
commit
7ce403f51e
@ -28,6 +28,7 @@ import (
|
||||
"cosmossdk.io/x/accounts/accountstd"
|
||||
baseaccount "cosmossdk.io/x/accounts/defaults/base"
|
||||
lockup "cosmossdk.io/x/accounts/defaults/lockup"
|
||||
"cosmossdk.io/x/accounts/defaults/multisig"
|
||||
"cosmossdk.io/x/accounts/testing/account_abstraction"
|
||||
"cosmossdk.io/x/accounts/testing/counter"
|
||||
"cosmossdk.io/x/authz"
|
||||
@ -315,6 +316,7 @@ func NewSimApp(
|
||||
accountstd.AddAccount(lockup.PERIODIC_LOCKING_ACCOUNT, lockup.NewPeriodicLockingAccount),
|
||||
accountstd.AddAccount(lockup.DELAYED_LOCKING_ACCOUNT, lockup.NewDelayedLockingAccount),
|
||||
accountstd.AddAccount(lockup.PERMANENT_LOCKING_ACCOUNT, lockup.NewPermanentLockingAccount),
|
||||
accountstd.AddAccount("multisig", multisig.NewAccount),
|
||||
// PRODUCTION: add
|
||||
baseaccount.NewAccount("base", txConfig.SignModeHandler(), baseaccount.WithSecp256K1PubKey()),
|
||||
)
|
||||
|
||||
@ -15,6 +15,9 @@ import (
|
||||
"cosmossdk.io/depinject"
|
||||
"cosmossdk.io/log"
|
||||
"cosmossdk.io/x/accounts"
|
||||
basedepinject "cosmossdk.io/x/accounts/defaults/base/depinject"
|
||||
lockupdepinject "cosmossdk.io/x/accounts/defaults/lockup/depinject"
|
||||
multisigdepinject "cosmossdk.io/x/accounts/defaults/multisig/depinject"
|
||||
bankkeeper "cosmossdk.io/x/bank/keeper"
|
||||
circuitkeeper "cosmossdk.io/x/circuit/keeper"
|
||||
consensuskeeper "cosmossdk.io/x/consensus/keeper"
|
||||
@ -155,6 +158,27 @@ func NewSimApp(
|
||||
// For providing a custom inflation function for x/mint add here your
|
||||
// custom function that implements the minttypes.MintFn interface.
|
||||
),
|
||||
depinject.Provide(
|
||||
// inject desired account types:
|
||||
multisigdepinject.ProvideAccount,
|
||||
basedepinject.ProvideAccount,
|
||||
lockupdepinject.ProvideAllLockupAccounts,
|
||||
|
||||
// provide base account options
|
||||
basedepinject.ProvideSecp256K1PubKey,
|
||||
// if you want to provide a custom public key you
|
||||
// can do it from here.
|
||||
// Example:
|
||||
// basedepinject.ProvideCustomPubkey[Ed25519PublicKey]()
|
||||
//
|
||||
// You can also provide a custom public key with a custom validation function:
|
||||
//
|
||||
// basedepinject.ProvideCustomPubKeyAndValidationFunc(func(pub Ed25519PublicKey) error {
|
||||
// if len(pub.Key) != 64 {
|
||||
// return fmt.Errorf("invalid pub key size")
|
||||
// }
|
||||
// })
|
||||
),
|
||||
)
|
||||
)
|
||||
|
||||
|
||||
@ -48,6 +48,7 @@ require (
|
||||
|
||||
require (
|
||||
cosmossdk.io/x/accounts/defaults/base v0.0.0-00010101000000-000000000000
|
||||
cosmossdk.io/x/accounts/defaults/multisig v0.0.0-00010101000000-000000000000
|
||||
google.golang.org/grpc v1.67.0
|
||||
)
|
||||
|
||||
@ -62,7 +63,6 @@ require (
|
||||
cloud.google.com/go/storage v1.43.0 // indirect
|
||||
cosmossdk.io/errors v1.0.1 // indirect
|
||||
cosmossdk.io/schema v0.3.0 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/multisig v0.0.0-00010101000000-000000000000 // indirect
|
||||
filippo.io/edwards25519 v1.1.0 // indirect
|
||||
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 // indirect
|
||||
github.com/99designs/keyring v1.2.2 // indirect
|
||||
|
||||
@ -13,6 +13,9 @@ import (
|
||||
"cosmossdk.io/log"
|
||||
"cosmossdk.io/runtime/v2"
|
||||
"cosmossdk.io/store/v2/root"
|
||||
basedepinject "cosmossdk.io/x/accounts/defaults/base/depinject"
|
||||
lockupdepinject "cosmossdk.io/x/accounts/defaults/lockup/depinject"
|
||||
multisigdepinject "cosmossdk.io/x/accounts/defaults/multisig/depinject"
|
||||
upgradekeeper "cosmossdk.io/x/upgrade/keeper"
|
||||
|
||||
"github.com/cosmos/cosmos-sdk/client"
|
||||
@ -119,6 +122,25 @@ func NewSimApp[T transaction.Tx](
|
||||
codec.ProvideAddressCodec,
|
||||
codec.ProvideProtoCodec,
|
||||
codec.ProvideLegacyAmino,
|
||||
// inject desired account types:
|
||||
multisigdepinject.ProvideAccount,
|
||||
basedepinject.ProvideAccount,
|
||||
lockupdepinject.ProvideAllLockupAccounts,
|
||||
|
||||
// provide base account options
|
||||
basedepinject.ProvideSecp256K1PubKey,
|
||||
// if you want to provide a custom public key you
|
||||
// can do it from here.
|
||||
// Example:
|
||||
// basedepinject.ProvideCustomPubkey[Ed25519PublicKey]()
|
||||
//
|
||||
// You can also provide a custom public key with a custom validation function:
|
||||
//
|
||||
// basedepinject.ProvideCustomPubKeyAndValidationFunc(func(pub Ed25519PublicKey) error {
|
||||
// if len(pub.Key) != 64 {
|
||||
// return fmt.Errorf("invalid pub key size")
|
||||
// }
|
||||
// })
|
||||
),
|
||||
depinject.Invoke(
|
||||
std.RegisterInterfaces,
|
||||
|
||||
@ -42,6 +42,12 @@ require (
|
||||
google.golang.org/protobuf v1.34.2
|
||||
)
|
||||
|
||||
require (
|
||||
cosmossdk.io/x/accounts/defaults/base v0.0.0-00010101000000-000000000000
|
||||
cosmossdk.io/x/accounts/defaults/lockup v0.0.0-00010101000000-000000000000
|
||||
cosmossdk.io/x/accounts/defaults/multisig v0.0.0-00010101000000-000000000000
|
||||
)
|
||||
|
||||
require (
|
||||
buf.build/gen/go/cometbft/cometbft/protocolbuffers/go v1.34.2-20240701160653-fedbb9acfd2f.2 // indirect
|
||||
buf.build/gen/go/cosmos/gogo-proto/protocolbuffers/go v1.34.2-20240130113600-88ef6483f90f.2 // indirect
|
||||
@ -59,9 +65,6 @@ require (
|
||||
cosmossdk.io/server/v2/appmanager v0.0.0-20240802110823-cffeedff643d // indirect
|
||||
cosmossdk.io/server/v2/stf v0.0.0-20240708142107-25e99c54bac1 // indirect
|
||||
cosmossdk.io/store v1.1.1 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/base v0.0.0-00010101000000-000000000000 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/lockup v0.0.0-20240417181816-5e7aae0db1f5 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/multisig v0.0.0-00010101000000-000000000000 // indirect
|
||||
cosmossdk.io/x/tx v0.13.5 // indirect
|
||||
filippo.io/edwards25519 v1.1.0 // indirect
|
||||
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 // indirect
|
||||
|
||||
@ -10,7 +10,6 @@ import (
|
||||
"cosmossdk.io/core/transaction"
|
||||
"cosmossdk.io/math"
|
||||
"cosmossdk.io/simapp"
|
||||
multisigaccount "cosmossdk.io/x/accounts/defaults/multisig"
|
||||
v1 "cosmossdk.io/x/accounts/defaults/multisig/v1"
|
||||
"cosmossdk.io/x/bank/testutil"
|
||||
|
||||
@ -76,7 +75,7 @@ func (s *E2ETestSuite) initAccount(ctx context.Context, sender []byte, membersPo
|
||||
members = append(members, &v1.Member{Address: addrStr, Weight: power})
|
||||
}
|
||||
|
||||
_, accountAddr, err := s.app.AccountsKeeper.Init(ctx, multisigaccount.MULTISIG_ACCOUNT, sender,
|
||||
_, accountAddr, err := s.app.AccountsKeeper.Init(ctx, "multisig", sender,
|
||||
&v1.MsgInit{
|
||||
Members: members,
|
||||
Config: &v1.Config{
|
||||
|
||||
@ -1,6 +1,95 @@
|
||||
# x/accounts
|
||||
# x/accounts Module
|
||||
|
||||
The x/accounts module provides module and facilities for writing smart cosmos-sdk accounts.
|
||||
The x/accounts module enhances the Cosmos SDK by providing tools and infrastructure for creating advanced smart accounts.
|
||||
|
||||
# The Authentication Interface
|
||||
|
||||
x/accounts introduces the `Authentication` interface, allowing for flexible transaction (TX) authentication beyond traditional public key cryptography.
|
||||
|
||||
Chain developers can implement tailored authentication methods for their accounts. Any account that implements the `Authentication` interface can be authenticated within a transaction.
|
||||
|
||||
To implement the `Authentication` interface in x/accounts, an account must expose an execution handler capable of processing a specific message type.
|
||||
|
||||
The key message type for authentication is `MsgAuthenticate`, which is defined in the module's protocol buffer files:
|
||||
|
||||
[interfaces/account_abstraction/v1/interface.proto](./proto/cosmos/accounts/interfaces/account_abstraction/v1/interface.proto)
|
||||
|
||||
## Authentication Mechanism
|
||||
|
||||
### AnteHandler in the SDK
|
||||
|
||||
The Cosmos SDK utilizes an `AnteHandler` to verify transaction (TX) integrity. Its primary function is to ensure that the messages within a transaction are correctly signed by the purported sender.
|
||||
|
||||
### Authentication Flow for x/accounts Module
|
||||
|
||||
When the `AnteHandler` identifies that a message sender (and transaction signer) belongs to the x/accounts module, it delegates the authentication process to that module.
|
||||
|
||||
#### Authentication Interface Requirement
|
||||
|
||||
For successful authentication, the account must implement the `Authentication` interface. If an account fails to implement this interface, it's considered non-externally owned, resulting in transaction rejection.
|
||||
|
||||
##### Sequence Diagram
|
||||
|
||||
```mermaid
|
||||
graph TD
|
||||
A[Tx Is Received] --> B[Execute Signature Verification Ante Handler]
|
||||
B --> D{Is signer an x/accounts account?}
|
||||
D -->|No| E[Continue with signature verification ante handler]
|
||||
D -->|Yes| F{Does account handle MsgAuthenticate?}
|
||||
F -->|No| G[Fail TX: Non-externally owned account]
|
||||
F -->|Yes| H[Invoke signer account MsgAuthenticate]
|
||||
E --> I[End]
|
||||
G --> I
|
||||
H --> I
|
||||
```
|
||||
|
||||
|
||||
## Implementing the Authentication Interface
|
||||
|
||||
To implement the Authentication interface, an account must handle the execution of `MsgAuthenticate`. Here's an example of how to do this:
|
||||
|
||||
```go
|
||||
package base
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
aa_interface_v1 "github.com/cosmos/cosmos-sdk/x/accounts/interfaces/account_abstraction/v1"
|
||||
"github.com/cosmos/cosmos-sdk/x/accounts/std"
|
||||
)
|
||||
|
||||
// Account represents a base account structure
|
||||
type Account struct {
|
||||
// Account fields...
|
||||
}
|
||||
|
||||
// Authenticate implements the authentication flow for an abstracted base account.
|
||||
func (a Account) Authenticate(ctx context.Context, msg *aa_interface_v1.MsgAuthenticate) (*aa_interface_v1.MsgAuthenticateResponse, error) {
|
||||
if !accountstd.SenderIsAccountsModule(ctx) {
|
||||
return nil, errors.New("unauthorized: only accounts module is allowed to call this")
|
||||
}
|
||||
// Implement your authentication logic here
|
||||
// ...
|
||||
return &aa_interface_v1.MsgAuthenticateResponse{}, nil
|
||||
}
|
||||
|
||||
// RegisterExecuteHandlers registers the execution handlers for the account.
|
||||
func (a Account) RegisterExecuteHandlers(builder *accountstd.ExecuteBuilder) {
|
||||
accountstd.RegisterExecuteHandler(builder, a.SwapPubKey) // Other handlers
|
||||
accountstd.RegisterExecuteHandler(builder, a.Authenticate) // Implements the Authentication interface
|
||||
}
|
||||
```
|
||||
|
||||
### Key Implementation Points
|
||||
|
||||
1. **Sender Verification**: Always verify that the sender is the x/accounts module. This prevents unauthorized accounts from triggering authentication.
|
||||
2. **Authentication Safety**: Ensure your authentication mechanism is secure:
|
||||
- Prevent replay attacks by making it impossible to reuse the same action with the same signature.
|
||||
|
||||
|
||||
#### Implementation example
|
||||
|
||||
Please find an example [here](./defaults/base/account.go).
|
||||
|
||||
# Supporting Custom Accounts in the x/auth gRPC Server
|
||||
|
||||
|
||||
@ -34,6 +34,16 @@ type InitBuilder = implementation.InitBuilder
|
||||
// AccountCreatorFunc is the exported type of AccountCreatorFunc.
|
||||
type AccountCreatorFunc = implementation.AccountCreatorFunc
|
||||
|
||||
func DIAccount[A Interface](name string, constructor func(deps Dependencies) (A, error)) DepinjectAccount {
|
||||
return DepinjectAccount{MakeAccount: AddAccount(name, constructor)}
|
||||
}
|
||||
|
||||
type DepinjectAccount struct {
|
||||
MakeAccount AccountCreatorFunc
|
||||
}
|
||||
|
||||
func (DepinjectAccount) IsManyPerContainerType() {}
|
||||
|
||||
// Dependencies is the exported type of Dependencies.
|
||||
type Dependencies = implementation.Dependencies
|
||||
|
||||
|
||||
@ -33,6 +33,8 @@ var (
|
||||
|
||||
type Option func(a *Account)
|
||||
|
||||
func (Option) IsManyPerContainerType() {}
|
||||
|
||||
func NewAccount(name string, handlerMap *signing.HandlerMap, options ...Option) accountstd.AccountCreatorFunc {
|
||||
return func(deps accountstd.Dependencies) (string, accountstd.Interface, error) {
|
||||
acc := Account{
|
||||
|
||||
31
x/accounts/defaults/base/depinject/depinject.go
Normal file
31
x/accounts/defaults/base/depinject/depinject.go
Normal file
@ -0,0 +1,31 @@
|
||||
package basedepinject
|
||||
|
||||
import (
|
||||
"cosmossdk.io/depinject"
|
||||
"cosmossdk.io/x/accounts/accountstd"
|
||||
"cosmossdk.io/x/accounts/defaults/base"
|
||||
"cosmossdk.io/x/tx/signing"
|
||||
)
|
||||
|
||||
type Inputs struct {
|
||||
depinject.In
|
||||
|
||||
SignHandlersMap *signing.HandlerMap
|
||||
Options []base.Option
|
||||
}
|
||||
|
||||
func ProvideAccount(in Inputs) accountstd.DepinjectAccount {
|
||||
return accountstd.DepinjectAccount{MakeAccount: base.NewAccount("base", in.SignHandlersMap, in.Options...)}
|
||||
}
|
||||
|
||||
func ProvideSecp256K1PubKey() base.Option {
|
||||
return base.WithSecp256K1PubKey()
|
||||
}
|
||||
|
||||
func ProvideCustomPubkey[T any, PT base.PubKeyG[T]]() base.Option {
|
||||
return base.WithPubKey[T, PT]()
|
||||
}
|
||||
|
||||
func ProvideCustomPubKeyAndValidationFunc[T any, PT base.PubKeyG[T]](validateFn func(PT) error) base.Option {
|
||||
return base.WithPubKeyWithValidationFunc(validateFn)
|
||||
}
|
||||
@ -6,6 +6,7 @@ require (
|
||||
cosmossdk.io/api v0.7.6
|
||||
cosmossdk.io/collections v0.4.0
|
||||
cosmossdk.io/core v1.0.0-alpha.3
|
||||
cosmossdk.io/depinject v1.0.0
|
||||
cosmossdk.io/x/accounts v0.0.0-20240913065641-0064ccbce64e
|
||||
cosmossdk.io/x/tx v0.13.3
|
||||
github.com/cosmos/cosmos-sdk v0.53.0
|
||||
@ -19,7 +20,6 @@ require (
|
||||
buf.build/gen/go/cometbft/cometbft/protocolbuffers/go v1.34.2-20240701160653-fedbb9acfd2f.2 // indirect
|
||||
buf.build/gen/go/cosmos/gogo-proto/protocolbuffers/go v1.34.2-20240130113600-88ef6483f90f.2 // indirect
|
||||
cosmossdk.io/core/testing v0.0.0-20240923163230-04da382a9f29 // indirect
|
||||
cosmossdk.io/depinject v1.0.0 // indirect
|
||||
cosmossdk.io/errors v1.0.1 // indirect
|
||||
cosmossdk.io/log v1.4.1 // indirect
|
||||
cosmossdk.io/math v1.3.0 // indirect
|
||||
@ -174,15 +174,7 @@ replace (
|
||||
cosmossdk.io/collections => ../../../../collections // TODO tag new collections ASAP
|
||||
cosmossdk.io/store => ../../../../store
|
||||
cosmossdk.io/x/accounts => ../../.
|
||||
cosmossdk.io/x/accounts/defaults/multisig => ../multisig
|
||||
cosmossdk.io/x/auth => ../../../auth
|
||||
cosmossdk.io/x/bank => ../../../bank
|
||||
cosmossdk.io/x/consensus => ../../../consensus
|
||||
cosmossdk.io/x/distribution => ../../../distribution
|
||||
cosmossdk.io/x/gov => ../../../gov
|
||||
cosmossdk.io/x/mint => ../../../mint
|
||||
cosmossdk.io/x/protocolpool => ../../../protocolpool
|
||||
cosmossdk.io/x/slashing => ../../../slashing
|
||||
cosmossdk.io/x/staking => ../../../staking
|
||||
cosmossdk.io/x/tx => ../../../tx
|
||||
)
|
||||
|
||||
31
x/accounts/defaults/lockup/depinject/depinject.go
Normal file
31
x/accounts/defaults/lockup/depinject/depinject.go
Normal file
@ -0,0 +1,31 @@
|
||||
package lockupdepinject
|
||||
|
||||
import (
|
||||
"cosmossdk.io/x/accounts/accountstd"
|
||||
"cosmossdk.io/x/accounts/defaults/lockup"
|
||||
)
|
||||
|
||||
func ProvideAllLockupAccounts() []accountstd.DepinjectAccount {
|
||||
return []accountstd.DepinjectAccount{
|
||||
ProvidePeriodicLockingAccount(),
|
||||
ProvideContinuousLockingAccount(),
|
||||
ProvidePermanentLockingAccount(),
|
||||
ProvideDelayedLockingAccount(),
|
||||
}
|
||||
}
|
||||
|
||||
func ProvideContinuousLockingAccount() accountstd.DepinjectAccount {
|
||||
return accountstd.DIAccount(lockup.CONTINUOUS_LOCKING_ACCOUNT, lockup.NewContinuousLockingAccount)
|
||||
}
|
||||
|
||||
func ProvidePeriodicLockingAccount() accountstd.DepinjectAccount {
|
||||
return accountstd.DIAccount(lockup.PERIODIC_LOCKING_ACCOUNT, lockup.NewPeriodicLockingAccount)
|
||||
}
|
||||
|
||||
func ProvideDelayedLockingAccount() accountstd.DepinjectAccount {
|
||||
return accountstd.DIAccount(lockup.DELAYED_LOCKING_ACCOUNT, lockup.NewDelayedLockingAccount)
|
||||
}
|
||||
|
||||
func ProvidePermanentLockingAccount() accountstd.DepinjectAccount {
|
||||
return accountstd.DIAccount(lockup.PERMANENT_LOCKING_ACCOUNT, lockup.NewPermanentLockingAccount)
|
||||
}
|
||||
@ -151,13 +151,8 @@ replace (
|
||||
cosmossdk.io/collections => ../../../../collections // TODO tag new collections ASAP
|
||||
cosmossdk.io/store => ../../../../store
|
||||
cosmossdk.io/x/accounts => ../../.
|
||||
cosmossdk.io/x/accounts/defaults/multisig => ../multisig
|
||||
cosmossdk.io/x/bank => ../../../bank
|
||||
cosmossdk.io/x/consensus => ../../../consensus
|
||||
cosmossdk.io/x/distribution => ../../../distribution
|
||||
cosmossdk.io/x/gov => ../../../gov
|
||||
cosmossdk.io/x/mint => ../../../mint
|
||||
cosmossdk.io/x/protocolpool => ../../../protocolpool
|
||||
cosmossdk.io/x/slashing => ../../../slashing
|
||||
cosmossdk.io/x/staking => ../../../staking
|
||||
cosmossdk.io/x/tx => ../../../tx
|
||||
)
|
||||
|
||||
@ -18,8 +18,6 @@ cosmossdk.io/math v1.3.0 h1:RC+jryuKeytIiictDslBP9i1fhkVm6ZDmZEoNP316zE=
|
||||
cosmossdk.io/math v1.3.0/go.mod h1:vnRTxewy+M7BtXBNFybkuhSH4WfedVAAnERHgVFhp3k=
|
||||
cosmossdk.io/schema v0.3.0 h1:01lcaM4trhzZ1HQTfTV8z6Ma1GziOZ/YmdzBN3F720c=
|
||||
cosmossdk.io/schema v0.3.0/go.mod h1:RDAhxIeNB4bYqAlF4NBJwRrgtnciMcyyg0DOKnhNZQQ=
|
||||
cosmossdk.io/x/tx v0.13.3 h1:Ha4mNaHmxBc6RMun9aKuqul8yHiL78EKJQ8g23Zf73g=
|
||||
cosmossdk.io/x/tx v0.13.3/go.mod h1:I8xaHv0rhUdIvIdptKIqzYy27+n2+zBVaxO6fscFhys=
|
||||
filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA=
|
||||
filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4=
|
||||
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 h1:/vQbFIOMbk2FiG/kXiLl8BRyzTWDw7gX/Hz7Dd5eDMs=
|
||||
|
||||
@ -16,8 +16,6 @@ import (
|
||||
"github.com/cosmos/cosmos-sdk/codec"
|
||||
)
|
||||
|
||||
var MULTISIG_ACCOUNT = "multisig-account"
|
||||
|
||||
var (
|
||||
MembersPrefix = collections.NewPrefix(0)
|
||||
SequencePrefix = collections.NewPrefix(1)
|
||||
|
||||
10
x/accounts/defaults/multisig/depinject/depinject.go
Normal file
10
x/accounts/defaults/multisig/depinject/depinject.go
Normal file
@ -0,0 +1,10 @@
|
||||
package multisigdepinject
|
||||
|
||||
import (
|
||||
"cosmossdk.io/x/accounts/accountstd"
|
||||
"cosmossdk.io/x/accounts/defaults/multisig"
|
||||
)
|
||||
|
||||
func ProvideAccount() accountstd.DepinjectAccount {
|
||||
return accountstd.DIAccount("multisig", multisig.NewAccount)
|
||||
}
|
||||
@ -175,12 +175,6 @@ replace (
|
||||
cosmossdk.io/store => ../../../../store
|
||||
cosmossdk.io/x/accounts => ../../.
|
||||
cosmossdk.io/x/bank => ../../../bank
|
||||
cosmossdk.io/x/consensus => ../../../consensus
|
||||
cosmossdk.io/x/distribution => ../../../distribution
|
||||
cosmossdk.io/x/gov => ../../../gov
|
||||
cosmossdk.io/x/mint => ../../../mint
|
||||
cosmossdk.io/x/protocolpool => ../../../protocolpool
|
||||
cosmossdk.io/x/slashing => ../../../slashing
|
||||
cosmossdk.io/x/staking => ../../../staking
|
||||
cosmossdk.io/x/tx => ../../../tx
|
||||
)
|
||||
|
||||
@ -1,19 +1,12 @@
|
||||
package accounts
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
modulev1 "cosmossdk.io/api/cosmos/accounts/module/v1"
|
||||
signingv1beta1 "cosmossdk.io/api/cosmos/tx/signing/v1beta1"
|
||||
"cosmossdk.io/core/address"
|
||||
"cosmossdk.io/core/appmodule"
|
||||
"cosmossdk.io/depinject"
|
||||
"cosmossdk.io/depinject/appconfig"
|
||||
"cosmossdk.io/x/accounts/accountstd"
|
||||
baseaccount "cosmossdk.io/x/accounts/defaults/base"
|
||||
"cosmossdk.io/x/accounts/defaults/lockup"
|
||||
"cosmossdk.io/x/accounts/defaults/multisig"
|
||||
"cosmossdk.io/x/tx/signing"
|
||||
|
||||
"github.com/cosmos/cosmos-sdk/codec"
|
||||
cdctypes "github.com/cosmos/cosmos-sdk/codec/types"
|
||||
@ -39,6 +32,7 @@ type ModuleInputs struct {
|
||||
AddressCodec address.Codec
|
||||
Registry cdctypes.InterfaceRegistry
|
||||
|
||||
Accounts []accountstd.DepinjectAccount // how can the account impls provide this??
|
||||
// TODO: Add a way to inject custom accounts.
|
||||
// Currently only the base account is supported.
|
||||
}
|
||||
@ -50,32 +44,19 @@ type ModuleOutputs struct {
|
||||
Module appmodule.AppModule
|
||||
}
|
||||
|
||||
var _ signing.SignModeHandler = directHandler{}
|
||||
|
||||
type directHandler struct{}
|
||||
|
||||
func (s directHandler) Mode() signingv1beta1.SignMode {
|
||||
return signingv1beta1.SignMode_SIGN_MODE_DIRECT
|
||||
}
|
||||
|
||||
func (s directHandler) GetSignBytes(_ context.Context, _ signing.SignerData, _ signing.TxData) ([]byte, error) {
|
||||
panic("not implemented")
|
||||
}
|
||||
|
||||
func ProvideModule(in ModuleInputs) ModuleOutputs {
|
||||
handler := directHandler{}
|
||||
account := baseaccount.NewAccount("base", signing.NewHandlerMap(handler), baseaccount.WithSecp256K1PubKey())
|
||||
accountskeeper, err := NewKeeper(
|
||||
in.Cdc, in.Environment, in.AddressCodec, in.Registry, account,
|
||||
accountstd.AddAccount(lockup.CONTINUOUS_LOCKING_ACCOUNT, lockup.NewContinuousLockingAccount),
|
||||
accountstd.AddAccount(lockup.PERIODIC_LOCKING_ACCOUNT, lockup.NewPeriodicLockingAccount),
|
||||
accountstd.AddAccount(lockup.DELAYED_LOCKING_ACCOUNT, lockup.NewDelayedLockingAccount),
|
||||
accountstd.AddAccount(lockup.PERMANENT_LOCKING_ACCOUNT, lockup.NewPermanentLockingAccount),
|
||||
accountstd.AddAccount(multisig.MULTISIG_ACCOUNT, multisig.NewAccount),
|
||||
accCreators := make([]accountstd.AccountCreatorFunc, len(in.Accounts))
|
||||
for i, acc := range in.Accounts {
|
||||
accCreators[i] = acc.MakeAccount
|
||||
}
|
||||
|
||||
accountsKeeper, err := NewKeeper(
|
||||
in.Cdc, in.Environment, in.AddressCodec, in.Registry,
|
||||
accCreators...,
|
||||
)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
m := NewAppModule(in.Cdc, accountskeeper)
|
||||
return ModuleOutputs{AccountsKeeper: accountskeeper, Module: m}
|
||||
m := NewAppModule(in.Cdc, accountsKeeper)
|
||||
return ModuleOutputs{AccountsKeeper: accountsKeeper, Module: m}
|
||||
}
|
||||
|
||||
@ -8,8 +8,6 @@ require (
|
||||
cosmossdk.io/core v1.0.0-alpha.3
|
||||
cosmossdk.io/core/testing v0.0.0-20240923163230-04da382a9f29
|
||||
cosmossdk.io/depinject v1.0.0
|
||||
cosmossdk.io/x/accounts/defaults/base v0.0.0-00010101000000-000000000000
|
||||
cosmossdk.io/x/accounts/defaults/multisig v0.0.0-00010101000000-000000000000
|
||||
cosmossdk.io/x/bank v0.0.0-20240226161501-23359a0b6d91
|
||||
cosmossdk.io/x/tx v0.13.3
|
||||
github.com/cosmos/cosmos-sdk v0.53.0
|
||||
@ -35,8 +33,6 @@ require (
|
||||
cosmossdk.io/math v1.3.0
|
||||
cosmossdk.io/schema v0.3.0 // indirect
|
||||
cosmossdk.io/store v1.1.1-0.20240418092142-896cdf1971bc // indirect
|
||||
cosmossdk.io/x/accounts/defaults/lockup v0.0.0-20240417181816-5e7aae0db1f5
|
||||
cosmossdk.io/x/distribution v0.0.0-00010101000000-000000000000 // indirect
|
||||
cosmossdk.io/x/staking v0.0.0-00010101000000-000000000000 // indirect
|
||||
filippo.io/edwards25519 v1.1.0 // indirect
|
||||
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 // indirect
|
||||
@ -181,13 +177,7 @@ replace (
|
||||
cosmossdk.io/api => ../../api
|
||||
cosmossdk.io/collections => ../../collections
|
||||
cosmossdk.io/store => ../../store
|
||||
cosmossdk.io/x/accounts/defaults/base => ./defaults/base // REMOVE this when
|
||||
cosmossdk.io/x/accounts/defaults/lockup => ./defaults/lockup
|
||||
cosmossdk.io/x/accounts/defaults/multisig => ./defaults/multisig
|
||||
cosmossdk.io/x/bank => ../bank
|
||||
cosmossdk.io/x/distribution => ../distribution
|
||||
cosmossdk.io/x/mint => ../mint
|
||||
cosmossdk.io/x/slashing => ../slashing
|
||||
cosmossdk.io/x/staking => ../staking
|
||||
cosmossdk.io/x/tx => ../tx
|
||||
)
|
||||
|
||||
@ -49,9 +49,10 @@ type ModuleInputs struct {
|
||||
type ModuleOutputs struct {
|
||||
depinject.Out
|
||||
|
||||
BaseAppOption runtime.BaseAppOption // This is only useful for chains using baseapp.
|
||||
TxConfig client.TxConfig
|
||||
TxConfigOptions tx.ConfigOptions
|
||||
BaseAppOption runtime.BaseAppOption // This is only useful for chains using baseapp.
|
||||
TxConfig client.TxConfig
|
||||
TxConfigOptions tx.ConfigOptions
|
||||
TxSigningHandlerMap *txsigning.HandlerMap
|
||||
}
|
||||
|
||||
func ProvideProtoRegistry() txsigning.ProtoFileResolver {
|
||||
@ -89,8 +90,9 @@ func ProvideModule(in ModuleInputs) ModuleOutputs {
|
||||
app.SetTxDecoder(txConfig.TxDecoder())
|
||||
app.SetTxEncoder(txConfig.TxEncoder())
|
||||
},
|
||||
TxConfig: txConfig,
|
||||
TxConfigOptions: txConfigOptions,
|
||||
TxConfig: txConfig,
|
||||
TxConfigOptions: txConfigOptions,
|
||||
TxSigningHandlerMap: txConfig.SignModeHandler(),
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -39,10 +39,6 @@ require (
|
||||
buf.build/gen/go/cosmos/gogo-proto/protocolbuffers/go v1.34.2-20240130113600-88ef6483f90f.2 // indirect
|
||||
cosmossdk.io/collections v0.4.0 // indirect
|
||||
cosmossdk.io/schema v0.3.0 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/base v0.0.0-00010101000000-000000000000 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/lockup v0.0.0-20240417181816-5e7aae0db1f5 // indirect
|
||||
cosmossdk.io/x/accounts/defaults/multisig v0.0.0-00010101000000-000000000000 // indirect
|
||||
cosmossdk.io/x/distribution v0.0.0-00010101000000-000000000000 // indirect
|
||||
cosmossdk.io/x/epochs v0.0.0-20240522060652-a1ae4c3e0337 // indirect
|
||||
cosmossdk.io/x/tx v0.13.3 // indirect
|
||||
filippo.io/edwards25519 v1.1.0 // indirect
|
||||
|
||||
Loading…
Reference in New Issue
Block a user