forked from cerc-io/laconicd
Prathamesh Musale
ec6e2f3776
Part of [Add a CLI query to list all authorities with owner filter](cerc-io/laconicd#41) Usage: ```bash $ laconicd query registry list-authorities -h List authorities (optionally by owner) Usage: laconicd query registry list-authorities [flags] Flags: --grpc-addr string the gRPC endpoint to use for this chain --grpc-insecure allow gRPC over insecure channels, if not the server must use TLS --height int Use a specific height to query state at (this can error if the node is pruning state) -h, --help help for list-authorities --no-indent Do not indent JSON output --node string <host>:<port> to CometBFT RPC interface for this chain (default "tcp://localhost:26657") -o, --output string Output format (text|json) (default "text") --owner string Owner to get the authorities for ``` Example: ```bash # Without owner filter $ laconicd query registry list-authorities authorities: - entry: expiry_time: "2024-07-26T06:54:28.491158167Z" height: "247" owner_address: laconic1e23vfttpvk045pqeydr4mujmlemx8hf9zjm7h2 owner_public_key: A6RlTGLIpyA8nnEQN4V3sz3uaLMY0fHtB7aS7u1zTOdD status: active name: cerc - entry: expiry_time: "2024-07-26T06:47:58.971429925Z" height: "118" owner_address: laconic10ztdu07xn7rracvzvehelgwvsytqlrvj6pvput owner_public_key: AvBxGIXBFmWCF+OHFwydqEtp2bfP+aimObO3teunbve7 status: active name: laconic # With owner filter $ laconicd query registry list-authorities --owner laconic1e23vfttpvk045pqeydr4mujmlemx8hf9zjm7h2 authorities: - entry: expiry_time: "2024-07-26T06:54:28.491158167Z" height: "247" owner_address: laconic1e23vfttpvk045pqeydr4mujmlemx8hf9zjm7h2 owner_public_key: A6RlTGLIpyA8nnEQN4V3sz3uaLMY0fHtB7aS7u1zTOdD status: active name: cerc ``` Reviewed-on: cerc-io/laconicd#42 Co-authored-by: Prathamesh Musale <prathamesh.musale0@gmail.com> Co-committed-by: Prathamesh Musale <prathamesh.musale0@gmail.com>
176 lines
4.7 KiB
Go
176 lines
4.7 KiB
Go
package keeper
|
|
|
|
import (
|
|
"context"
|
|
|
|
errorsmod "cosmossdk.io/errors"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
|
|
|
|
registrytypes "git.vdb.to/cerc-io/laconicd/x/registry"
|
|
)
|
|
|
|
var _ registrytypes.QueryServer = queryServer{}
|
|
|
|
type queryServer struct {
|
|
k Keeper
|
|
}
|
|
|
|
// NewQueryServerImpl returns an implementation of the module QueryServer.
|
|
func NewQueryServerImpl(k Keeper) registrytypes.QueryServer {
|
|
return queryServer{k}
|
|
}
|
|
|
|
func (qs queryServer) Params(c context.Context, _ *registrytypes.QueryParamsRequest) (*registrytypes.QueryParamsResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
params, err := qs.k.GetParams(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return ®istrytypes.QueryParamsResponse{Params: params}, nil
|
|
}
|
|
|
|
func (qs queryServer) Records(c context.Context, req *registrytypes.QueryRecordsRequest) (*registrytypes.QueryRecordsResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
attributes := req.GetAttributes()
|
|
all := req.GetAll()
|
|
|
|
var records []registrytypes.Record
|
|
var err error
|
|
if len(attributes) > 0 {
|
|
records, err = qs.k.RecordsFromAttributes(ctx, attributes, all)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
} else {
|
|
records, err = qs.k.ListRecords(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
|
|
return ®istrytypes.QueryRecordsResponse{Records: records}, nil
|
|
}
|
|
|
|
func (qs queryServer) GetRecord(c context.Context, req *registrytypes.QueryGetRecordRequest) (*registrytypes.QueryGetRecordResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
id := req.GetId()
|
|
|
|
if has, err := qs.k.HasRecord(ctx, req.Id); !has {
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return nil, errorsmod.Wrap(sdkerrors.ErrUnknownRequest, "Record not found.")
|
|
}
|
|
|
|
record, err := qs.k.GetRecordById(ctx, id)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return ®istrytypes.QueryGetRecordResponse{Record: record}, nil
|
|
}
|
|
|
|
func (qs queryServer) GetRecordsByBondId(
|
|
c context.Context,
|
|
req *registrytypes.QueryGetRecordsByBondIdRequest,
|
|
) (*registrytypes.QueryGetRecordsByBondIdResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
records, err := qs.k.GetRecordsByBondId(ctx, req.GetId())
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return ®istrytypes.QueryGetRecordsByBondIdResponse{Records: records}, nil
|
|
}
|
|
|
|
func (qs queryServer) GetRegistryModuleBalance(c context.Context,
|
|
_ *registrytypes.QueryGetRegistryModuleBalanceRequest,
|
|
) (*registrytypes.QueryGetRegistryModuleBalanceResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
balances := qs.k.GetModuleBalances(ctx)
|
|
|
|
return ®istrytypes.QueryGetRegistryModuleBalanceResponse{
|
|
Balances: balances,
|
|
}, nil
|
|
}
|
|
|
|
func (qs queryServer) NameRecords(c context.Context, _ *registrytypes.QueryNameRecordsRequest) (*registrytypes.QueryNameRecordsResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
nameRecords, err := qs.k.ListNameRecords(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return ®istrytypes.QueryNameRecordsResponse{Names: nameRecords}, nil
|
|
}
|
|
|
|
func (qs queryServer) Whois(c context.Context, req *registrytypes.QueryWhoisRequest) (*registrytypes.QueryWhoisResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
nameAuthority, err := qs.k.GetNameAuthority(ctx, req.GetName())
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return ®istrytypes.QueryWhoisResponse{NameAuthority: nameAuthority}, nil
|
|
}
|
|
|
|
func (qs queryServer) Authorities(c context.Context, req *registrytypes.QueryAuthoritiesRequest) (*registrytypes.QueryAuthoritiesResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
authorityEntries, err := qs.k.ListNameAuthorityRecords(ctx, req.GetOwner())
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return ®istrytypes.QueryAuthoritiesResponse{Authorities: authorityEntries}, nil
|
|
}
|
|
|
|
func (qs queryServer) LookupLrn(c context.Context, req *registrytypes.QueryLookupLrnRequest) (*registrytypes.QueryLookupLrnResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
lrn := req.GetLrn()
|
|
|
|
lrnExists, err := qs.k.HasNameRecord(ctx, lrn)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if !lrnExists {
|
|
return nil, errorsmod.Wrap(sdkerrors.ErrUnknownRequest, "LRN not found.")
|
|
}
|
|
|
|
nameRecord, err := qs.k.LookupNameRecord(ctx, lrn)
|
|
if nameRecord == nil {
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return nil, errorsmod.Wrap(sdkerrors.ErrUnknownRequest, "name record not found.")
|
|
}
|
|
|
|
return ®istrytypes.QueryLookupLrnResponse{Name: nameRecord}, nil
|
|
}
|
|
|
|
func (qs queryServer) ResolveLrn(c context.Context, req *registrytypes.QueryResolveLrnRequest) (*registrytypes.QueryResolveLrnResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(c)
|
|
|
|
lrn := req.GetLrn()
|
|
record, err := qs.k.ResolveLRN(ctx, lrn)
|
|
if record == nil {
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return nil, errorsmod.Wrap(sdkerrors.ErrUnknownRequest, "record not found.")
|
|
}
|
|
|
|
return ®istrytypes.QueryResolveLrnResponse{Record: record}, nil
|
|
}
|