175 lines
5.2 KiB
Protocol Buffer
175 lines
5.2 KiB
Protocol Buffer
syntax = "proto3";
|
|
package cbridge;
|
|
|
|
import "query.proto";
|
|
import "cbridge.proto";
|
|
|
|
option go_package = "../cbridge";
|
|
|
|
|
|
message Chain {
|
|
uint32 id = 1;
|
|
string name = 2;
|
|
string icon = 3;
|
|
uint32 block_delay = 4;
|
|
string gas_token_symbol = 5;
|
|
string explore_url = 6;
|
|
reserved 7; // rpc_url removed
|
|
string contract_addr = 8; // bridge contract addr
|
|
string drop_gas_amt = 9; // how much gas will be dropped on dst chain when transfer(dst chain gas token)
|
|
double suggested_base_fee = 10; // only for backend
|
|
}
|
|
|
|
message ChainTokenInfo {
|
|
repeated TokenInfo token = 1;
|
|
}
|
|
|
|
message TokenInfo {
|
|
Token token = 1;
|
|
string name = 2;
|
|
string icon = 3;
|
|
}
|
|
|
|
message TransferInfo {
|
|
Chain chain = 1;
|
|
Token token = 2;
|
|
string amount = 3;
|
|
}
|
|
|
|
message GetTransferStatusRequest {
|
|
string transfer_id = 1;
|
|
}
|
|
|
|
message GetTransferStatusResponse {
|
|
ErrMsg err = 1;
|
|
TransferHistoryStatus status = 2;
|
|
bytes wd_onchain = 3; // for refund only
|
|
repeated bytes sorted_sigs = 4; // for refund only
|
|
repeated bytes signers = 5; // for refund only
|
|
repeated bytes powers = 6; // for refund only
|
|
XferStatus refund_reason = 7; // used only for to_be_refund TransferStatus. BAD_LIQUIDITY, BAD_SLIPPAGE and BAD_TOKEN are used here
|
|
uint32 block_delay = 8; // waiting
|
|
string src_block_tx_link = 9;
|
|
string dst_block_tx_link = 10;
|
|
}
|
|
|
|
message GetTransferConfigsRequest {}
|
|
|
|
message GetTransferConfigsResponse {
|
|
ErrMsg err = 1;
|
|
repeated Chain chains = 2;
|
|
map<uint32, ChainTokenInfo> chain_token = 3; // map<chain_id, ChainTokenInfo>
|
|
string farming_reward_contract_addr = 4;
|
|
}
|
|
|
|
message GetTokenInfoRequest {
|
|
uint32 chain_id = 1;
|
|
string token_symbol = 2;
|
|
}
|
|
|
|
message GetTokenInfoResponse {
|
|
ErrMsg err = 1;
|
|
TokenInfo token_info = 2;
|
|
}
|
|
|
|
message EstimateAmtRequest {
|
|
uint32 src_chain_id = 1;
|
|
uint32 dst_chain_id = 2;
|
|
string token_symbol = 3;
|
|
string amt = 4;
|
|
string usr_addr = 5;
|
|
uint32 slippage_tolerance = 6; // user setting, for ui only, slippage * 1M, eg. 0.5% is 5000
|
|
}
|
|
|
|
message EstimateAmtResponse {
|
|
ErrMsg err = 1;
|
|
string eq_value_token_amt = 2; // on_dst_chain, to cal minimum_received_amt = eq_value_token_amt*(1-slippage_tolerance) - fee
|
|
float bridge_rate = 3;
|
|
string perc_fee = 4; // on_dst_chain, percentage fee based on amount
|
|
string base_fee = 7; // on_dest_chain, independent of amount, to cover relay onchain tx gas cost
|
|
uint32 slippage_tolerance = 5; // user setting, from request, slippage * 1M, eg. 0.5% is 5000
|
|
uint32 max_slippage = 6; // param for requesting on chain, slippage * 1M, eg. 0.5% is 5000
|
|
}
|
|
|
|
message WithdrawInfo {
|
|
uint32 chain_id = 1;
|
|
string amount = 2;
|
|
uint32 slippage_tolerance = 3; // user setting, for ui only, slippage * 1M, eg. 0.5% is 5000
|
|
}
|
|
|
|
message EstimateWithdrawAmtRequest {
|
|
repeated WithdrawInfo src_withdraws = 1;
|
|
uint32 dst_chain_id = 2;
|
|
string token_symbol = 3;
|
|
string usr_addr = 4;
|
|
}
|
|
|
|
message EstimateWithdrawAmtResponse {
|
|
ErrMsg err = 1;
|
|
map<uint32, EstimateWithdrawAmt> req_amt = 2; // map<src_chain_id, EstimateWithdrawAmt>
|
|
}
|
|
|
|
message EstimateWithdrawAmt {
|
|
string eq_value_token_amt = 1; // on_dst_chain, to cal minimum_received_amt = eq_value_token_amt*(1-slippage_tolerance) - fee
|
|
float bridge_rate = 2;
|
|
string perc_fee = 3; // on_dst_chain, percentage fee based on amount
|
|
string base_fee = 4; // on_dest_chain, independent of amount, to cover relay onchain tx gas cost
|
|
uint32 slippage_tolerance = 5; // user setting, for ui only, slippage * 1M, eg. 0.5% is 5000
|
|
uint32 max_slippage = 6; // param for requesting on chain, slippage * 1M, eg. 0.5% is 5000
|
|
}
|
|
|
|
message WithdrawLiquidityRequest {
|
|
bytes withdraw_req = 1; // serialized WithdrawReq in sgn/cbridge/v1/tx.proto
|
|
bytes sig = 2;
|
|
string estimated_received_amt = 3; // on dst chain
|
|
WithdrawMethodType method_type = 4; // record which type it is
|
|
}
|
|
|
|
message WithdrawLiquidityResponse {
|
|
ErrMsg err = 1;
|
|
uint64 seq_num = 2; // same as WithdrawLiquidityRequest.reqid
|
|
}
|
|
|
|
message TransferHistory {
|
|
string transfer_id = 1;
|
|
TransferInfo src_send_info = 2;
|
|
TransferInfo dst_received_info = 3;
|
|
uint64 ts = 4;
|
|
string src_block_tx_link = 5;
|
|
string dst_block_tx_link = 6;
|
|
TransferHistoryStatus status = 7;
|
|
XferStatus refund_reason = 8; // used only for to_be_refund TransferStatus. BAD_LIQUIDITY, BAD_SLIPPAGE and BAD_TOKEN are used here
|
|
}
|
|
|
|
message TransferHistoryRequest {
|
|
string next_page_token = 1; // for first page, it's ""
|
|
uint64 page_size = 2;
|
|
string addr = 3;
|
|
}
|
|
|
|
message TransferHistoryResponse {
|
|
ErrMsg err = 1;
|
|
repeated TransferHistory history = 2;
|
|
string next_page_token = 3;
|
|
uint64 current_size = 4;
|
|
}
|
|
|
|
enum WithdrawMethodType {
|
|
WD_METHOD_TYPE_UNDEFINED = 0;
|
|
WD_METHOD_TYPE_ONE_RM = 1; // for lp one chain liquidity remove
|
|
WD_METHOD_TYPE_ALL_IN_ONE = 2; // for lp multi-chain -> one chain liquidity remove
|
|
WD_METHOD_TYPE_STAKING_CLAIM = 3; // for staking claim lp reward, these entries will not be shown in lp history
|
|
}
|
|
|
|
message ErrMsg {
|
|
ErrCode code = 1;
|
|
string msg = 2;
|
|
}
|
|
|
|
enum ErrCode {
|
|
ERROR_CODE_UNDEFINED = 0;
|
|
ERROR_CODE_COMMON = 500;
|
|
ERROR_NO_TOKEN_ON_DST_CHAIN = 1001;
|
|
ERROR_NO_TOKEN_ON_SRC_CHAIN = 1002;
|
|
ERROR_INIT_WITHDRAW_FAILED = 1003;
|
|
} |