mirror of
https://github.com/onsonr/sonr.git
synced 2025-03-10 21:09:11 +00:00
* feat: add support for DID number as primary key for Controllers * refactor: rename pkg/proxy to app/proxy * feat: add vault module keeper tests * feat(vault): add DID keeper to vault module * refactor: move vault client code to its own package * refactor(vault): extract schema definition * refactor: use vaulttypes for MsgAllocateVault * refactor: update vault assembly logic to use new methods * feat: add dwn-proxy command * refactor: remove unused context.go file * refactor: remove unused web-related code * feat: add DWN proxy server * feat: add BuildTx RPC to vault module * fix: Implement BuildTx endpoint * feat: add devbox integration to project
151 lines
4.8 KiB
Protocol Buffer
151 lines
4.8 KiB
Protocol Buffer
syntax = "proto3";
|
|
|
|
package did.v1;
|
|
|
|
import "cosmos/msg/v1/msg.proto";
|
|
import "cosmos_proto/cosmos.proto";
|
|
import "did/v1/genesis.proto";
|
|
import "gogoproto/gogo.proto";
|
|
|
|
option go_package = "github.com/onsonr/sonr/x/did/types";
|
|
|
|
// Msg defines the Msg service.
|
|
service Msg {
|
|
option (cosmos.msg.v1.service) = true;
|
|
|
|
// AuthorizeService asserts the given controller is the owner of the given
|
|
// address.
|
|
rpc AuthorizeService(MsgAuthorizeService) returns (MsgAuthorizeServiceResponse);
|
|
|
|
// ExecuteTx executes a transaction on the Sonr Blockchain. It leverages
|
|
// Macaroon for verification.
|
|
rpc ExecuteTx(MsgExecuteTx) returns (MsgExecuteTxResponse);
|
|
|
|
// RegisterController initializes a controller with the given authentication
|
|
// set, address, cid, publicKey, and user-defined alias.
|
|
rpc RegisterController(MsgRegisterController) returns (MsgRegisterControllerResponse);
|
|
|
|
// RegisterService initializes a Service with a given permission scope and
|
|
// URI. The domain must have a valid TXT record containing the public key.
|
|
rpc RegisterService(MsgRegisterService) returns (MsgRegisterServiceResponse);
|
|
|
|
// UpdateParams defines a governance operation for updating the parameters.
|
|
rpc UpdateParams(MsgUpdateParams) returns (MsgUpdateParamsResponse);
|
|
}
|
|
|
|
// MsgRegisterController is the message type for the InitializeController RPC.
|
|
message MsgRegisterController {
|
|
option (cosmos.msg.v1.signer) = "authority";
|
|
|
|
// authority is the address of the governance account.
|
|
string authority = 1 [(cosmos_proto.scalar) = "cosmos.AddressString"];
|
|
|
|
// Assertions is the list of assertions to initialize the controller with.
|
|
repeated bytes assertions = 2;
|
|
|
|
// Keyshares is the list of keyshares to initialize the controller with.
|
|
repeated bytes keyshares = 3;
|
|
|
|
// Verifications is the list of verifications to initialize the controller
|
|
// with.
|
|
repeated bytes verifications = 4;
|
|
}
|
|
|
|
// MsgRegisterControllerResponse is the response type for the
|
|
// InitializeController RPC.
|
|
message MsgRegisterControllerResponse {
|
|
// Success returns true if the specified cid is valid and not already
|
|
// encrypted.
|
|
bool success = 1;
|
|
|
|
// Controller is the address of the initialized controller.
|
|
string controller = 2 [(cosmos_proto.scalar) = "cosmos.AddressString"];
|
|
|
|
// Accounts are a Address Map and Supported coin Denoms for the controller
|
|
map<string, string> accounts = 3;
|
|
}
|
|
|
|
// MsgExecuteTx is the message type for the ExecuteTx RPC.
|
|
message MsgExecuteTx {
|
|
option (cosmos.msg.v1.signer) = "controller";
|
|
|
|
// Controller is the address of the controller to authenticate.
|
|
string controller = 1 [(cosmos_proto.scalar) = "cosmos.AddressString"];
|
|
|
|
// Messages is the list of messages to execute.
|
|
map<string, bytes> messages = 2;
|
|
|
|
// MacaroonToken is the macaroon token to authenticate the operation.
|
|
string macaroon_token = 3;
|
|
}
|
|
|
|
// MsgExecuteTxResponse is the response type for the ExecuteTx RPC.
|
|
message MsgExecuteTxResponse {
|
|
bool success = 1;
|
|
string tx_hash = 2;
|
|
}
|
|
|
|
// MsgAuthorizeService is the message type for the AuthorizeService RPC.
|
|
message MsgAuthorizeService {
|
|
option (cosmos.msg.v1.signer) = "controller";
|
|
|
|
// Controller is the address of the controller to authenticate.
|
|
string controller = 1 [(cosmos_proto.scalar) = "cosmos.AddressString"];
|
|
|
|
// Origin is the origin of the request in wildcard form.
|
|
string origin = 2;
|
|
|
|
// Permissions is the scope of the service.
|
|
map<string, string> permissions = 3;
|
|
|
|
// token is the macron token to authenticate the operation.
|
|
string token = 4;
|
|
}
|
|
|
|
// MsgAuthorizeServiceResponse is the response type for the AuthorizeService
|
|
// RPC.
|
|
message MsgAuthorizeServiceResponse {
|
|
bool success = 1;
|
|
string token = 2;
|
|
}
|
|
|
|
// MsgRegisterService is the message type for the RegisterService RPC.
|
|
message MsgRegisterService {
|
|
option (cosmos.msg.v1.signer) = "controller";
|
|
|
|
// authority is the address of the governance account.
|
|
string controller = 1 [(cosmos_proto.scalar) = "cosmos.AddressString"];
|
|
|
|
// origin is the origin of the request in wildcard form. Requires valid TXT
|
|
// record in DNS.
|
|
Service service = 2;
|
|
}
|
|
|
|
// MsgRegisterServiceResponse is the response type for the RegisterService RPC.
|
|
message MsgRegisterServiceResponse {
|
|
bool success = 1;
|
|
string did = 2;
|
|
}
|
|
|
|
// MsgUpdateParams is the Msg/UpdateParams request type.
|
|
//
|
|
// Since: cosmos-sdk 0.47
|
|
message MsgUpdateParams {
|
|
option (cosmos.msg.v1.signer) = "authority";
|
|
|
|
// authority is the address of the governance account.
|
|
string authority = 1 [(cosmos_proto.scalar) = "cosmos.AddressString"];
|
|
|
|
// params defines the parameters to update.
|
|
Params params = 2 [(gogoproto.nullable) = false];
|
|
|
|
// token is the macron token to authenticate the operation.
|
|
string token = 3;
|
|
}
|
|
|
|
// MsgUpdateParamsResponse defines the response structure for executing a
|
|
// MsgUpdateParams message.
|
|
//
|
|
// Since: cosmos-sdk 0.47
|
|
message MsgUpdateParamsResponse {}
|