Skip to content

Commit

Permalink
fix(uniswapx-sdk): add classic amounts to priority order trade (#173)
Browse files Browse the repository at this point in the history
  • Loading branch information
zhongeric authored Oct 16, 2024
1 parent 7d4ed55 commit d25b3b0
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 6 deletions.
22 changes: 22 additions & 0 deletions sdks/uniswapx-sdk/src/trade/PriorityOrderTrade.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -124,4 +124,26 @@ describe("PriorityOrderTrade", () => {
);
expect(ethOutputTrade.outputAmount.currency).toEqual(Ether.onChain(1));
});

it("returns the correct amountIn and amountOut with classic quote data", () => {
const classicAmounts = {
classicAmountInGasAndPortionAdjusted: "1",
classicAmountOutGasAndPortionAdjusted: "1",
};
const classicAmountTrade = new PriorityOrderTrade<Currency, Currency, TradeType>(
{
currencyIn: USDC,
currenciesOut: [DAI],
orderInfo,
tradeType: TradeType.EXACT_INPUT,
classicAmounts,
}
);
expect(classicAmountTrade.inputAmount.quotient.toString()).toEqual(
classicAmounts.classicAmountInGasAndPortionAdjusted
);
expect(classicAmountTrade.outputAmount.quotient.toString()).toEqual(
classicAmounts.classicAmountOutGasAndPortionAdjusted
);
});
});
47 changes: 41 additions & 6 deletions sdks/uniswapx-sdk/src/trade/PriorityOrderTrade.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,10 @@ export class PriorityOrderTrade<
> {
public readonly tradeType: TTradeType;
public readonly order: UnsignedPriorityOrder;
public readonly classicAmounts: {
classicAmountInGasAndPortionAdjusted: string;
classicAmountOutGasAndPortionAdjusted: string;
} | undefined;

private _inputAmount: CurrencyAmount<TInput> | undefined;
private _outputAmounts: CurrencyAmount<TOutput>[] | undefined;
Expand All @@ -23,15 +27,21 @@ export class PriorityOrderTrade<
currenciesOut,
orderInfo,
tradeType,
classicAmounts,
}: {
currencyIn: TInput;
currenciesOut: TOutput[];
orderInfo: UnsignedPriorityOrderInfo;
tradeType: TTradeType;
classicAmounts?: {
classicAmountInGasAndPortionAdjusted: string;
classicAmountOutGasAndPortionAdjusted: string;
};
}) {
this._currencyIn = currencyIn;
this._currenciesOut = currenciesOut;
this.tradeType = tradeType;
this.classicAmounts = classicAmounts;

// assume single-chain for now
this.order = new UnsignedPriorityOrder(orderInfo, currencyIn.chainId);
Expand All @@ -40,10 +50,13 @@ export class PriorityOrderTrade<
public get inputAmount(): CurrencyAmount<TInput> {
if (this._inputAmount) return this._inputAmount;

const amount = CurrencyAmount.fromRawAmount(
this._currencyIn,
this.order.info.input.amount.toString()
);
// If we have classic quote data use that, otherwise use the order input amount
const amount = this.classicAmounts?.classicAmountInGasAndPortionAdjusted
? this.getClassicAmountIn()
: CurrencyAmount.fromRawAmount(
this._currencyIn,
this.order.info.input.amount.toString()
);
this._inputAmount = amount;
return amount;
}
Expand Down Expand Up @@ -107,8 +120,8 @@ export class PriorityOrderTrade<

// TODO: revise when there are actually multiple output amounts. for now, assume only one non-fee output at a time
public get outputAmount(): CurrencyAmount<TOutput> {
// TODO: estimate epected amount, using classic quote or expected priority
return this.getFirstNonFeeOutputAmount();
// If we have classic quote data use that, otherwise use the first non-fee output
return this.classicAmounts?.classicAmountOutGasAndPortionAdjusted ? this.getClassicAmountOut() : this.getFirstNonFeeOutputAmount();
}

public minimumAmountOut(): CurrencyAmount<TOutput> {
Expand Down Expand Up @@ -151,4 +164,26 @@ export class PriorityOrderTrade<
this.minimumAmountOut().quotient
);
}

private getClassicAmountIn(): CurrencyAmount<TInput> {
if (!this.classicAmounts?.classicAmountInGasAndPortionAdjusted) {
throw new Error("classicAmountInGasAndPortionAdjusted not set");
}

return CurrencyAmount.fromRawAmount(
this._currencyIn,
this.classicAmounts.classicAmountInGasAndPortionAdjusted
);
}

private getClassicAmountOut(): CurrencyAmount<TOutput> {
if (!this.classicAmounts?.classicAmountOutGasAndPortionAdjusted) {
throw new Error("classicAmountOutGasAndPortionAdjusted not set");
}

return CurrencyAmount.fromRawAmount(
this._currenciesOut[0],
this.classicAmounts.classicAmountOutGasAndPortionAdjusted
);
}
}

0 comments on commit d25b3b0

Please sign in to comment.