@cryptorubic/web3 0.8.17-alpha.solana.3 → 0.8.17-alpha.solana.4
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 +3 -3
- package/src/lib/adapter/adapters/solana-adapter.d.ts +1 -1
- package/src/lib/adapter/adapters/solana-adapter.js +2 -2
- package/src/lib/adapter/adapters/utils/{solana-api-service.d.ts → solana-utils/solana-api-service.d.ts} +4 -4
- package/src/lib/adapter/adapters/utils/{solana-api-service.js → solana-utils/solana-api-service.js} +5 -2
- package/src/lib/adapter/adapters/utils/{solana-tokens-service.d.ts → solana-utils/solana-tokens-service.d.ts} +1 -1
- package/src/lib/adapter/adapters/utils/{solana-tokens-service.js → solana-utils/solana-tokens-service.js} +1 -1
- package/src/lib/adapter/adapters/utils/solana-utils/utility-funcs.d.ts +2 -0
- package/src/lib/adapter/adapters/utils/solana-utils/utility-funcs.js +9 -0
package/package.json
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cryptorubic/web3",
|
|
3
|
-
"version": "0.8.17-alpha.solana.
|
|
3
|
+
"version": "0.8.17-alpha.solana.4",
|
|
4
4
|
"dependencies": {
|
|
5
5
|
"tslib": "^2.3.0",
|
|
6
6
|
"bignumber.js": "9.1.2",
|
|
7
|
-
"@cryptorubic/core": "0.8.17-alpha.solana.
|
|
7
|
+
"@cryptorubic/core": "0.8.17-alpha.solana.4",
|
|
8
8
|
"viem": "^2.19.1",
|
|
9
9
|
"web3-utils": "^4.3.1",
|
|
10
10
|
"@ton/ton": "^15.1.0",
|
|
11
11
|
"@solana/web3.js": "1.95.3",
|
|
12
12
|
"@solflare-wallet/utl-sdk": "^1.4.0",
|
|
13
13
|
"@ethersproject/bignumber": "^5.7.0",
|
|
14
|
-
"@cryptorubic/tron-types": "0.8.17-alpha.solana.
|
|
14
|
+
"@cryptorubic/tron-types": "0.8.17-alpha.solana.4",
|
|
15
15
|
"bitcoin-address-validation": "^2.2.3",
|
|
16
16
|
"axios": "0.27.2",
|
|
17
17
|
"crc-32": "^1.2.2",
|
|
@@ -5,8 +5,8 @@ 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 { SolanaApiService } from './utils/solana-api-service';
|
|
9
8
|
import { SolanaAdapterConfig } from './models/solana-adapter-config';
|
|
9
|
+
import { SolanaApiService } from './utils/solana-utils/solana-api-service';
|
|
10
10
|
export declare const NATIVE_SOLANA_MINT_ADDRESS = "So11111111111111111111111111111111111111111";
|
|
11
11
|
export declare const DEFAULT_CU_LIMIT = 600000;
|
|
12
12
|
export declare class SolanaAdapter extends AbstractAdapter<Connection, Connection, SolanaBlockchainName> {
|
|
@@ -7,10 +7,10 @@ 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
11
|
const utils_1 = require("ethers/lib/utils");
|
|
13
|
-
const solana_api_service_1 = require("./utils/solana-api-service");
|
|
12
|
+
const solana_api_service_1 = require("./utils/solana-utils/solana-api-service");
|
|
13
|
+
const solana_tokens_service_1 = require("./utils/solana-utils/solana-tokens-service");
|
|
14
14
|
exports.NATIVE_SOLANA_MINT_ADDRESS = 'So11111111111111111111111111111111111111111';
|
|
15
15
|
exports.DEFAULT_CU_LIMIT = 600000;
|
|
16
16
|
class SolanaAdapter extends abstract_adapter_1.AbstractAdapter {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { HttpClient } from '@cryptorubic/core';
|
|
2
|
-
import { Connection
|
|
3
|
-
import { SolanaAdapterConfig } from '
|
|
2
|
+
import { Connection } from '@solana/web3.js';
|
|
3
|
+
import { SolanaAdapterConfig } from '../../models/solana-adapter-config';
|
|
4
4
|
export declare class SolanaApiService {
|
|
5
5
|
private httpClient;
|
|
6
6
|
private readonly connection;
|
|
@@ -10,9 +10,9 @@ export declare class SolanaApiService {
|
|
|
10
10
|
/**
|
|
11
11
|
* @returns ComputedUnitsLimit - like gasLimit in evm
|
|
12
12
|
*/
|
|
13
|
-
getConsumedUnitsLimit(
|
|
13
|
+
getConsumedUnitsLimit(txData: string): Promise<number>;
|
|
14
14
|
/**
|
|
15
15
|
* @returns ComputedUnitsPrice - like gasPrice in evm
|
|
16
16
|
*/
|
|
17
|
-
getConsumedUnitsPrice(
|
|
17
|
+
getConsumedUnitsPrice(txData: string): Promise<number>;
|
|
18
18
|
}
|
package/src/lib/adapter/adapters/utils/{solana-api-service.js → solana-utils/solana-api-service.js}
RENAMED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.SolanaApiService = void 0;
|
|
4
4
|
const utils_1 = require("ethers/lib/utils");
|
|
5
|
+
const utility_funcs_1 = require("./utility-funcs");
|
|
5
6
|
class SolanaApiService {
|
|
6
7
|
constructor(httpClient, connection, solanaConfig) {
|
|
7
8
|
this.httpClient = httpClient;
|
|
@@ -12,9 +13,10 @@ class SolanaApiService {
|
|
|
12
13
|
/**
|
|
13
14
|
* @returns ComputedUnitsLimit - like gasLimit in evm
|
|
14
15
|
*/
|
|
15
|
-
async getConsumedUnitsLimit(
|
|
16
|
+
async getConsumedUnitsLimit(txData) {
|
|
16
17
|
const DEFAULT_CU_LIMIT = 600000;
|
|
17
18
|
try {
|
|
19
|
+
const tx = (0, utility_funcs_1.convertB64DataToTx)(txData);
|
|
18
20
|
const resp = await this.connection.simulateTransaction(tx, {
|
|
19
21
|
replaceRecentBlockhash: true
|
|
20
22
|
});
|
|
@@ -28,10 +30,11 @@ class SolanaApiService {
|
|
|
28
30
|
/**
|
|
29
31
|
* @returns ComputedUnitsPrice - like gasPrice in evm
|
|
30
32
|
*/
|
|
31
|
-
async getConsumedUnitsPrice(
|
|
33
|
+
async getConsumedUnitsPrice(txData) {
|
|
32
34
|
if (!this.HELIUS_API_KEY) {
|
|
33
35
|
throw new Error('[SolanaApiService_getConsumedUnitsPrice] params.solanaParams.heliusApiKey is not provided in "createFactory" method to use this method');
|
|
34
36
|
}
|
|
37
|
+
const tx = (0, utility_funcs_1.convertB64DataToTx)(txData);
|
|
35
38
|
const resp = await this.httpClient.post(`${this.HELIUS_API_URL}/?api-key=${this.HELIUS_API_KEY}`, {
|
|
36
39
|
jsonrpc: '2.0',
|
|
37
40
|
id: '1',
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Connection, PublicKey } from '@solana/web3.js';
|
|
2
2
|
import { HttpClient } from '@cryptorubic/core';
|
|
3
|
-
import { SolanaToken } from '
|
|
3
|
+
import { SolanaToken } from '../../models/solana-web3-types';
|
|
4
4
|
export declare class SolanaTokensService {
|
|
5
5
|
private readonly httpClient;
|
|
6
6
|
private connection;
|
|
@@ -3,7 +3,7 @@ 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("
|
|
6
|
+
const timeout_1 = require("../timeout");
|
|
7
7
|
class SolanaTokensService {
|
|
8
8
|
constructor(connection, httpClient) {
|
|
9
9
|
this.httpClient = httpClient;
|
|
@@ -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(base64Data) {
|
|
6
|
+
const bufferData = base64Data.startsWith('0x') ? Buffer.from(base64Data.slice(2), 'hex') : Buffer.from(base64Data, 'base64');
|
|
7
|
+
const tx = web3_js_1.VersionedTransaction.deserialize(bufferData);
|
|
8
|
+
return tx;
|
|
9
|
+
}
|