mirror of
https://github.com/onsonr/sonr.git
synced 2025-03-10 21:09:11 +00:00
182 lines
5.3 KiB
Go
182 lines
5.3 KiB
Go
package keeper
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
|
|
"cosmossdk.io/errors"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types"
|
|
|
|
"github.com/onsonr/sonr/x/did/builder"
|
|
"github.com/onsonr/sonr/x/did/types"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types"
|
|
|
|
"cosmossdk.io/errors"
|
|
didv1 "github.com/onsonr/hway/api/did/v1"
|
|
"github.com/onsonr/hway/x/did/types"
|
|
)
|
|
|
|
type msgServer struct {
|
|
k Keeper
|
|
}
|
|
|
|
var _ types.MsgServer = msgServer{}
|
|
|
|
// NewMsgServerImpl returns an implementation of the module MsgServer interface.
|
|
func NewMsgServerImpl(keeper Keeper) types.MsgServer {
|
|
return &msgServer{k: keeper}
|
|
}
|
|
|
|
// # AuthorizeService
|
|
//
|
|
// AuthorizeService implements types.MsgServer.
|
|
func (ms msgServer) AuthorizeService(goCtx context.Context, msg *types.MsgAuthorizeService) (*types.MsgAuthorizeServiceResponse, error) {
|
|
if ms.k.authority != msg.Controller {
|
|
return nil, errors.Wrapf(
|
|
govtypes.ErrInvalidSigner,
|
|
"invalid authority; expected %s, got %s",
|
|
ms.k.authority,
|
|
msg.Controller,
|
|
)
|
|
}
|
|
return &types.MsgAuthorizeServiceResponse{}, nil
|
|
}
|
|
|
|
// # AllocateVault
|
|
//
|
|
// AllocateVault implements types.MsgServer.
|
|
func (ms msgServer) AllocateVault(
|
|
goCtx context.Context,
|
|
msg *types.MsgAllocateVault,
|
|
) (*types.MsgAllocateVaultResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(goCtx)
|
|
// 1.Check if the service origin is valid
|
|
if ms.k.IsValidServiceOrigin(ctx, msg.Origin) {
|
|
return nil, types.ErrInvalidServiceOrigin
|
|
}
|
|
|
|
cid, expiryBlock, err := ms.k.assembleInitialVault(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
regOpts, err := builder.GetPublicKeyCredentialCreationOptions(msg.Origin, msg.Subject, cid, ms.k.GetParams(ctx))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// Convert to string
|
|
regOptsJSON, err := json.Marshal(regOpts)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &types.MsgAllocateVaultResponse{
|
|
ExpiryBlock: expiryBlock,
|
|
Cid: cid,
|
|
RegistrationOptions: string(regOptsJSON),
|
|
}, nil
|
|
}
|
|
|
|
// # RegisterController
|
|
//
|
|
// RegisterController implements types.MsgServer.
|
|
func (ms msgServer) RegisterController(
|
|
goCtx context.Context,
|
|
msg *types.MsgRegisterController,
|
|
) (*types.MsgRegisterControllerResponse, error) {
|
|
_ = sdk.UnwrapSDKContext(goCtx)
|
|
return &types.MsgRegisterControllerResponse{}, nil
|
|
}
|
|
|
|
// # RegisterService
|
|
//
|
|
// RegisterService implements types.MsgServer.
|
|
func (ms msgServer) RegisterService(
|
|
goCtx context.Context,
|
|
msg *types.MsgRegisterService,
|
|
) (*types.MsgRegisterServiceResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(goCtx)
|
|
|
|
// 1.Check if the service origin is valid
|
|
if !ms.k.IsValidServiceOrigin(ctx, msg.Service.Origin) {
|
|
return nil, types.ErrInvalidServiceOrigin
|
|
}
|
|
return ms.k.insertService(ctx, msg.Service)
|
|
}
|
|
|
|
// # SyncController
|
|
//
|
|
// SyncController implements types.MsgServer.
|
|
func (ms msgServer) SyncController(ctx context.Context, msg *types.MsgSyncController) (*types.MsgSyncControllerResponse, error) {
|
|
// ctx := sdk.UnwrapSDKContext(goCtx)
|
|
return &types.MsgSyncControllerResponse{}, nil
|
|
}
|
|
|
|
// # UpdateParams
|
|
//
|
|
// UpdateParams updates the x/did module parameters.
|
|
func (ms msgServer) UpdateParams(
|
|
ctx context.Context,
|
|
msg *types.MsgUpdateParams,
|
|
) (*types.MsgUpdateParamsResponse, error) {
|
|
if ms.k.authority != msg.Authority {
|
|
return nil, errors.Wrapf(
|
|
govtypes.ErrInvalidSigner,
|
|
"invalid authority; expected %s, got %s",
|
|
ms.k.authority,
|
|
msg.Authority,
|
|
)
|
|
}
|
|
return nil, ms.k.Params.Set(ctx, msg.Params)
|
|
}
|
|
|
|
// Authenticate implements types.MsgServer.
|
|
func (ms msgServer) Authenticate(ctx context.Context, msg *types.MsgAuthenticate) (*types.MsgAuthenticateResponse, error) {
|
|
if ms.k.authority != msg.Authority {
|
|
return nil, errors.Wrapf(govtypes.ErrInvalidSigner, "invalid authority; expected %s, got %s", ms.k.authority, msg.Authority)
|
|
}
|
|
// ctx := sdk.UnwrapSDKContext(goCtx)
|
|
return &types.MsgAuthenticateResponse{}, nil
|
|
}
|
|
|
|
// RegisterController implements types.MsgServer.
|
|
func (ms msgServer) RegisterController(goCtx context.Context, msg *types.MsgRegisterController) (*types.MsgRegisterControllerResponse, error) {
|
|
if ms.k.authority != msg.Authority {
|
|
return nil, errors.Wrapf(govtypes.ErrInvalidSigner, "invalid authority; expected %s, got %s", ms.k.authority, msg.Authority)
|
|
}
|
|
return &types.MsgRegisterControllerResponse{}, nil
|
|
}
|
|
|
|
// RegisterService implements types.MsgServer.
|
|
func (ms msgServer) RegisterService(goCtx context.Context, msg *types.MsgRegisterService) (*types.MsgRegisterServiceResponse, error) {
|
|
if ms.k.authority != msg.Authority {
|
|
return nil, errors.Wrapf(govtypes.ErrInvalidSigner, "invalid authority; expected %s, got %s", ms.k.authority, msg.Authority)
|
|
}
|
|
|
|
ctx := sdk.UnwrapSDKContext(goCtx)
|
|
svc := didv1.Service{
|
|
ControllerDid: msg.Authority,
|
|
}
|
|
err := ms.k.OrmDB.ServiceTable().Insert(ctx, &svc)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &types.MsgRegisterServiceResponse{}, nil
|
|
}
|
|
|
|
// ProveWitness implements types.MsgServer.
|
|
func (ms msgServer) ProveWitness(ctx context.Context, msg *types.MsgProveWitness) (*types.MsgProveWitnessResponse, error) {
|
|
// ctx := sdk.UnwrapSDKContext(goCtx)
|
|
return &types.MsgProveWitnessResponse{}, nil
|
|
}
|
|
|
|
// SyncVault implements types.MsgServer.
|
|
func (ms msgServer) SyncVault(ctx context.Context, msg *types.MsgSyncVault) (*types.MsgSyncVaultResponse, error) {
|
|
// ctx := sdk.UnwrapSDKContext(goCtx)
|
|
return &types.MsgSyncVaultResponse{}, nil
|
|
}
|