Skip to content

Commit

Permalink
feat: add all skyway endpoints to REST GW (#1272)
Browse files Browse the repository at this point in the history
# Related Github tickets

- #1938

# Background

In order to add all the skyway commands (query and tx) to the Python and
JS SDKs, they need to be exposed as rpc endpoints.

# Testing completed

- [ ] test coverage exists or has been added/updated
- [ ] tested in a private testnet

# Breaking changes

- [x] I have checked my code for breaking changes
- [x] If there are breaking changes, there is a supporting migration.
  • Loading branch information
maharifu authored Aug 22, 2024
1 parent 5baf5f2 commit c2e3248
Show file tree
Hide file tree
Showing 9 changed files with 2,601 additions and 571 deletions.
53 changes: 43 additions & 10 deletions proto/palomachain/paloma/skyway/msgs.proto
Original file line number Diff line number Diff line change
Expand Up @@ -16,22 +16,55 @@ option go_package = "github.com/palomachain/paloma/x/skyway/types";

// Msg defines the state transitions possible within skyway
service Msg {
rpc SendToRemote(MsgSendToRemote) returns (MsgSendToRemoteResponse) {}
rpc ConfirmBatch(MsgConfirmBatch) returns (MsgConfirmBatchResponse) {}
rpc EstimateBatchGas(MsgEstimateBatchGas)
returns (google.protobuf.Empty) {}
rpc SendToRemote(MsgSendToRemote) returns (MsgSendToRemoteResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/send-to-remote";
}

rpc ConfirmBatch(MsgConfirmBatch) returns (MsgConfirmBatchResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/confirm-batch";
}

rpc EstimateBatchGas(MsgEstimateBatchGas) returns (google.protobuf.Empty) {
option (google.api.http).post =
"/palomachain/paloma/skyway/estimate-batch-gas";
}

rpc SendToPalomaClaim(MsgSendToPalomaClaim)
returns (MsgSendToPalomaClaimResponse) {}
returns (MsgSendToPalomaClaimResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/send-to-paloma-claim";
}

rpc BatchSendToRemoteClaim(MsgBatchSendToRemoteClaim)
returns (MsgBatchSendToRemoteClaimResponse) {}
returns (MsgBatchSendToRemoteClaimResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/batch-send-to-remote";
}

rpc CancelSendToRemote(MsgCancelSendToRemote)
returns (MsgCancelSendToRemoteResponse) {}
returns (MsgCancelSendToRemoteResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/cancel-send-to-remote";
}

rpc SubmitBadSignatureEvidence(MsgSubmitBadSignatureEvidence)
returns (MsgSubmitBadSignatureEvidenceResponse) {}
rpc UpdateParams(MsgUpdateParams) returns (MsgUpdateParamsResponse);
returns (MsgSubmitBadSignatureEvidenceResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/submit-bad-signature-evidence";
}

rpc UpdateParams(MsgUpdateParams) returns (MsgUpdateParamsResponse) {
option (google.api.http).post =
"/palomachain/paloma/skyway/update-params";
}

rpc LightNodeSaleClaim(MsgLightNodeSaleClaim)
returns (google.protobuf.Empty) {}
returns (google.protobuf.Empty) {
option (google.api.http).post =
"/palomachain/paloma/skyway/light-node-sale-claim";
}
}

// MsgSendToRemote
Expand Down
100 changes: 74 additions & 26 deletions proto/palomachain/paloma/skyway/query.proto
Original file line number Diff line number Diff line change
@@ -1,73 +1,121 @@
syntax = "proto3";
package palomachain.paloma.skyway;

import "palomachain/paloma/skyway/pool.proto";
import "palomachain/paloma/skyway/batch.proto";
import "palomachain/paloma/skyway/attestation.proto";
import "gogoproto/gogo.proto";
import "google/api/annotations.proto";
import "palomachain/paloma/skyway/genesis.proto";
import "palomachain/paloma/skyway/types.proto";
import "palomachain/paloma/skyway/msgs.proto";
import "palomachain/paloma/skyway/params.proto";
import "google/protobuf/empty.proto";
import "palomachain/paloma/skyway/attestation.proto";
import "palomachain/paloma/skyway/batch.proto";
import "palomachain/paloma/skyway/bridge_tax.proto";
import "palomachain/paloma/skyway/bridge_transfer_limit.proto";
import "palomachain/paloma/skyway/genesis.proto";
import "palomachain/paloma/skyway/light_node_sale_contract.proto";
import "google/protobuf/empty.proto";
import "palomachain/paloma/skyway/msgs.proto";
import "palomachain/paloma/skyway/params.proto";
import "palomachain/paloma/skyway/pool.proto";
import "palomachain/paloma/skyway/types.proto";

option go_package = "github.com/palomachain/paloma/x/skyway/types";

// Query defines the gRPC querier service
service Query {
rpc Params(QueryParamsRequest) returns (QueryParamsResponse) {}
rpc Params(QueryParamsRequest) returns (QueryParamsResponse) {
option (google.api.http).get = "/palomachain/paloma/skyway/params";
}

rpc LastPendingBatchRequestByAddr(QueryLastPendingBatchRequestByAddrRequest)
returns (QueryLastPendingBatchRequestByAddrResponse) {}
returns (QueryLastPendingBatchRequestByAddrResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/last-pending-batch-request-by-addr/{address}";
}

rpc LastObservedSkywayNonce(QueryLastObservedSkywayNonceRequest)
returns (QueryLastObservedSkywayNonceResponse) {}
returns (QueryLastObservedSkywayNonceResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/last-observed-skyway-nonce/{chain_reference_id}";
}

rpc LastObservedSkywayNonceByAddr(QueryLastObservedSkywayNonceByAddrRequest)
returns (QueryLastObservedSkywayNonceResponse) {}
returns (QueryLastObservedSkywayNonceResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/last-observed-skyway-nonce/{chain_reference_id}";
}

rpc LastObservedSkywayBlock(QueryLastObservedSkywayBlockRequest)
returns (QueryLastObservedSkywayBlockResponse) {}
returns (QueryLastObservedSkywayBlockResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/last-observed-skyway-block/{chain_reference_id}";
}

rpc OutgoingTxBatches(QueryOutgoingTxBatchesRequest)
returns (QueryOutgoingTxBatchesResponse) {}
returns (QueryOutgoingTxBatchesResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/outgoing-tx-batches/{chain_reference_id}";
}

rpc BatchRequestByNonce(QueryBatchRequestByNonceRequest)
returns (QueryBatchRequestByNonceResponse) {}
returns (QueryBatchRequestByNonceResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/batch-request-by-nonce";
}

rpc BatchConfirms(QueryBatchConfirmsRequest)
returns (QueryBatchConfirmsResponse) {}
returns (QueryBatchConfirmsResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/batch-confirms";
}

rpc ERC20ToDenom(QueryERC20ToDenomRequest)
returns (QueryERC20ToDenomResponse) {}
returns (QueryERC20ToDenomResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/erc20-to-denom/{chain_reference_id}";
}

rpc DenomToERC20(QueryDenomToERC20Request)
returns (QueryDenomToERC20Response) {}
returns (QueryDenomToERC20Response) {
option (google.api.http).get =
"/palomachain/paloma/skyway/denom-to-erc20/{chain_reference_id}";
}

rpc GetAttestations(QueryAttestationsRequest)
returns (QueryAttestationsResponse) {}
returns (QueryAttestationsResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/attestations/{chain_reference_id}";
}

rpc GetErc20ToDenoms(QueryErc20ToDenoms)
returns (QueryErc20ToDenomsResponse) {}
returns (QueryErc20ToDenomsResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/erc20-to-denoms";
}

rpc GetPendingSendToRemote(QueryPendingSendToRemote)
returns (QueryPendingSendToRemoteResponse) {}
returns (QueryPendingSendToRemoteResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/pending-send-to-remote/{sender_address}";
}

rpc GetBridgeTaxes(google.protobuf.Empty) returns (QueryBridgeTaxesResponse) {
option (google.api.http).get = "/palomachain/paloma/skyway/bridge_taxes";
option (google.api.http).get = "/palomachain/paloma/skyway/bridge-taxes";
}

rpc GetBridgeTransferLimits(google.protobuf.Empty)
returns (QueryBridgeTransferLimitsResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/all_bridge_transfer_limits";
"/palomachain/paloma/skyway/all-bridge-transfer-limits";
}

rpc GetLightNodeSaleContracts(google.protobuf.Empty)
returns (QueryLightNodeSaleContractsResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/light_node_sale_contracts";
"/palomachain/paloma/skyway/light-node-sale-contracts";
}

rpc LastPendingBatchForGasEstimation(QueryLastPendingBatchForGasEstimationRequest)
returns (QueryLastPendingBatchForGasEstimationResponse) {
option (google.api.http).get =
"/palomachain/paloma/skyway/pending_batch_for_gas_estimation";
}
"/palomachain/paloma/skyway/pending-batch-for-gas-estimation/{chain_reference_id}";
}
}

message QueryParamsRequest {}
Expand Down
6 changes: 5 additions & 1 deletion x/skyway/module.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,11 @@ func (AppModuleBasic) GetTxCmd() *cobra.Command {

// RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the distribution module.
// also implements app module basic
func (AppModuleBasic) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *runtime.ServeMux) {}
func (AppModuleBasic) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *runtime.ServeMux) {
if err := types.RegisterQueryHandlerClient(context.Background(), mux, types.NewQueryClient(clientCtx)); err != nil {
panic(err)
}
}

// RegisterInterfaces implements app bmodule basic
func (b AppModuleBasic) RegisterInterfaces(registry codectypes.InterfaceRegistry) {
Expand Down
Loading

0 comments on commit c2e3248

Please sign in to comment.