@cryptorubic/web3 0.8.17-alpha.solana.1 → 0.8.17-alpha.solana.10

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.
Files changed (28) hide show
  1. package/package.json +21 -15
  2. package/src/lib/adapter/adapters/abstract-adapter.js +5 -3
  3. package/src/lib/adapter/adapters/bitcoin-adapter.js +1 -0
  4. package/src/lib/adapter/adapters/constants/tron-multicall-abi.d.ts +1 -1
  5. package/src/lib/adapter/adapters/evm-adapter.js +8 -6
  6. package/src/lib/adapter/adapters/models/adapter-factory-params.d.ts +9 -0
  7. package/src/lib/adapter/adapters/models/adapter-factory-params.js +2 -0
  8. package/src/lib/adapter/adapters/models/approve-adapter.d.ts +1 -1
  9. package/src/lib/adapter/adapters/models/solana-adapter-config.d.ts +3 -0
  10. package/src/lib/adapter/adapters/models/solana-adapter-config.js +2 -0
  11. package/src/lib/adapter/adapters/solana-adapter.d.ts +4 -1
  12. package/src/lib/adapter/adapters/solana-adapter.js +10 -6
  13. package/src/lib/adapter/adapters/ton-adapter.js +2 -0
  14. package/src/lib/adapter/adapters/tron-adapter.d.ts +6 -5
  15. package/src/lib/adapter/adapters/tron-adapter.js +1 -1
  16. package/src/lib/adapter/adapters/utils/solana-utils/solana-gas-service.d.ts +22 -0
  17. package/src/lib/adapter/adapters/utils/solana-utils/solana-gas-service.js +71 -0
  18. package/src/lib/adapter/adapters/utils/{solana-tokens-service.d.ts → solana-utils/solana-tokens-service.d.ts} +1 -1
  19. package/src/lib/adapter/adapters/utils/{solana-tokens-service.js → solana-utils/solana-tokens-service.js} +10 -8
  20. package/src/lib/adapter/adapters/utils/solana-utils/utility-funcs.d.ts +2 -0
  21. package/src/lib/adapter/adapters/utils/solana-utils/utility-funcs.js +9 -0
  22. package/src/lib/adapter/adapters/utils/ton-api.service.js +4 -0
  23. package/src/lib/adapter/blockchain-adapter-factory.service.d.ts +4 -6
  24. package/src/lib/adapter/blockchain-adapter-factory.service.js +21 -19
  25. package/src/lib/utils/web3-types/common-web3-pure.js +4 -2
  26. package/src/lib/utils/web3-types/solana-web3-pure.js +1 -1
  27. package/src/lib/utils/web3-types/sui-web3-pure.js +2 -2
  28. package/src/lib/utils/web3-types/tron-web3-pure.d.ts +2 -3
package/package.json CHANGED
@@ -1,27 +1,26 @@
1
1
  {
2
2
  "name": "@cryptorubic/web3",
3
- "version": "0.8.17-alpha.solana.1",
3
+ "version": "0.8.17-alpha.solana.10",
4
4
  "dependencies": {
5
- "tslib": "^2.3.0",
6
- "bignumber.js": "9.1.2",
7
- "@cryptorubic/core": "0.8.17-alpha.solana.1",
8
- "viem": "^2.19.1",
9
- "web3-utils": "^4.3.1",
10
- "@ton/ton": "^15.1.0",
5
+ "@ethersproject/bignumber": "^5.8.0",
6
+ "@mysten/sui": "^1.24.0",
7
+ "@solana/spl-token": "*",
11
8
  "@solana/web3.js": "1.95.3",
12
9
  "@solflare-wallet/utl-sdk": "^1.4.0",
13
- "@ethersproject/bignumber": "^5.7.0",
14
- "@cryptorubic/tron-types": "0.8.17-alpha.solana.1",
10
+ "@suiet/wallet-sdk": "^0.3.3",
11
+ "@ton/ton": "^15.1.0",
12
+ "axios": "*",
13
+ "bignumber.js": "9.1.2",
15
14
  "bitcoin-address-validation": "^2.2.3",
16
- "axios": "0.27.2",
15
+ "bs58": "^6.0.0",
17
16
  "crc-32": "^1.2.2",
17
+ "ethers": "*",
18
+ "js-base64": "^3.7.8",
18
19
  "tronweb": "^6.0.0-beta.4",
19
- "@solana/spl-token": "0.2.0",
20
- "@mysten/sui": "^1.24.0",
21
- "@suiet/wallet-sdk": "^0.3.3",
22
- "bs58": "^6.0.0",
23
- "ethers": "5.7.2"
20
+ "tslib": "*",
21
+ "viem": "^2.33.1"
24
22
  },
23
+ "peerDependencies": {},
25
24
  "type": "commonjs",
26
25
  "main": "./src/index.js",
27
26
  "typings": "./src/index.d.ts",
@@ -31,5 +30,12 @@
31
30
  "author": {
32
31
  "name": "Sleta Dmitrii"
33
32
  },
33
+ "exports": {
34
+ "./package.json": "./package.json",
35
+ ".": {
36
+ "types": "./src/index.d.ts",
37
+ "default": "./src/index.js"
38
+ }
39
+ },
34
40
  "types": "./src/index.d.ts"
35
41
  }
@@ -3,6 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AbstractAdapter = void 0;
4
4
  const viem_1 = require("viem");
5
5
  class AbstractAdapter {
6
+ logger;
7
+ blockchain;
8
+ _public = null;
6
9
  set public(value) {
7
10
  this._public = value;
8
11
  }
@@ -14,6 +17,7 @@ class AbstractAdapter {
14
17
  }
15
18
  return this._public;
16
19
  }
20
+ _wallet = null;
17
21
  set wallet(value) {
18
22
  this._wallet = value;
19
23
  }
@@ -25,6 +29,7 @@ class AbstractAdapter {
25
29
  }
26
30
  return this._wallet;
27
31
  }
32
+ _walletAddress = null;
28
33
  set walletAddress(value) {
29
34
  this._walletAddress = value;
30
35
  }
@@ -37,9 +42,6 @@ class AbstractAdapter {
37
42
  return this._walletAddress;
38
43
  }
39
44
  constructor(blockchain, logger) {
40
- this._public = null;
41
- this._wallet = null;
42
- this._walletAddress = null;
43
45
  this.blockchain = blockchain;
44
46
  if (logger) {
45
47
  this.logger = logger;
@@ -5,6 +5,7 @@ const core_1 = require("@cryptorubic/core");
5
5
  const bignumber_js_1 = require("bignumber.js");
6
6
  const abstract_adapter_1 = require("./abstract-adapter");
7
7
  class BitcoinAdapter extends abstract_adapter_1.AbstractAdapter {
8
+ httpClient;
8
9
  constructor(httpClient, logger) {
9
10
  super(core_1.BLOCKCHAIN_NAME.BITCOIN, logger);
10
11
  this.httpClient = httpClient;
@@ -1,2 +1,2 @@
1
- import { AbiItem } from 'web3-utils';
1
+ import { AbiItem } from '../../../utils/models/abi-types';
2
2
  export declare const TRON_MULTICALL_ABI: AbiItem[];
@@ -34,21 +34,22 @@ class EvmAdapter extends abstract_adapter_1.AbstractAdapter {
34
34
  return null;
35
35
  }
36
36
  const transports = rpcList.map((rpc) => (0, viem_1.http)(rpc, {
37
- batch: { batchSize: 2000, wait: 16 },
37
+ batch: { batchSize: 2_000, wait: 16 },
38
38
  onFetchResponse: (response) => {
39
39
  this.handlePossibleError(response);
40
40
  },
41
41
  retryCount: 2,
42
42
  retryDelay: 100,
43
- timeout: 5000
43
+ timeout: 5_000
44
44
  }));
45
45
  const chain = viem_blockchain_mapping_1.viemBlockchainMapping[this.blockchain];
46
+ // @ts-ignore
46
47
  return (0, viem_1.createPublicClient)({
47
48
  // @ts-ignore
48
49
  chain,
49
50
  transport: (0, viem_1.fallback)(transports, {
50
51
  rank: {
51
- interval: 1800000
52
+ interval: 1_800_000
52
53
  }
53
54
  })
54
55
  });
@@ -80,7 +81,8 @@ class EvmAdapter extends abstract_adapter_1.AbstractAdapter {
80
81
  to: to,
81
82
  value: (0, viem_1.parseEther)(value),
82
83
  data: data,
83
- chain: this.public.chain
84
+ chain: this.public.chain,
85
+ kzg: undefined
84
86
  });
85
87
  return result;
86
88
  }
@@ -135,7 +137,7 @@ class EvmAdapter extends abstract_adapter_1.AbstractAdapter {
135
137
  throw err;
136
138
  }
137
139
  }
138
- async simulateTransaction(config, from, timeout = 15000) {
140
+ async simulateTransaction(config, from, timeout = 15_000) {
139
141
  try {
140
142
  const callParams = {
141
143
  account: from,
@@ -278,7 +280,7 @@ class EvmAdapter extends abstract_adapter_1.AbstractAdapter {
278
280
  to: tx.to
279
281
  };
280
282
  }
281
- async approveOnPermit2(fromAddress, tokenAddress, permit2Address, spenderAddress, deadline = new bignumber_js_1.default(1000000), amount) {
283
+ async approveOnPermit2(fromAddress, tokenAddress, permit2Address, spenderAddress, deadline = new bignumber_js_1.default(1_000_000), amount) {
282
284
  const approveAmount = amount ? amount : new bignumber_js_1.default(2).pow(256).minus(1);
283
285
  const expiration = new bignumber_js_1.default(Date.now()).plus(deadline).toFixed();
284
286
  const tx = this.encodePermit2Approve(tokenAddress, spenderAddress, permit2Address, expiration, approveAmount.toFixed());
@@ -0,0 +1,9 @@
1
+ import { HttpClient, ICustomLogger } from '@cryptorubic/core';
2
+ import { SolanaAdapterConfig } from './solana-adapter-config';
3
+ import { TonAdapterConfig } from './ton-adapter-config';
4
+ export interface AdaptersFactoryParams {
5
+ tonParams: TonAdapterConfig;
6
+ solanaParams: SolanaAdapterConfig;
7
+ httpClient?: HttpClient;
8
+ createLogger?: (label: string) => ICustomLogger;
9
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -2,7 +2,7 @@ import { BlockchainName, TokenAmount } from '@cryptorubic/core';
2
2
  import { AllowanceInfo } from './common-types';
3
3
  import { AbstractAdapter } from '../abstract-adapter';
4
4
  import { EvmTransactionConfig } from '../../../utils/models/evm-transaction-config';
5
- import { TronTransactionConfig } from '@cryptorubic/tron-types';
5
+ import { TronTransactionConfig } from '../../../utils/models/tron-transaction-config';
6
6
  export interface ApproveAdapter<T> extends AbstractAdapter<any, any, BlockchainName> {
7
7
  /**
8
8
  * @param fromTokenAddress erc20 address of checked token
@@ -0,0 +1,3 @@
1
+ export interface SolanaAdapterConfig {
2
+ heliusApiKey: string;
3
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -5,11 +5,14 @@ import { HttpClient, ICustomLogger, PriceTokenAmount, SolanaBlockchainName, Toke
5
5
  import BigNumber from 'bignumber.js';
6
6
  import { SolanaRawInstruction } from './models/solana-web3-types';
7
7
  import { SolanaTxConfig } from '../../utils/models/solana-transaction-config';
8
+ import { SolanaAdapterConfig } from './models/solana-adapter-config';
9
+ import { SolanaGasService } from './utils/solana-utils/solana-gas-service';
8
10
  export declare const NATIVE_SOLANA_MINT_ADDRESS = "So11111111111111111111111111111111111111111";
9
11
  export declare const DEFAULT_CU_LIMIT = 600000;
10
12
  export declare class SolanaAdapter extends AbstractAdapter<Connection, Connection, SolanaBlockchainName> {
11
13
  private readonly httpClient;
12
- constructor(rpcList: string[], httpClient: HttpClient, logger?: ICustomLogger);
14
+ readonly gasService: SolanaGasService;
15
+ constructor(rpcList: string[], httpClient: HttpClient, solanaConfig: SolanaAdapterConfig, logger?: ICustomLogger);
13
16
  private createPublicClient;
14
17
  read<T>(_address: string, _abi: Abi, _method: string, _methodArgs?: unknown[]): Promise<T>;
15
18
  write<T>(_address: string, _abi: Abi, _method: string, _methodArgs?: unknown[]): Promise<T>;
@@ -7,16 +7,20 @@ const web3_js_1 = require("@solana/web3.js");
7
7
  const core_1 = require("@cryptorubic/core");
8
8
  const web3_pure_1 = require("../../utils/web3-pure");
9
9
  const bignumber_js_1 = require("bignumber.js");
10
- const solana_tokens_service_1 = require("./utils/solana-tokens-service");
11
10
  const bs58_1 = require("bs58");
12
- const utils_1 = require("ethers/lib/utils");
11
+ const js_base64_1 = require("js-base64");
12
+ const solana_gas_service_1 = require("./utils/solana-utils/solana-gas-service");
13
+ const solana_tokens_service_1 = require("./utils/solana-utils/solana-tokens-service");
13
14
  exports.NATIVE_SOLANA_MINT_ADDRESS = 'So11111111111111111111111111111111111111111';
14
- exports.DEFAULT_CU_LIMIT = 600000;
15
+ exports.DEFAULT_CU_LIMIT = 600_000;
15
16
  class SolanaAdapter extends abstract_adapter_1.AbstractAdapter {
16
- constructor(rpcList, httpClient, logger) {
17
+ httpClient;
18
+ gasService;
19
+ constructor(rpcList, httpClient, solanaConfig, logger) {
17
20
  super(core_1.BLOCKCHAIN_NAME.SOLANA, logger);
18
21
  this.httpClient = httpClient;
19
22
  this.public = this.createPublicClient(rpcList);
23
+ this.gasService = new solana_gas_service_1.SolanaGasService(httpClient, this.public, solanaConfig);
20
24
  }
21
25
  createPublicClient(rpcList) {
22
26
  if (!rpcList?.[0]) {
@@ -39,7 +43,7 @@ class SolanaAdapter extends abstract_adapter_1.AbstractAdapter {
39
43
  async multicallByAddress(_address, _abi, _method, _methodArgs = [], _allowErrors = true) {
40
44
  throw new Error('Method multicall is not supported');
41
45
  }
42
- async simulateTransaction(config, timeout = 15000) {
46
+ async simulateTransaction(config, timeout = 15_000) {
43
47
  try {
44
48
  const bufferData = config.data.startsWith('0x') ? Buffer.from(config.data.slice(2), 'hex') : Buffer.from(config.data, 'base64');
45
49
  const { blockhash } = await this.public.getLatestBlockhash();
@@ -179,7 +183,7 @@ class SolanaAdapter extends abstract_adapter_1.AbstractAdapter {
179
183
  return new web3_js_1.VersionedTransaction(newMsg);
180
184
  }
181
185
  deserializeTransaction(data) {
182
- const decodedData = data.startsWith('0x') ? Buffer.from(data.slice(2), 'hex') : utils_1.base64.decode(data);
186
+ const decodedData = data.startsWith('0x') ? Buffer.from(data.slice(2), 'hex') : js_base64_1.Base64.toUint8Array(data);
183
187
  return web3_js_1.VersionedTransaction.deserialize(decodedData);
184
188
  }
185
189
  serializeTransactionToBase58(tx) {
@@ -8,6 +8,8 @@ const bignumber_js_1 = require("bignumber.js");
8
8
  const abstract_adapter_1 = require("./abstract-adapter");
9
9
  const web3_pure_1 = require("../../utils/web3-pure");
10
10
  class TonAdapter extends abstract_adapter_1.AbstractAdapter {
11
+ tonApi;
12
+ tonClient;
11
13
  constructor(httpClient, config, logger) {
12
14
  super(core_1.BLOCKCHAIN_NAME.TON, logger);
13
15
  this.tonApi = new ton_api_service_1.TonApiService(httpClient, config.tonApiConfig);
@@ -1,25 +1,26 @@
1
1
  import BigNumber from 'bignumber.js';
2
2
  import { AbstractAdapter } from './abstract-adapter';
3
- import { ContractMulticallResponse, MethodData, TronWeb3PrimitiveType } from '@cryptorubic/tron-types';
4
3
  import { TronWeb } from 'tronweb';
5
- import { AbiFragment } from 'tronweb/lib/commonjs/types';
6
4
  import { ICustomLogger, PriceTokenAmount, Token, TokenAmount, TronBlockchainName } from '@cryptorubic/core';
7
5
  import { TronTransactionConfig } from '../../utils/models/tron-transaction-config';
8
6
  import { TronParameters } from '../../utils/models/tron-parameters';
9
7
  import { Abi } from 'viem';
10
8
  import { ApproveAdapter } from './models/approve-adapter';
11
9
  import { AllowanceInfo } from './models/common-types';
10
+ import { ContractMulticallResponse } from '../../utils/models/contract-multicall-response';
11
+ import { TronWeb3PrimitiveType } from '../../utils/models/primitive-types';
12
+ import { MethodData } from '../../utils/models/method-data';
12
13
  export declare class TronAdapter extends AbstractAdapter<TronWeb, TronWeb, TronBlockchainName> implements ApproveAdapter<TronTransactionConfig> {
13
14
  private readonly multicallAddress;
14
15
  needPreswapAction(token: TokenAmount, contractAddress: string, walletAddress: string, amount: string): Promise<boolean>;
15
16
  constructor(rpcList: string[], logger?: ICustomLogger);
16
17
  checkEnoughBalance(token: TokenAmount | PriceTokenAmount, walletAddress: string): Promise<boolean>;
17
- multicallContractsMethods<Output extends TronWeb3PrimitiveType>(contractAbi: readonly AbiFragment[], contractsData: {
18
+ multicallContractsMethods<Output extends TronWeb3PrimitiveType>(contractAbi: any, contractsData: {
18
19
  contractAddress: string;
19
20
  methodsData: MethodData[];
20
- }[]): Promise<ContractMulticallResponse<Output>[][]>;
21
+ }[]): Promise<ContractMulticallResponse<any>[][]>;
21
22
  private multicall;
22
- read<T>(contractAddress: string, contractAbi: readonly AbiFragment[], methodName: string, methodArguments?: unknown[]): Promise<T>;
23
+ read<T>(contractAddress: string, contractAbi: any, methodName: string, methodArguments?: unknown[]): Promise<T>;
23
24
  private multicallContractsMethodsByOne;
24
25
  getTokensBalances(userAddress: string, tokensAddresses: string[]): Promise<BigNumber[]>;
25
26
  callForTokensInfo(tokenAddresses: string[] | ReadonlyArray<string>): Promise<Token[]>;
@@ -10,13 +10,13 @@ const core_1 = require("@cryptorubic/core");
10
10
  const web3_pure_1 = require("../../utils/web3-pure");
11
11
  const tron_web3_pure_1 = require("../../utils/web3-types/tron-web3-pure");
12
12
  class TronAdapter extends abstract_adapter_1.AbstractAdapter {
13
+ multicallAddress = 'T9ziQU4EBteJzjzMzhHELdhgWFqwzS5Vki';
13
14
  async needPreswapAction(token, contractAddress, walletAddress, amount) {
14
15
  // return this.needApprove()
15
16
  return false;
16
17
  }
17
18
  constructor(rpcList, logger) {
18
19
  super(core_1.BLOCKCHAIN_NAME.TRON, logger);
19
- this.multicallAddress = 'T9ziQU4EBteJzjzMzhHELdhgWFqwzS5Vki';
20
20
  this.public = new tronweb_1.TronWeb({ fullHost: rpcList[0] });
21
21
  }
22
22
  async checkEnoughBalance(token, walletAddress) {
@@ -0,0 +1,22 @@
1
+ import { HttpClient } from '@cryptorubic/core';
2
+ import { Connection } from '@solana/web3.js';
3
+ import { SolanaAdapterConfig } from '../../models/solana-adapter-config';
4
+ import BigNumber from 'bignumber.js';
5
+ export declare class SolanaGasService {
6
+ private httpClient;
7
+ private readonly connection;
8
+ private readonly HELIUS_API_URL;
9
+ private readonly HELIUS_API_KEY;
10
+ constructor(httpClient: HttpClient, connection: Connection, solanaConfig: SolanaAdapterConfig);
11
+ /**
12
+ * @returns wei ComputedUnitsLimit - like gasLimit in evm
13
+ */
14
+ getConsumedUnitsLimit(txData: string): Promise<BigNumber>;
15
+ /**
16
+ * @param txData base64 or hex string
17
+ * @returns wei ComputedUnitsPrice - like gasPrice in evm
18
+ */
19
+ getConsumedUnitsPrice(txData: string): Promise<BigNumber>;
20
+ private calculateCUPriceHelius;
21
+ private calculateCUPriceSolWeb3;
22
+ }
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SolanaGasService = void 0;
4
+ const utils_1 = require("ethers/lib/utils");
5
+ const utility_funcs_1 = require("./utility-funcs");
6
+ const bignumber_js_1 = require("bignumber.js");
7
+ class SolanaGasService {
8
+ httpClient;
9
+ connection;
10
+ HELIUS_API_URL = 'https://mainnet.helius-rpc.com';
11
+ HELIUS_API_KEY;
12
+ constructor(httpClient, connection, solanaConfig) {
13
+ this.httpClient = httpClient;
14
+ this.connection = connection;
15
+ this.HELIUS_API_KEY = solanaConfig.heliusApiKey;
16
+ }
17
+ /**
18
+ * @returns wei ComputedUnitsLimit - like gasLimit in evm
19
+ */
20
+ async getConsumedUnitsLimit(txData) {
21
+ const DEFAULT_CU_LIMIT = 600_000;
22
+ try {
23
+ const tx = (0, utility_funcs_1.convertB64DataToTx)(txData);
24
+ const resp = await this.connection.simulateTransaction(tx, {
25
+ replaceRecentBlockhash: true
26
+ });
27
+ return resp.value.unitsConsumed ? new bignumber_js_1.default(resp.value.unitsConsumed * 1.2) : new bignumber_js_1.default(DEFAULT_CU_LIMIT);
28
+ }
29
+ catch (err) {
30
+ console.error('Solana_simulateTransaction_Error ==> ', err);
31
+ return new bignumber_js_1.default(DEFAULT_CU_LIMIT);
32
+ }
33
+ }
34
+ /**
35
+ * @param txData base64 or hex string
36
+ * @returns wei ComputedUnitsPrice - like gasPrice in evm
37
+ */
38
+ async getConsumedUnitsPrice(txData) {
39
+ if (!this.HELIUS_API_KEY) {
40
+ console.warn('[SolanaApiService_getConsumedUnitsPrice] heliusApiKey is not provided in "createFactory"');
41
+ }
42
+ const cuPrice = await Promise.any([this.calculateCUPriceHelius(txData), this.calculateCUPriceSolWeb3()]);
43
+ return cuPrice;
44
+ }
45
+ async calculateCUPriceHelius(txData) {
46
+ const tx = (0, utility_funcs_1.convertB64DataToTx)(txData);
47
+ const resp = await this.httpClient.post(`${this.HELIUS_API_URL}/?api-key=${this.HELIUS_API_KEY}`, {
48
+ jsonrpc: '2.0',
49
+ id: '1',
50
+ method: 'getPriorityFeeEstimate',
51
+ params: [
52
+ {
53
+ transaction: utils_1.base58.encode(tx.serialize()), // Pass the serialized transaction in Base58
54
+ options: { priorityLevel: 'Medium' }
55
+ }
56
+ ]
57
+ });
58
+ return new bignumber_js_1.default(resp.result.priorityFeeEstimate);
59
+ }
60
+ async calculateCUPriceSolWeb3() {
61
+ const BASE_FEE = 5_000;
62
+ const resp = await this.connection.getRecentPrioritizationFees();
63
+ const avgCUPrice = resp
64
+ .reduce((acc, tx) => acc.plus(tx.prioritizationFee), new bignumber_js_1.default(0))
65
+ .div(resp.length)
66
+ .dp(0, bignumber_js_1.default.ROUND_CEIL);
67
+ const cuPrice = new bignumber_js_1.default(Math.max(BASE_FEE, avgCUPrice.toNumber()));
68
+ return cuPrice;
69
+ }
70
+ }
71
+ exports.SolanaGasService = SolanaGasService;
@@ -1,6 +1,6 @@
1
1
  import { Connection, PublicKey } from '@solana/web3.js';
2
2
  import { HttpClient } from '@cryptorubic/core';
3
- import { SolanaToken } from '../models/solana-web3-types';
3
+ import { SolanaToken } from '../../models/solana-web3-types';
4
4
  export declare class SolanaTokensService {
5
5
  private readonly httpClient;
6
6
  private connection;
@@ -3,16 +3,18 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SolanaTokensService = void 0;
4
4
  const spl_token_1 = require("@solana/spl-token");
5
5
  const utl_sdk_1 = require("@solflare-wallet/utl-sdk");
6
- const timeout_1 = require("./timeout");
6
+ const timeout_1 = require("../timeout");
7
7
  class SolanaTokensService {
8
+ httpClient;
9
+ connection;
10
+ // key - address of token, value - idx of token in initial tokensAddress
11
+ tokensOrder = {};
12
+ initialMints = [];
13
+ apiEndpoint = 'https://x-api.rubic.exchange/sol_token_list';
14
+ newTokensEndpoint = 'https://api.rubic.exchange/api/v2';
15
+ xApiKey = 'sndfje3u4b3fnNSDNFUSDNVSunw345842hrnfd3b4nt4';
8
16
  constructor(connection, httpClient) {
9
17
  this.httpClient = httpClient;
10
- // key - address of token, value - idx of token in initial tokensAddress
11
- this.tokensOrder = {};
12
- this.initialMints = [];
13
- this.apiEndpoint = 'https://x-api.rubic.exchange/sol_token_list';
14
- this.newTokensEndpoint = 'https://api.rubic.exchange/api/v2';
15
- this.xApiKey = 'sndfje3u4b3fnNSDNFUSDNVSunw345842hrnfd3b4nt4';
16
18
  this.connection = connection;
17
19
  }
18
20
  async fetchTokensData(mints) {
@@ -57,7 +59,7 @@ class SolanaTokensService {
57
59
  }
58
60
  async fetchTokensFromOldBackend(mints, prevFetchedTokens) {
59
61
  const tokensAddresses = mints.map((mint) => mint.toString());
60
- const { content: tokensFromOlbBackend } = await (0, timeout_1.withTimeout)(this.getTokensListOld(tokensAddresses), 3000, 'Api Timeout!').catch(() => ({ content: [] }));
62
+ const { content: tokensFromOlbBackend } = await (0, timeout_1.withTimeout)(this.getTokensListOld(tokensAddresses), 3_000, 'Api Timeout!').catch(() => ({ content: [] }));
61
63
  const notSortedTokensList = [...prevFetchedTokens, ...tokensFromOlbBackend];
62
64
  const notFetchedMints = this.getNotFetchedTokensList(notSortedTokensList);
63
65
  return {
@@ -0,0 +1,2 @@
1
+ import { VersionedTransaction } from '@solana/web3.js';
2
+ export declare function convertB64DataToTx(txData: string): VersionedTransaction;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertB64DataToTx = convertB64DataToTx;
4
+ const web3_js_1 = require("@solana/web3.js");
5
+ function convertB64DataToTx(txData) {
6
+ const bufferData = txData.startsWith('0x') ? Buffer.from(txData.slice(2), 'hex') : Buffer.from(txData, 'base64');
7
+ const tx = web3_js_1.VersionedTransaction.deserialize(bufferData);
8
+ return tx;
9
+ }
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.TonApiService = void 0;
4
4
  class TonApiService {
5
+ httpClient;
6
+ tonApiUrl;
7
+ apiKey;
8
+ tonCenterV3Url;
5
9
  constructor(httpClient, params) {
6
10
  this.httpClient = httpClient;
7
11
  this.apiKey = params.tonApiKey;
@@ -2,21 +2,19 @@ import { SolanaAdapter } from './adapters/solana-adapter';
2
2
  import { TronAdapter } from './adapters/tron-adapter';
3
3
  import { AbstractAdapter } from './adapters/abstract-adapter';
4
4
  import { WalletProvider } from './constants/models/wallet-provider';
5
- import { BlockchainName, EvmBlockchainName, SolanaBlockchainName, TronBlockchainName, ICustomLogger, HttpClient, TonBlockchainName, BitcoinBlockchainName, SuiBlockchainName } from '@cryptorubic/core';
5
+ import { BlockchainName, EvmBlockchainName, SolanaBlockchainName, TronBlockchainName, ICustomLogger, TonBlockchainName, BitcoinBlockchainName, SuiBlockchainName } from '@cryptorubic/core';
6
6
  import { TonAdapter } from './adapters/ton-adapter';
7
- import { TonAdapterConfig } from './adapters/models/ton-adapter-config';
8
7
  import { EvmAdapter } from './adapters/evm-adapter';
9
8
  import { BitcoinAdapter } from './adapters/bitcoin-adapter';
10
9
  import { SuiAdapter } from './adapters/sui-adapter';
10
+ import { AdaptersFactoryParams } from './adapters/models/adapter-factory-params';
11
11
  export declare class BlockchainAdapterFactoryService {
12
12
  private readonly rpcList;
13
- private readonly createLogger?;
14
- private readonly httpClient?;
15
- private readonly tonParams?;
13
+ private readonly params;
16
14
  readonly adapterStore: Partial<Record<BlockchainName, AbstractAdapter<unknown, unknown, BlockchainName>>>;
17
15
  protected readonly logger?: ICustomLogger;
18
16
  private constructor();
19
- static createFactory(rpcList: Partial<Record<EvmBlockchainName, string[]>>, httpClient?: HttpClient, tonParams?: TonAdapterConfig, createLogger?: (label: string) => ICustomLogger): Promise<BlockchainAdapterFactoryService>;
17
+ static createFactory(rpcList: Partial<Record<EvmBlockchainName, string[]>>, params: AdaptersFactoryParams): Promise<BlockchainAdapterFactoryService>;
20
18
  getAdapter(blockchain: SolanaBlockchainName): SolanaAdapter;
21
19
  getAdapter(blockchain: EvmBlockchainName): EvmAdapter;
22
20
  getAdapter(blockchain: TronBlockchainName): TronAdapter;
@@ -11,22 +11,24 @@ const evm_adapter_1 = require("./adapters/evm-adapter");
11
11
  const bitcoin_adapter_1 = require("./adapters/bitcoin-adapter");
12
12
  const sui_adapter_1 = require("./adapters/sui-adapter");
13
13
  class BlockchainAdapterFactoryService {
14
- constructor(rpcList, createLogger, httpClient, tonParams) {
14
+ rpcList;
15
+ params;
16
+ adapterStore = {};
17
+ logger;
18
+ constructor(rpcList, params) {
15
19
  this.rpcList = rpcList;
16
- this.createLogger = createLogger;
17
- this.httpClient = httpClient;
18
- this.tonParams = tonParams;
19
- this.adapterStore = {};
20
+ this.params = params;
20
21
  this.adapterStore = this.createStorage();
21
- if (this.createLogger) {
22
- this.logger = this.createLogger('BlockchainAdapterFactory');
22
+ if (this.params.createLogger) {
23
+ this.logger = this.params.createLogger('BlockchainAdapterFactory');
23
24
  }
24
25
  }
25
- static async createFactory(rpcList, httpClient, tonParams, createLogger) {
26
+ static async createFactory(rpcList, params) {
26
27
  // @TODO Add default logger
27
- const loggerFn = createLogger || undefined;
28
- const resolvedHttpClient = httpClient ?? (await Promise.resolve().then(() => require('axios')));
29
- return new this(rpcList, createLogger, resolvedHttpClient, tonParams);
28
+ const loggerFn = params.createLogger || undefined;
29
+ const resolvedHttpClient = params.httpClient ?? (await Promise.resolve().then(() => require('axios')));
30
+ params.httpClient = resolvedHttpClient;
31
+ return new this(rpcList, params);
30
32
  }
31
33
  getAdapter(blockchain) {
32
34
  const adapter = this.adapterStore?.[blockchain];
@@ -64,24 +66,24 @@ class BlockchainAdapterFactoryService {
64
66
  return new evm_adapter_1.EvmAdapter({
65
67
  blockchain: blockchain,
66
68
  rpcList: rpcs
67
- }, this.createLogger?.(`EVM_ADAPTER_${blockchain}`));
69
+ }, this.params.createLogger?.(`EVM_ADAPTER_${blockchain}`));
68
70
  }
69
71
  }
70
72
  if (blockchainType === core_1.CHAIN_TYPE.TRON) {
71
- return new tron_adapter_1.TronAdapter(rpcs, this.createLogger?.(`TRON_ADAPTER`));
73
+ return new tron_adapter_1.TronAdapter(rpcs, this.params.createLogger?.(`TRON_ADAPTER`));
72
74
  }
73
75
  if (blockchainType === core_1.CHAIN_TYPE.SUI) {
74
- return new sui_adapter_1.SuiAdapter(rpcs, this.createLogger?.(`SUI_ADAPTER`));
76
+ return new sui_adapter_1.SuiAdapter(rpcs, this.params.createLogger?.(`SUI_ADAPTER`));
75
77
  }
76
78
  if (blockchainType === core_1.CHAIN_TYPE.SOLANA) {
77
- return new solana_adapter_1.SolanaAdapter(rpcs, this.httpClient, this.createLogger?.(`SOLANA_ADAPTER`));
79
+ return new solana_adapter_1.SolanaAdapter(rpcs, this.params.httpClient, this.params.solanaParams, this.params.createLogger?.(`SOLANA_ADAPTER`));
78
80
  }
79
81
  }
80
- if (blockchain === core_1.BLOCKCHAIN_NAME.TON && this.tonParams?.tonApiConfig && this.tonParams?.tonClientConfig) {
81
- return new ton_adapter_1.TonAdapter(this.httpClient, this.tonParams, this.createLogger?.(`TON_ADAPTER`));
82
+ if (blockchain === core_1.BLOCKCHAIN_NAME.TON && this.params.tonParams?.tonApiConfig && this.params.tonParams?.tonClientConfig) {
83
+ return new ton_adapter_1.TonAdapter(this.params.httpClient, this.params.tonParams, this.params.createLogger?.(`TON_ADAPTER`));
82
84
  }
83
- if (blockchain === core_1.BLOCKCHAIN_NAME.BITCOIN && this.httpClient) {
84
- return new bitcoin_adapter_1.BitcoinAdapter(this.httpClient, this.createLogger?.(`BTC_ADAPTER`));
85
+ if (blockchain === core_1.BLOCKCHAIN_NAME.BITCOIN && this.params.httpClient) {
86
+ return new bitcoin_adapter_1.BitcoinAdapter(this.params.httpClient, this.params.createLogger?.(`BTC_ADAPTER`));
85
87
  }
86
88
  return null;
87
89
  }
@@ -3,9 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CommonWeb3Pure = void 0;
4
4
  const axios_1 = require("axios");
5
5
  class CommonWeb3Pure {
6
+ nativeTokenAddress = '0x0000000000000000000000000000000000000000';
7
+ emptyAddress = '0x0000000000000000000000000000000000000000';
8
+ cnApiKey;
9
+ regEx;
6
10
  constructor(commonParams) {
7
- this.nativeTokenAddress = '0x0000000000000000000000000000000000000000';
8
- this.emptyAddress = '0x0000000000000000000000000000000000000000';
9
11
  this.cnApiKey = commonParams?.cnApiKey || undefined;
10
12
  this.regEx = commonParams?.regex || undefined;
11
13
  }
@@ -5,12 +5,12 @@ const changenow_api_blockchain_1 = require("../constants/changenow-api-blockchai
5
5
  const common_web3_pure_1 = require("./common-web3-pure");
6
6
  const core_1 = require("@cryptorubic/core");
7
7
  class SolanaWeb3Pure extends common_web3_pure_1.CommonWeb3Pure {
8
+ nativeTokenAddress = 'So11111111111111111111111111111111111111111';
8
9
  constructor() {
9
10
  super({
10
11
  cnApiKey: changenow_api_blockchain_1.changenowApiBlockchain.SOLANA,
11
12
  regex: /^(?!.*([1-9A-HJ-NP-Za-km-z])\1{31,43}$)[1-9A-HJ-NP-Za-km-z]{32,44}$/
12
13
  });
13
- this.nativeTokenAddress = 'So11111111111111111111111111111111111111111';
14
14
  }
15
15
  async isAddressCorrect(address) {
16
16
  if ((0, core_1.compareAddresses)(address, this.nativeTokenAddress)) {
@@ -5,6 +5,8 @@ const common_web3_pure_1 = require("./common-web3-pure");
5
5
  const core_1 = require("@cryptorubic/core");
6
6
  const bignumber_js_1 = require("bignumber.js");
7
7
  class SuiWeb3Pure extends common_web3_pure_1.CommonWeb3Pure {
8
+ nativeTokenAddress = '0x0000000000000000000000000000000000000000000000000000000000000002::sui::SUI';
9
+ emptyAddress = '0x0000000000000000000000000000000000000000000000000000000000000002::sui::SUI';
8
10
  static compareAddress(addressA, addressB) {
9
11
  const pureAddressA = addressA.split(':')[0];
10
12
  const pureAddressB = addressB.split(':')[0];
@@ -20,8 +22,6 @@ class SuiWeb3Pure extends common_web3_pure_1.CommonWeb3Pure {
20
22
  super({
21
23
  regex: /(^0[xX][a-fA-F0-9]{0,64}::[a-zA-Z0-9_]*::[A-Z0-9_]*$)|(^0[xX][a-fA-F0-9]{64}$)/
22
24
  });
23
- this.nativeTokenAddress = '0x0000000000000000000000000000000000000000000000000000000000000002::sui::SUI';
24
- this.emptyAddress = '0x0000000000000000000000000000000000000000000000000000000000000002::sui::SUI';
25
25
  }
26
26
  }
27
27
  exports.SuiWeb3Pure = SuiWeb3Pure;
@@ -2,7 +2,6 @@ import { CommonWeb3Pure } from './common-web3-pure';
2
2
  import { TronTransactionConfig } from '../models/tron-transaction-config';
3
3
  import { TronParameters } from '../models/tron-parameters';
4
4
  import { TronWeb3PrimitiveType, Web3PrimitiveType } from '../models/primitive-types';
5
- import { FunctionFragment } from 'tronweb/src/types/ABI';
6
5
  import { AbiItem } from '../models/abi-types';
7
6
  export declare class TronWeb3Pure extends CommonWeb3Pure {
8
7
  constructor();
@@ -16,7 +15,7 @@ export declare class TronWeb3Pure extends CommonWeb3Pure {
16
15
  * @param methodArguments Parameters to encode.
17
16
  * @returns An ABI encoded function call. Means function signature + parameters.
18
17
  */
19
- static encodeFunctionCall(contractAbi: FunctionFragment[], methodName: string, methodArguments: unknown[]): string;
18
+ static encodeFunctionCall(contractAbi: any[], methodName: string, methodArguments: unknown[]): string;
20
19
  static encodeMethodSignature(methodSignature: string, parameters: TronParameters): string;
21
20
  /**
22
21
  * Decodes method result using its JSON interface object and given parameters.
@@ -24,7 +23,7 @@ export declare class TronWeb3Pure extends CommonWeb3Pure {
24
23
  * @param response Bytes code returned after method call.
25
24
  * @returns Parsed method output.
26
25
  */
27
- static decodeMethodOutput(outputAbi: FunctionFragment[], response: string): Web3PrimitiveType;
26
+ static decodeMethodOutput(outputAbi: any[], response: string): Web3PrimitiveType;
28
27
  private static flattenTypesToString;
29
28
  private static flattenTypesToArray;
30
29
  private static flattenParameters;