* Add proto files for onboarding module * Add generated proto bindings * Define onboarding object * Define the participants state in keeper * Update genesis file to initialize and export module state to/from genesis * Add msg to onboard participant * Register command to enroll participant * Add functionality to decode ethereum address from signature * Add comments for messages and fields * Fix lint errors in proto files * Add message validation and events in msg_server * Reuse crypto utils from go-nitro * Sign entire eth_payload object * Use google API for rpc method * Regenerate proto bindings --------- Co-authored-by: Prathamesh Musale <prathamesh.musale0@gmail.com>
		
			
				
	
	
		
			119 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package module
 | |
| 
 | |
| import (
 | |
| 	"encoding/json"
 | |
| 	"fmt"
 | |
| 
 | |
| 	"cosmossdk.io/core/appmodule"
 | |
| 	gwruntime "github.com/grpc-ecosystem/grpc-gateway/runtime"
 | |
| 
 | |
| 	"github.com/cosmos/cosmos-sdk/client"
 | |
| 	"github.com/cosmos/cosmos-sdk/codec"
 | |
| 	codectypes "github.com/cosmos/cosmos-sdk/codec/types"
 | |
| 	sdk "github.com/cosmos/cosmos-sdk/types"
 | |
| 	"github.com/cosmos/cosmos-sdk/types/module"
 | |
| 
 | |
| 	"git.vdb.to/cerc-io/laconicd/x/onboarding"
 | |
| 	"git.vdb.to/cerc-io/laconicd/x/onboarding/keeper"
 | |
| )
 | |
| 
 | |
| var (
 | |
| 	_ module.AppModuleBasic = AppModule{}
 | |
| 	_ module.HasGenesis     = AppModule{}
 | |
| 	_ appmodule.AppModule   = AppModule{}
 | |
| )
 | |
| 
 | |
| // ConsensusVersion defines the current module consensus version.
 | |
| const ConsensusVersion = 1
 | |
| 
 | |
| type AppModule struct {
 | |
| 	cdc    codec.Codec
 | |
| 	keeper *keeper.Keeper
 | |
| }
 | |
| 
 | |
| // NewAppModule creates a new AppModule object
 | |
| func NewAppModule(cdc codec.Codec, keeper *keeper.Keeper) AppModule {
 | |
| 	return AppModule{
 | |
| 		cdc:    cdc,
 | |
| 		keeper: keeper,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func NewAppModuleBasic(m AppModule) module.AppModuleBasic {
 | |
| 	return module.CoreAppModuleBasicAdaptor(m.Name(), m)
 | |
| }
 | |
| 
 | |
| // Name returns the onboarding module's name.
 | |
| func (AppModule) Name() string { return onboarding.ModuleName }
 | |
| 
 | |
| // RegisterLegacyAminoCodec registers the onboarding module's types on the LegacyAmino codec.
 | |
| // New modules do not need to support Amino.
 | |
| func (AppModule) RegisterLegacyAminoCodec(cdc *codec.LegacyAmino) {}
 | |
| 
 | |
| // RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the onboarding module.
 | |
| func (AppModule) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *gwruntime.ServeMux) {
 | |
| 	// TODO: Implement
 | |
| 	// if err := onboarding.RegisterQueryHandlerClient(context.Background(), mux, onboarding.NewQueryClient(clientCtx)); err != nil {
 | |
| 	//     panic(err)
 | |
| 	// }
 | |
| }
 | |
| 
 | |
| // RegisterInterfaces registers interfaces and implementations of the onboarding module.
 | |
| func (AppModule) RegisterInterfaces(registry codectypes.InterfaceRegistry) {
 | |
| 	onboarding.RegisterInterfaces(registry)
 | |
| }
 | |
| 
 | |
| // ConsensusVersion implements AppModule/ConsensusVersion.
 | |
| func (AppModule) ConsensusVersion() uint64 { return ConsensusVersion }
 | |
| 
 | |
| // RegisterServices registers a gRPC query service to respond to the module-specific gRPC queries.
 | |
| func (am AppModule) RegisterServices(cfg module.Configurator) {
 | |
| 	// TODO: Implement
 | |
| 	// Register servers
 | |
| 	onboarding.RegisterMsgServer(cfg.MsgServer(), keeper.NewMsgServerImpl(am.keeper))
 | |
| 	// onboarding.RegisterQueryServer(cfg.QueryServer(), keeper.NewQueryServerImpl(am.keeper))
 | |
| 
 | |
| 	// Register in place module state migration migrations
 | |
| 	// m := keeper.NewMigrator(am.keeper)
 | |
| 	// if err := cfg.RegisterMigration(onboarding.ModuleName, 1, m.Migrate1to2); err != nil {
 | |
| 	//     panic(fmt.Sprintf("failed to migrate x/%s from version 1 to 2: %v", onboarding.ModuleName, err))
 | |
| 	// }
 | |
| }
 | |
| 
 | |
| // DefaultGenesis returns default genesis state as raw bytes for the module.
 | |
| func (AppModule) DefaultGenesis(cdc codec.JSONCodec) json.RawMessage {
 | |
| 	return cdc.MustMarshalJSON(onboarding.DefaultGenesisState())
 | |
| }
 | |
| 
 | |
| // ValidateGenesis performs genesis state validation for the circuit module.
 | |
| func (AppModule) ValidateGenesis(cdc codec.JSONCodec, _ client.TxEncodingConfig, bz json.RawMessage) error {
 | |
| 	var data onboarding.GenesisState
 | |
| 	if err := cdc.UnmarshalJSON(bz, &data); err != nil {
 | |
| 		return fmt.Errorf("failed to unmarshal %s genesis state: %w", onboarding.ModuleName, err)
 | |
| 	}
 | |
| 
 | |
| 	return data.Validate()
 | |
| }
 | |
| 
 | |
| // InitGenesis performs genesis initialization for the onboarding module.
 | |
| // It returns no validator updates.
 | |
| func (am AppModule) InitGenesis(ctx sdk.Context, cdc codec.JSONCodec, data json.RawMessage) {
 | |
| 	var genesisState onboarding.GenesisState
 | |
| 	cdc.MustUnmarshalJSON(data, &genesisState)
 | |
| 
 | |
| 	if err := am.keeper.InitGenesis(ctx, &genesisState); err != nil {
 | |
| 		panic(fmt.Sprintf("failed to initialize %s genesis state: %v", onboarding.ModuleName, err))
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // ExportGenesis returns the exported genesis state as raw bytes for the circuit
 | |
| // module.
 | |
| func (am AppModule) ExportGenesis(ctx sdk.Context, cdc codec.JSONCodec) json.RawMessage {
 | |
| 	gs, err := am.keeper.ExportGenesis(ctx)
 | |
| 	if err != nil {
 | |
| 		panic(fmt.Sprintf("failed to export %s genesis state: %v", onboarding.ModuleName, err))
 | |
| 	}
 | |
| 
 | |
| 	return cdc.MustMarshalJSON(gs)
 | |
| }
 |