@clonegod/ttd-sol-common 2.0.48 → 2.0.49
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.
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Transaction, VersionedTransaction } from '@solana/web3.js';
|
|
2
|
+
import { TradeContext } from '@clonegod/ttd-core/dist';
|
|
2
3
|
export declare class TransactionSender {
|
|
3
4
|
constructor();
|
|
4
|
-
sendTransaction(
|
|
5
|
-
sendBundle(mainTx: Transaction | VersionedTransaction, tipTx: Transaction | VersionedTransaction, use_multi_ips?: boolean): Promise<string>;
|
|
5
|
+
sendTransaction(context: TradeContext, mainTx: Transaction | VersionedTransaction, swqos_only?: boolean): Promise<string>;
|
|
6
|
+
sendBundle(context: TradeContext, mainTx: Transaction | VersionedTransaction, tipTx: Transaction | VersionedTransaction, use_multi_ips?: boolean): Promise<string>;
|
|
6
7
|
}
|
|
7
|
-
export declare function serializeTransactionBase64(tx: Transaction | VersionedTransaction): string;
|
|
@@ -1,23 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.TransactionSender = void 0;
|
|
4
|
-
exports.serializeTransactionBase64 = serializeTransactionBase64;
|
|
5
4
|
const web3_js_1 = require("@solana/web3.js");
|
|
6
5
|
const helius_1 = require("./helius");
|
|
7
6
|
const jito_1 = require("./jito");
|
|
8
7
|
const common_1 = require("../../common");
|
|
8
|
+
const sol_gas_cache_1 = require("../sol_gas_cache");
|
|
9
9
|
class TransactionSender {
|
|
10
10
|
constructor() {
|
|
11
11
|
}
|
|
12
|
-
async sendTransaction(
|
|
13
|
-
const
|
|
12
|
+
async sendTransaction(context, mainTx, swqos_only = true) {
|
|
13
|
+
const mainTxHash = (0, common_1.getSignature)(mainTx);
|
|
14
|
+
set_transaciton_gas_cost(mainTxHash, context);
|
|
15
|
+
const singedTxBase64 = serializeTransactionBase64(mainTx);
|
|
14
16
|
return await (0, helius_1.sendTxWithHelius)(singedTxBase64, swqos_only);
|
|
15
17
|
}
|
|
16
|
-
async sendBundle(mainTx, tipTx, use_multi_ips = false) {
|
|
18
|
+
async sendBundle(context, mainTx, tipTx, use_multi_ips = false) {
|
|
19
|
+
const mainTxHash = (0, common_1.getSignature)(mainTx);
|
|
20
|
+
set_transaciton_gas_cost(mainTxHash, context);
|
|
17
21
|
const mainTxBase64 = serializeTransactionBase64(mainTx);
|
|
18
22
|
const tipTxBase64 = serializeTransactionBase64(tipTx);
|
|
19
23
|
if (use_multi_ips) {
|
|
20
|
-
const mainTxHash = (0, common_1.getSignature)(mainTx);
|
|
21
24
|
return await (0, jito_1.sendBundleWithJitoMultiIps)(mainTxHash, mainTxBase64, tipTxBase64);
|
|
22
25
|
}
|
|
23
26
|
else {
|
|
@@ -36,3 +39,7 @@ function serializeTransactionBase64(tx) {
|
|
|
36
39
|
}
|
|
37
40
|
return buffer.toString('base64');
|
|
38
41
|
}
|
|
42
|
+
function set_transaciton_gas_cost(txid, context) {
|
|
43
|
+
const { sol_priority_fee, sol_tip_fee } = context.trade_runtime.settings.strategy;
|
|
44
|
+
(0, sol_gas_cache_1.set_sol_gas_fee)(txid, { base_fee: 5000, priority_fee: sol_priority_fee + sol_tip_fee, total_fee: 5000 + sol_priority_fee + sol_tip_fee });
|
|
45
|
+
}
|
package/package.json
CHANGED
|
@@ -2,6 +2,8 @@ import { Transaction, VersionedTransaction } from '@solana/web3.js';
|
|
|
2
2
|
import { sendTxWithHelius } from './helius';
|
|
3
3
|
import { sendBundleWithJito, sendBundleWithJitoMultiIps } from './jito';
|
|
4
4
|
import { getSignature } from '../../common';
|
|
5
|
+
import { TradeContext } from '@clonegod/ttd-core/dist';
|
|
6
|
+
import { set_sol_gas_fee } from '../sol_gas_cache';
|
|
5
7
|
|
|
6
8
|
|
|
7
9
|
/**
|
|
@@ -17,12 +19,15 @@ export class TransactionSender {
|
|
|
17
19
|
* - swqos_only=true, 需给 helius 发送至少5000lamports的通道使用费
|
|
18
20
|
* - swqos_only=false, 需给helius 发送至少0.0002SOL的小费,会同时向jito发送交易
|
|
19
21
|
*
|
|
20
|
-
* @param
|
|
22
|
+
* @param mainTx 签名后的交易
|
|
21
23
|
* @param swqos_only true:swqos ;false: swqos + jito
|
|
22
24
|
* @returns txhash
|
|
23
25
|
*/
|
|
24
|
-
async sendTransaction(
|
|
25
|
-
const
|
|
26
|
+
async sendTransaction(context:TradeContext, mainTx: Transaction | VersionedTransaction, swqos_only:boolean=true): Promise<string> {
|
|
27
|
+
const mainTxHash = getSignature(mainTx)
|
|
28
|
+
set_transaciton_gas_cost(mainTxHash, context)
|
|
29
|
+
|
|
30
|
+
const singedTxBase64 = serializeTransactionBase64(mainTx)
|
|
26
31
|
return await sendTxWithHelius(singedTxBase64, swqos_only)
|
|
27
32
|
}
|
|
28
33
|
|
|
@@ -36,11 +41,14 @@ export class TransactionSender {
|
|
|
36
41
|
* @param use_multi_ips true:多节点;false: 单节点
|
|
37
42
|
* @returns bundleId
|
|
38
43
|
*/
|
|
39
|
-
async sendBundle(mainTx: Transaction | VersionedTransaction, tipTx: Transaction | VersionedTransaction, use_multi_ips: boolean=false): Promise<string> {
|
|
44
|
+
async sendBundle(context:TradeContext, mainTx: Transaction | VersionedTransaction, tipTx: Transaction | VersionedTransaction, use_multi_ips: boolean=false): Promise<string> {
|
|
45
|
+
const mainTxHash = getSignature(mainTx)
|
|
46
|
+
set_transaciton_gas_cost(mainTxHash, context)
|
|
47
|
+
|
|
40
48
|
const mainTxBase64 = serializeTransactionBase64(mainTx)
|
|
41
49
|
const tipTxBase64 = serializeTransactionBase64(tipTx)
|
|
50
|
+
|
|
42
51
|
if(use_multi_ips) {
|
|
43
|
-
const mainTxHash = getSignature(mainTx)
|
|
44
52
|
return await sendBundleWithJitoMultiIps(mainTxHash, mainTxBase64, tipTxBase64)
|
|
45
53
|
} else {
|
|
46
54
|
return await sendBundleWithJito(mainTxBase64, tipTxBase64)
|
|
@@ -53,7 +61,7 @@ export class TransactionSender {
|
|
|
53
61
|
/**
|
|
54
62
|
* 序列化交易为 base64 字符串
|
|
55
63
|
*/
|
|
56
|
-
|
|
64
|
+
function serializeTransactionBase64(tx: Transaction | VersionedTransaction): string {
|
|
57
65
|
let buffer:Buffer
|
|
58
66
|
if (tx instanceof VersionedTransaction) {
|
|
59
67
|
buffer = Buffer.from(tx.serialize())
|
|
@@ -64,3 +72,11 @@ export function serializeTransactionBase64(tx: Transaction | VersionedTransactio
|
|
|
64
72
|
}
|
|
65
73
|
return buffer.toString('base64')
|
|
66
74
|
}
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
// 缓存交易的gas支出
|
|
78
|
+
function set_transaciton_gas_cost(txid:string, context:TradeContext) {
|
|
79
|
+
const {sol_priority_fee, sol_tip_fee} = context.trade_runtime.settings.strategy
|
|
80
|
+
set_sol_gas_fee(txid, {base_fee: 5000, priority_fee: sol_priority_fee + sol_tip_fee, total_fee: 5000 + sol_priority_fee + sol_tip_fee})
|
|
81
|
+
}
|
|
82
|
+
|