@cryptorubic/web3 0.13.0-alpha.solana-gas.1 → 0.13.0-alpha.solana-gas.3
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.
- package/package.json +1 -1
- package/src/lib/adapter/adapters/evm-adapter.js +1 -2
- package/src/lib/adapter/adapters/models/adapter-factory-params.d.ts +0 -2
- package/src/lib/adapter/adapters/solana-adapter.d.ts +1 -4
- package/src/lib/adapter/adapters/solana-adapter.js +1 -4
- package/src/lib/adapter/blockchain-adapter-factory.service.js +1 -1
- package/src/lib/adapter/adapters/models/solana-adapter-config.d.ts +0 -3
- package/src/lib/adapter/adapters/models/solana-adapter-config.js +0 -2
- package/src/lib/adapter/adapters/utils/solana-utils/solana-gas-service.d.ts +0 -27
- package/src/lib/adapter/adapters/utils/solana-utils/solana-gas-service.js +0 -97
- package/src/lib/adapter/adapters/utils/solana-utils/utility-funcs.d.ts +0 -2
- package/src/lib/adapter/adapters/utils/solana-utils/utility-funcs.js +0 -9
package/package.json
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
import { HttpClient, ICustomLogger } from '@cryptorubic/core';
|
|
2
|
-
import { SolanaAdapterConfig } from './solana-adapter-config';
|
|
3
2
|
import { TonAdapterConfig } from './ton-adapter-config';
|
|
4
3
|
export interface AdaptersFactoryParams {
|
|
5
4
|
tonParams: TonAdapterConfig;
|
|
6
|
-
solanaParams: SolanaAdapterConfig;
|
|
7
5
|
httpClient?: HttpClient;
|
|
8
6
|
createLogger?: (label: string) => ICustomLogger;
|
|
9
7
|
}
|
|
@@ -5,14 +5,11 @@ 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';
|
|
10
8
|
export declare const NATIVE_SOLANA_MINT_ADDRESS = "So11111111111111111111111111111111111111111";
|
|
11
9
|
export declare const DEFAULT_CU_LIMIT = 600000;
|
|
12
10
|
export declare class SolanaAdapter extends AbstractAdapter<Connection, Connection, SolanaBlockchainName> {
|
|
13
11
|
private readonly httpClient;
|
|
14
|
-
|
|
15
|
-
constructor(rpcList: string[], httpClient: HttpClient, solanaConfig: SolanaAdapterConfig, logger?: ICustomLogger);
|
|
12
|
+
constructor(rpcList: string[], httpClient: HttpClient, logger?: ICustomLogger);
|
|
16
13
|
private createPublicClient;
|
|
17
14
|
read<T>(_address: string, _abi: Abi, _method: string, _methodArgs?: unknown[]): Promise<T>;
|
|
18
15
|
write<T>(_address: string, _abi: Abi, _method: string, _methodArgs?: unknown[]): Promise<T>;
|
|
@@ -9,19 +9,16 @@ const web3_pure_1 = require("../../utils/web3-pure");
|
|
|
9
9
|
const bignumber_js_1 = require("bignumber.js");
|
|
10
10
|
const bs58_1 = require("bs58");
|
|
11
11
|
const js_base64_1 = require("js-base64");
|
|
12
|
-
const solana_gas_service_1 = require("./utils/solana-utils/solana-gas-service");
|
|
13
12
|
const solana_tokens_service_1 = require("./utils/solana-utils/solana-tokens-service");
|
|
14
13
|
const timeout_1 = require("./utils/timeout");
|
|
15
14
|
exports.NATIVE_SOLANA_MINT_ADDRESS = 'So11111111111111111111111111111111111111111';
|
|
16
15
|
exports.DEFAULT_CU_LIMIT = 600_000;
|
|
17
16
|
class SolanaAdapter extends abstract_adapter_1.AbstractAdapter {
|
|
18
17
|
httpClient;
|
|
19
|
-
|
|
20
|
-
constructor(rpcList, httpClient, solanaConfig, logger) {
|
|
18
|
+
constructor(rpcList, httpClient, logger) {
|
|
21
19
|
super(core_1.BLOCKCHAIN_NAME.SOLANA, logger);
|
|
22
20
|
this.httpClient = httpClient;
|
|
23
21
|
this.public = this.createPublicClient(rpcList);
|
|
24
|
-
this.gasService = new solana_gas_service_1.SolanaGasService(httpClient, this.public, logger, solanaConfig);
|
|
25
22
|
}
|
|
26
23
|
createPublicClient(rpcList) {
|
|
27
24
|
if (!rpcList?.[0]) {
|
|
@@ -76,7 +76,7 @@ class BlockchainAdapterFactoryService {
|
|
|
76
76
|
return new sui_adapter_1.SuiAdapter(rpcs, this.params.createLogger?.(`SUI_ADAPTER`));
|
|
77
77
|
}
|
|
78
78
|
if (blockchainType === core_1.CHAIN_TYPE.SOLANA) {
|
|
79
|
-
return new solana_adapter_1.SolanaAdapter(rpcs, this.params.httpClient, this.params.
|
|
79
|
+
return new solana_adapter_1.SolanaAdapter(rpcs, this.params.httpClient, this.params.createLogger?.(`SOLANA_ADAPTER`));
|
|
80
80
|
}
|
|
81
81
|
}
|
|
82
82
|
if (blockchain === core_1.BLOCKCHAIN_NAME.TON && this.params.tonParams?.tonApiConfig && this.params.tonParams?.tonClientConfig) {
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { HttpClient, ICustomLogger } 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 logger;
|
|
9
|
-
private readonly HELIUS_API_URL;
|
|
10
|
-
private readonly HELIUS_API_KEY;
|
|
11
|
-
readonly DEFAULT_CU_LIMIT = 200000;
|
|
12
|
-
constructor(httpClient: HttpClient, connection: Connection, logger: ICustomLogger | undefined, solanaConfig: SolanaAdapterConfig);
|
|
13
|
-
/**
|
|
14
|
-
* @returns wei ComputedUnitsLimit - like gasLimit in evm
|
|
15
|
-
*/
|
|
16
|
-
getConsumedUnitsLimit(txData: string): Promise<BigNumber>;
|
|
17
|
-
/**
|
|
18
|
-
* @param txData base64 or hex string
|
|
19
|
-
* @returns prioritizationFee in micro-lamports (lamport = 1_000_000 microlamports)
|
|
20
|
-
*/
|
|
21
|
-
getPriorityFee(txData: string): Promise<BigNumber>;
|
|
22
|
-
/**
|
|
23
|
-
* @returns prioritizationFee in micro-lamports(lamport * 10^-6)
|
|
24
|
-
*/
|
|
25
|
-
private calculatePriorityFeeHelius;
|
|
26
|
-
private getRecentPriorityFeeSolWeb3;
|
|
27
|
-
}
|
|
@@ -1,97 +0,0 @@
|
|
|
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
|
-
// solana gas fee FORMULA: 200_000 CU * 0.02 Lamports/CU = 4000 Lamports = 0.000004 SOL
|
|
8
|
-
class SolanaGasService {
|
|
9
|
-
httpClient;
|
|
10
|
-
connection;
|
|
11
|
-
logger;
|
|
12
|
-
HELIUS_API_URL = 'https://mainnet.helius-rpc.com';
|
|
13
|
-
HELIUS_API_KEY;
|
|
14
|
-
DEFAULT_CU_LIMIT = 200_000; //in CU
|
|
15
|
-
constructor(httpClient, connection, logger, solanaConfig) {
|
|
16
|
-
this.httpClient = httpClient;
|
|
17
|
-
this.connection = connection;
|
|
18
|
-
this.logger = logger;
|
|
19
|
-
this.HELIUS_API_KEY = solanaConfig.heliusApiKey;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* @returns wei ComputedUnitsLimit - like gasLimit in evm
|
|
23
|
-
*/
|
|
24
|
-
async getConsumedUnitsLimit(txData) {
|
|
25
|
-
try {
|
|
26
|
-
const tx = (0, utility_funcs_1.convertB64DataToTx)(txData);
|
|
27
|
-
const resp = await this.connection.simulateTransaction(tx, {
|
|
28
|
-
replaceRecentBlockhash: true
|
|
29
|
-
});
|
|
30
|
-
return resp.value.unitsConsumed ? new bignumber_js_1.default(resp.value.unitsConsumed * 1.2) : new bignumber_js_1.default(this.DEFAULT_CU_LIMIT);
|
|
31
|
-
}
|
|
32
|
-
catch (err) {
|
|
33
|
-
console.error('[SolanaApiService_getConsumedUnitsLimit] err ==> ', err);
|
|
34
|
-
return new bignumber_js_1.default(this.DEFAULT_CU_LIMIT);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* @param txData base64 or hex string
|
|
39
|
-
* @returns prioritizationFee in micro-lamports (lamport = 1_000_000 microlamports)
|
|
40
|
-
*/
|
|
41
|
-
async getPriorityFee(txData) {
|
|
42
|
-
if (!this.HELIUS_API_KEY) {
|
|
43
|
-
console.warn('[SolanaApiService_getPriorityFee] heliusApiKey is not provided in "createFactory"');
|
|
44
|
-
}
|
|
45
|
-
const resp = await Promise.allSettled([this.calculatePriorityFeeHelius(txData), this.getRecentPriorityFeeSolWeb3()]);
|
|
46
|
-
const cuPrice = resp
|
|
47
|
-
.filter((r) => r.status === 'fulfilled')
|
|
48
|
-
.map((r) => r.value)
|
|
49
|
-
.reduce((acc, price) => (acc.gt(price) ? acc : price), new bignumber_js_1.default(0));
|
|
50
|
-
return cuPrice;
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* @returns prioritizationFee in micro-lamports(lamport * 10^-6)
|
|
54
|
-
*/
|
|
55
|
-
async calculatePriorityFeeHelius(txData) {
|
|
56
|
-
try {
|
|
57
|
-
const tx = (0, utility_funcs_1.convertB64DataToTx)(txData);
|
|
58
|
-
const resp = await this.httpClient.post(`${this.HELIUS_API_URL}/?api-key=${this.HELIUS_API_KEY}`, {
|
|
59
|
-
jsonrpc: '2.0',
|
|
60
|
-
id: '1',
|
|
61
|
-
method: 'getPriorityFeeEstimate',
|
|
62
|
-
params: [
|
|
63
|
-
{
|
|
64
|
-
transaction: utils_1.base58.encode(tx.serialize()), // Pass the serialized transaction in Base58
|
|
65
|
-
options: { priorityLevel: 'Medium' }
|
|
66
|
-
}
|
|
67
|
-
]
|
|
68
|
-
});
|
|
69
|
-
this.logger?.customLog('HELIUS PRIORITY_FEE SUCCESS', { priorityFeeEstimate: resp.result.priorityFeeEstimate });
|
|
70
|
-
return new bignumber_js_1.default(resp.result.priorityFeeEstimate);
|
|
71
|
-
}
|
|
72
|
-
catch (err) {
|
|
73
|
-
this.logger?.customLog('HELIUS PRIORITY_FEE ERROR', err);
|
|
74
|
-
return new bignumber_js_1.default(0);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
async getRecentPriorityFeeSolWeb3() {
|
|
78
|
-
const lastSlot = await this.connection.getSlot();
|
|
79
|
-
// last slots array [1000, 1001, 1002 ...]
|
|
80
|
-
const last10Slots = Array.from({ length: 10 }, (_, idx) => lastSlot - idx).reverse();
|
|
81
|
-
const getPriorityFeesFromBlock = async (slotNum) => {
|
|
82
|
-
const block = await this.connection.getBlock(slotNum, { maxSupportedTransactionVersion: 0, commitment: 'confirmed' });
|
|
83
|
-
if (!block)
|
|
84
|
-
return [];
|
|
85
|
-
return block.transactions.map((tx) => (tx.meta && tx.meta.fee ? tx.meta.fee : 0));
|
|
86
|
-
};
|
|
87
|
-
const resp = await Promise.all(last10Slots.map((slotNum) => getPriorityFeesFromBlock(slotNum)));
|
|
88
|
-
const filteredPriorityFees = resp.flat().filter((fee) => fee > 0);
|
|
89
|
-
const avgProrityFee = filteredPriorityFees
|
|
90
|
-
.reduce((acc, fee) => acc.plus(fee), new bignumber_js_1.default(0))
|
|
91
|
-
.div(filteredPriorityFees.length)
|
|
92
|
-
.dp(0, bignumber_js_1.default.ROUND_CEIL);
|
|
93
|
-
this.logger?.customLog('SOLANA_WEB3 PRIORITY_FEE SUCCESS', { priorityFeeEstimate: avgProrityFee.toNumber() });
|
|
94
|
-
return avgProrityFee;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
exports.SolanaGasService = SolanaGasService;
|
|
@@ -1,9 +0,0 @@
|
|
|
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
|
-
}
|