@t2000/cli 0.25.9 → 0.25.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -66008,14 +66008,6 @@ var T2000 = class _T2000 extends import_index.default {
66008
66008
  if (route.priceImpact > 0.05) {
66009
66009
  console.warn(`[swap] High price impact: ${(route.priceImpact * 100).toFixed(2)}%`);
66010
66010
  }
66011
- const toEntry = Object.entries(SUPPORTED_ASSETS).find(([, v]) => v.type === toType);
66012
- const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
66013
- let preBalance = 0n;
66014
- try {
66015
- const bal = await this.client.getBalance({ owner: this._address, coinType: toType });
66016
- preBalance = BigInt(bal.totalBalance);
66017
- } catch {
66018
- }
66019
66011
  const gasResult = await executeWithGas(this.client, this._signer, async () => {
66020
66012
  const tx = new Transaction();
66021
66013
  tx.setSender(this._address);
@@ -66038,17 +66030,35 @@ var T2000 = class _T2000 extends import_index.default {
66038
66030
  tx.transferObjects([outputCoin], this._address);
66039
66031
  return tx;
66040
66032
  });
66033
+ const toEntry = Object.entries(SUPPORTED_ASSETS).find(([, v]) => v.type === toType);
66034
+ const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
66041
66035
  const fromAmount = Number(route.amountIn) / 10 ** fromDecimals;
66042
66036
  let toAmount = Number(route.amountOut) / 10 ** toDecimals;
66043
- try {
66044
- const postBal = await this.client.getBalance({ owner: this._address, coinType: toType });
66045
- const postBalance = BigInt(postBal.totalBalance);
66046
- const diff = postBalance - preBalance;
66047
- if (diff > 0n) {
66048
- toAmount = Number(diff) / 10 ** toDecimals;
66037
+ const toTypeSuffix = toType.split("::").slice(1).join("::");
66038
+ for (let attempt = 0; attempt < 4; attempt++) {
66039
+ try {
66040
+ const txBlock = await this.client.getTransactionBlock({
66041
+ digest: gasResult.digest,
66042
+ options: { showBalanceChanges: true }
66043
+ });
66044
+ const changes = txBlock.balanceChanges ?? [];
66045
+ const received = changes.find((c) => {
66046
+ if (BigInt(c.amount) <= 0n) return false;
66047
+ const ownerAddr = c.owner?.AddressOwner;
66048
+ if (!ownerAddr || ownerAddr.toLowerCase() !== this._address.toLowerCase()) return false;
66049
+ if (c.coinType === toType) return true;
66050
+ return c.coinType.endsWith(toTypeSuffix);
66051
+ });
66052
+ if (received) {
66053
+ const actual = Number(BigInt(received.amount)) / 10 ** toDecimals;
66054
+ if (actual > 0) {
66055
+ toAmount = actual;
66056
+ break;
66057
+ }
66058
+ }
66059
+ } catch {
66049
66060
  }
66050
- } catch {
66051
- console.warn("[swap] Could not read post-swap balance, using route estimate");
66061
+ if (attempt < 3) await new Promise((r) => setTimeout(r, 600));
66052
66062
  }
66053
66063
  const fromName = fromEntry ? fromEntry[0] : this._resolveTokenName(fromType, params.from);
66054
66064
  const toName = toEntry ? toEntry[0] : this._resolveTokenName(toType, params.to);
@@ -67073,4 +67083,4 @@ axios/dist/node/axios.cjs:
67073
67083
  @scure/bip39/index.js:
67074
67084
  (*! scure-bip39 - MIT License (c) 2022 Patricio Palladino, Paul Miller (paulmillr.com) *)
67075
67085
  */
67076
- //# sourceMappingURL=chunk-JHT7EXQL.js.map
67086
+ //# sourceMappingURL=chunk-CDQ2RJBX.js.map