Skip to content

Commit

Permalink
[MGX-522] Simplify XYK RPC api (#535)
Browse files Browse the repository at this point in the history
As agreed this PR introduces number of api breaking changes:
- `XYKRpcResult` is removed
- `RPCAmountsResult` is removed
- `calculate_sell_price` : returns `RpcResult<Balance>` instead of
`RpcResult<XYKRpcResult>`
- `calculate_buy_price` : returns `RpcResult<Balance>` instead of
`RpcResult<XYKRpcResult>`
- `calculate_sell_price_id` : returns `RpcResult<Balance>` instead of
`RpcResult<XYKRpcResult>`
- `calculate_buy_price_id` : returns `RpcResult<Balance>` instead of
`RpcResult<XYKRpcResult>`
- `get_burn_amount` : returns `RpcResult<(Balance,Balance)>` instead of
`RpcResult<RPCAmountsResult>`
- `get_max_instant_burn_amount` : returns `RpcResult<Balance>` instead
of `RpcResult<XYKRpcResult>`
- `get_max_instant_unreserve_amount` : returns `RpcResult<Balance>`
instead of `RpcResult<XYKRpcResult>`
- `calculate_rewards_amount` : returns `RpcResult<Balance>` instead of
`RpcResult<XYKRpcResult>`
- `calculate_Balanced_sell_amount` :
    * returns `RpcResult<Balance>` instead of `RpcResult<XYKRpcResul>`
* `total_amount` parameter type change from `Balance` to `NumberOrHex`
* `reserve_amount` parameter type change from `Balance` to `NumberOrHex`
- `is_buy_asset_lock_free`: `input_amount` type changed from `Balance`
to `NumberOrHex`
- `is_sell_asset_lock_free`: `input_amount` type changed from `Balance`
to `NumberOrHex`
  • Loading branch information
mateuszaaa authored Sep 21, 2023
2 parents 6530140 + e66bda1 commit ab0d1fd
Show file tree
Hide file tree
Showing 5 changed files with 168 additions and 249 deletions.
3 changes: 2 additions & 1 deletion .github/workflows/reusable-e2e-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,8 @@ jobs:

- name: Install e2e tests dependencies
working-directory: e2eTests
run: yarn
# TODO: remove cache clean later
run: yarn cache clean; yarn

- name: Run parachain launch
working-directory: devops/parachain-launch
Expand Down
173 changes: 83 additions & 90 deletions pallets/xyk/rpc/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,96 +16,87 @@ use sp_runtime::{
};
use sp_std::convert::{TryFrom, TryInto};
use std::sync::Arc;
use xyk_runtime_api::RpcAssetMetadata;
pub use xyk_runtime_api::XykApi as XykRuntimeApi;
use xyk_runtime_api::{RpcAmountsResult, RpcAssetMetadata, XYKRpcResult};

#[rpc(client, server)]
pub trait XykApi<
BlockHash,
Balance,
TokenId,
AccountId,
ResponseTypePrice,
ResponseTypeAmounts,
BalanceOutput,
>
{
pub trait XykApi<BlockHash, Balance, TokenId, AccountId> {
#[method(name = "xyk_calculate_sell_price")]
fn calculate_sell_price(
&self,
input_reserve: Balance,
output_reserve: Balance,
sell_amount: Balance,
input_reserve: NumberOrHex,
output_reserve: NumberOrHex,
sell_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_calculate_buy_price")]
fn calculate_buy_price(
&self,
input_reserve: Balance,
output_reserve: Balance,
buy_amount: Balance,
input_reserve: NumberOrHex,
output_reserve: NumberOrHex,
buy_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_calculate_sell_price_id")]
fn calculate_sell_price_id(
&self,
sold_token_id: TokenId,
bought_token_id: TokenId,
sell_amount: Balance,
sell_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_calculate_buy_price_id")]
fn calculate_buy_price_id(
&self,
sold_token_id: TokenId,
bought_token_id: TokenId,
buy_amount: Balance,
buy_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_get_burn_amount")]
fn get_burn_amount(
&self,
first_asset_id: TokenId,
second_asset_id: TokenId,
liquidity_asset_amount: Balance,
liquidity_asset_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypeAmounts>;
) -> RpcResult<(NumberOrHex, NumberOrHex)>;

#[method(name = "xyk_get_max_instant_burn_amount")]
fn get_max_instant_burn_amount(
&self,
user: AccountId,
liquidity_asset_id: TokenId,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_get_max_instant_unreserve_amount")]
fn get_max_instant_unreserve_amount(
&self,
user: AccountId,
liquidity_asset_id: TokenId,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_calculate_rewards_amount")]
fn calculate_rewards_amount(
&self,
user: AccountId,
liquidity_asset_id: TokenId,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_calculate_balanced_sell_amount")]
fn calculate_balanced_sell_amount(
&self,
total_amount: Balance,
reserve_amount: Balance,
total_amount: NumberOrHex,
reserve_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<ResponseTypePrice>;
) -> RpcResult<NumberOrHex>;

#[method(name = "xyk_get_liq_tokens_for_trading")]
fn get_liq_tokens_for_trading(&self, at: Option<BlockHash>) -> RpcResult<Vec<TokenId>>;
Expand All @@ -114,15 +105,15 @@ pub trait XykApi<
fn is_buy_asset_lock_free(
&self,
path: sp_std::vec::Vec<TokenId>,
input_amount: Balance,
input_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<Option<bool>>;

#[method(name = "xyk_is_sell_asset_lock_free")]
fn is_sell_asset_lock_free(
&self,
path: sp_std::vec::Vec<TokenId>,
input_amount: Balance,
input_amount: NumberOrHex,
at: Option<BlockHash>,
) -> RpcResult<Option<bool>>;

Expand Down Expand Up @@ -162,22 +153,14 @@ impl<T: TryFrom<U256>> TryIntoBalance<T> for NumberOrHex {

#[async_trait]
impl<C, Block, Balance, TokenId, AccountId>
XykApiServer<
<Block as BlockT>::Hash,
NumberOrHex,
TokenId,
AccountId,
XYKRpcResult<Balance>,
RpcAmountsResult<Balance>,
Balance,
> for Xyk<C, Block>
XykApiServer<<Block as BlockT>::Hash, Balance, TokenId, AccountId> for Xyk<C, Block>
where
Block: BlockT,
C: Send + Sync + 'static,
C: ProvideRuntimeApi<Block>,
C: HeaderBackend<Block>,
C::Api: XykRuntimeApi<Block, Balance, TokenId, AccountId>,
Balance: Codec + MaybeDisplay + MaybeFromStr + TryFrom<U256>,
Balance: Codec + MaybeDisplay + MaybeFromStr + TryFrom<U256> + Into<NumberOrHex>,
TokenId: Codec + MaybeDisplay + MaybeFromStr,
AccountId: Codec + MaybeDisplay + MaybeFromStr,
{
Expand All @@ -187,17 +170,18 @@ where
output_reserve: NumberOrHex,
sell_amount: NumberOrHex,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

let runtime_api_result = api.calculate_sell_price(
api.calculate_sell_price(
at,
input_reserve.try_into_balance()?,
output_reserve.try_into_balance()?,
sell_amount.try_into_balance()?,
);
runtime_api_result.map_err(|e| {
)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Expand All @@ -212,17 +196,18 @@ where
output_reserve: NumberOrHex,
buy_amount: NumberOrHex,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

let runtime_api_result = api.calculate_buy_price(
api.calculate_buy_price(
at,
input_reserve.try_into_balance()?,
output_reserve.try_into_balance()?,
buy_amount.try_into_balance()?,
);
runtime_api_result.map_err(|e| {
)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Expand All @@ -237,17 +222,18 @@ where
bought_token_id: TokenId,
sell_amount: NumberOrHex,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

let runtime_api_result = api.calculate_sell_price_id(
api.calculate_sell_price_id(
at,
sold_token_id,
bought_token_id,
sell_amount.try_into_balance()?,
);
runtime_api_result.map_err(|e| {
)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Expand All @@ -262,17 +248,18 @@ where
bought_token_id: TokenId,
buy_amount: NumberOrHex,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

let runtime_api_result = api.calculate_buy_price_id(
api.calculate_buy_price_id(
at,
sold_token_id,
bought_token_id,
buy_amount.try_into_balance()?,
);
runtime_api_result.map_err(|e| {
)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Expand All @@ -287,17 +274,18 @@ where
second_asset_id: TokenId,
liquidity_asset_amount: NumberOrHex,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<RpcAmountsResult<Balance>> {
) -> RpcResult<(NumberOrHex, NumberOrHex)> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

let runtime_api_result = api.get_burn_amount(
api.get_burn_amount(
at,
first_asset_id,
second_asset_id,
liquidity_asset_amount.try_into_balance()?,
);
runtime_api_result.map_err(|e| {
)
.map(|(val1, val2)| (val1.into(), val2.into()))
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Expand All @@ -311,63 +299,67 @@ where
user: AccountId,
liquidity_asset_id: TokenId,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

api.get_max_instant_burn_amount(at, user, liquidity_asset_id).map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Some(format!("{:?}", e)),
)))
})
api.get_max_instant_burn_amount(at, user, liquidity_asset_id)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Some(format!("{:?}", e)),
)))
})
}

fn get_max_instant_unreserve_amount(
&self,
user: AccountId,
liquidity_asset_id: TokenId,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

api.get_max_instant_unreserve_amount(at, user, liquidity_asset_id).map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Some(format!("{:?}", e)),
)))
})
api.get_max_instant_unreserve_amount(at, user, liquidity_asset_id)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Some(format!("{:?}", e)),
)))
})
}

fn calculate_rewards_amount(
&self,
user: AccountId,
liquidity_asset_id: TokenId,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

let runtime_api_result = api.calculate_rewards_amount(at, user, liquidity_asset_id);

runtime_api_result.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Some(format!("{:?}", e)),
)))
})
api.calculate_rewards_amount(at, user, liquidity_asset_id)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
"Unable to serve the request",
Some(format!("{:?}", e)),
)))
})
}

fn calculate_balanced_sell_amount(
&self,
total_amount: NumberOrHex,
reserve_amount: NumberOrHex,
at: Option<<Block as BlockT>::Hash>,
) -> RpcResult<XYKRpcResult<Balance>> {
) -> RpcResult<NumberOrHex> {
let api = self.client.runtime_api();
let at = self.client.info().best_hash;

Expand All @@ -376,6 +368,7 @@ where
total_amount.try_into_balance()?,
reserve_amount.try_into_balance()?,
)
.map(Into::<NumberOrHex>::into)
.map_err(|e| {
JsonRpseeError::Call(CallError::Custom(ErrorObject::owned(
1,
Expand Down
Loading

0 comments on commit ab0d1fd

Please sign in to comment.