@haven-fi/solauto-sdk 1.0.338 → 1.0.340
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/dist/transactions/transactionsManager.d.ts.map +1 -1
- package/dist/transactions/transactionsManager.js +7 -2
- package/dist/utils/jitoUtils.d.ts.map +1 -1
- package/dist/utils/jitoUtils.js +2 -1
- package/package.json +1 -1
- package/src/transactions/transactionsManager.ts +13 -2
- package/src/utils/jitoUtils.ts +3 -2
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"transactionsManager.d.ts","sourceRoot":"","sources":["../../src/transactions/transactionsManager.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,kBAAkB,EAEnB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAMzD,OAAO,EACL,aAAa,EAEd,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,kBAAkB,EAElB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,oBAAoB,EAAa,MAAM,YAAY,CAAC;AAW7D,qBAAa,wBAAyB,SAAQ,KAAK;gBACrC,OAAO,EAAE,MAAM;CAK5B;AAqCD,qBAAa,eAAe;IAMjB,OAAO,EAAE,CACd,UAAU,EAAE,MAAM,KACf,OAAO,CAAC,qBAAqB,GAAG,SAAS,CAAC;IACxC,IAAI,CAAC,EAAE,MAAM;IARtB,oBAAoB,EAAG,MAAM,EAAE,CAAC;IAChC,EAAE,CAAC,EAAE,kBAAkB,CAAC;IACjB,WAAW,EAAE,OAAO,CAAS;gBAG3B,OAAO,EAAE,CACd,UAAU,EAAE,MAAM,KACf,OAAO,CAAC,qBAAqB,GAAG,SAAS,CAAC,EACxC,IAAI,CAAC,EAAE,MAAM,YAAA;IAGhB,UAAU;IAKV,OAAO,CAAC,UAAU,EAAE,MAAM;IAMhC,cAAc,IAAI,MAAM,EAAE;CAY3B;AA0FD,oBAAY,iBAAiB;IAC3B,OAAO,YAAY;IACnB,UAAU,eAAe;IACzB,MAAM,WAAW;IACjB,UAAU,eAAe;IACzB,MAAM,WAAW;CAClB;AAED,MAAM,MAAM,0BAA0B,GAAG;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,iBAAiB,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,EAAE,CAAC;AAEJ,qBAAa,mBAAmB;IAK5B,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,cAAc,CAAC;IACvB,OAAO,CAAC,MAAM,CAAC;IACf,OAAO,CAAC,kBAAkB;IAC1B,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,aAAa,CAAC;IACtB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,UAAU;IAXpB,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,YAAY,CAAe;gBAGzB,SAAS,EAAE,aAAa,GAAG,oBAAoB,EAC/C,cAAc,CAAC,GAAE,CAAC,QAAQ,EAAE,0BAA0B,KAAK,IAAI,aAAA,EAC/D,MAAM,CAAC,EAAE,kBAAkB,YAAA,EAC3B,kBAAkB,GAAE,kBAA2C,EAC/D,UAAU,GAAE,OAAe,EAC3B,aAAa,CAAC,EAAE,aAAa,YAAA,EAC7B,OAAO,GAAE,MAAU,EACnB,UAAU,GAAE,MAAY;YAQpB,uBAAuB;IAwCrC,OAAO,CAAC,YAAY;YA6CN,aAAa;IAoB3B,OAAO,CAAC,4BAA4B;IAgBpC,OAAO,CAAC,mBAAmB;YAoBb,SAAS;IAgBV,UAAU,CACrB,YAAY,EAAE,eAAe,EAAE,GAC9B,OAAO,CAAC,0BAA0B,CAAC;IA4FzB,IAAI,CACf,KAAK,EAAE,eAAe,EAAE,GACvB,OAAO,CAAC,0BAA0B,CAAC;YAmCxB,6BAA6B;
|
1
|
+
{"version":3,"file":"transactionsManager.d.ts","sourceRoot":"","sources":["../../src/transactions/transactionsManager.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,kBAAkB,EAEnB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAMzD,OAAO,EACL,aAAa,EAEd,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,kBAAkB,EAElB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,oBAAoB,EAAa,MAAM,YAAY,CAAC;AAW7D,qBAAa,wBAAyB,SAAQ,KAAK;gBACrC,OAAO,EAAE,MAAM;CAK5B;AAqCD,qBAAa,eAAe;IAMjB,OAAO,EAAE,CACd,UAAU,EAAE,MAAM,KACf,OAAO,CAAC,qBAAqB,GAAG,SAAS,CAAC;IACxC,IAAI,CAAC,EAAE,MAAM;IARtB,oBAAoB,EAAG,MAAM,EAAE,CAAC;IAChC,EAAE,CAAC,EAAE,kBAAkB,CAAC;IACjB,WAAW,EAAE,OAAO,CAAS;gBAG3B,OAAO,EAAE,CACd,UAAU,EAAE,MAAM,KACf,OAAO,CAAC,qBAAqB,GAAG,SAAS,CAAC,EACxC,IAAI,CAAC,EAAE,MAAM,YAAA;IAGhB,UAAU;IAKV,OAAO,CAAC,UAAU,EAAE,MAAM;IAMhC,cAAc,IAAI,MAAM,EAAE;CAY3B;AA0FD,oBAAY,iBAAiB;IAC3B,OAAO,YAAY;IACnB,UAAU,eAAe;IACzB,MAAM,WAAW;IACjB,UAAU,eAAe;IACzB,MAAM,WAAW;CAClB;AAED,MAAM,MAAM,0BAA0B,GAAG;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,iBAAiB,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,EAAE,CAAC;AAEJ,qBAAa,mBAAmB;IAK5B,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,cAAc,CAAC;IACvB,OAAO,CAAC,MAAM,CAAC;IACf,OAAO,CAAC,kBAAkB;IAC1B,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,aAAa,CAAC;IACtB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,UAAU;IAXpB,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,YAAY,CAAe;gBAGzB,SAAS,EAAE,aAAa,GAAG,oBAAoB,EAC/C,cAAc,CAAC,GAAE,CAAC,QAAQ,EAAE,0BAA0B,KAAK,IAAI,aAAA,EAC/D,MAAM,CAAC,EAAE,kBAAkB,YAAA,EAC3B,kBAAkB,GAAE,kBAA2C,EAC/D,UAAU,GAAE,OAAe,EAC3B,aAAa,CAAC,EAAE,aAAa,YAAA,EAC7B,OAAO,GAAE,MAAU,EACnB,UAAU,GAAE,MAAY;YAQpB,uBAAuB;IAwCrC,OAAO,CAAC,YAAY;YA6CN,aAAa;IAoB3B,OAAO,CAAC,4BAA4B;IAgBpC,OAAO,CAAC,mBAAmB;YAoBb,SAAS;IAgBV,UAAU,CACrB,YAAY,EAAE,eAAe,EAAE,GAC9B,OAAO,CAAC,0BAA0B,CAAC;IA4FzB,IAAI,CACf,KAAK,EAAE,eAAe,EAAE,GACvB,OAAO,CAAC,0BAA0B,CAAC;YAmCxB,6BAA6B;YAwF7B,qBAAqB;YAuDrB,cAAc;YAqCd,eAAe;CAmD9B"}
|
@@ -336,7 +336,7 @@ class TransactionsManager {
|
|
336
336
|
}
|
337
337
|
async processTransactionsAtomically(itemSets) {
|
338
338
|
let num = 0;
|
339
|
-
await (0, generalUtils_1.retryWithExponentialBackoff)(async (attemptNum) => {
|
339
|
+
await (0, generalUtils_1.retryWithExponentialBackoff)(async (attemptNum, prevError) => {
|
340
340
|
num = attemptNum;
|
341
341
|
if (attemptNum > 0) {
|
342
342
|
for (let i = 0; i < itemSets.length; i++) {
|
@@ -348,11 +348,16 @@ class TransactionsManager {
|
|
348
348
|
for (const set of itemSets) {
|
349
349
|
transactions.push(await set.getSingleTransaction());
|
350
350
|
}
|
351
|
+
transactions = transactions.filter((x) => x.getInstructions().length > 0);
|
352
|
+
if (transactions.length === 0) {
|
353
|
+
this.updateStatusForSets(itemSets, TransactionStatus.Skipped, attemptNum);
|
354
|
+
return;
|
355
|
+
}
|
351
356
|
this.updateStatusForSets(itemSets, TransactionStatus.Processing, attemptNum);
|
352
357
|
let txSigs;
|
353
358
|
let error;
|
354
359
|
try {
|
355
|
-
txSigs = await (0, jitoUtils_1.sendJitoBundledTransactions)(this.txHandler.umi, this.txHandler.connection, this.txHandler.signer, transactions, this.txType, this.
|
360
|
+
txSigs = await (0, jitoUtils_1.sendJitoBundledTransactions)(this.txHandler.umi, this.txHandler.connection, this.txHandler.signer, transactions, this.txType, this.getUpdatedPriorityFeeSetting(prevError, attemptNum));
|
356
361
|
}
|
357
362
|
catch (e) {
|
358
363
|
error = e;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"jitoUtils.d.ts","sourceRoot":"","sources":["../../src/utils/jitoUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,
|
1
|
+
{"version":3,"file":"jitoUtils.d.ts","sourceRoot":"","sources":["../../src/utils/jitoUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAoE,MAAM,iBAAiB,CAAC;AAG1H,OAAO,EACL,MAAM,EACN,kBAAkB,EAClB,GAAG,EAEJ,MAAM,0BAA0B,CAAC;AASlC,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAKlE,wBAAsB,mBAAmB,IAAI,OAAO,CAAC,SAAS,CAAC,CAa9D;AAyHD,wBAAsB,2BAA2B,CAC/C,GAAG,EAAE,GAAG,EACR,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,kBAAkB,EAAE,EACzB,MAAM,CAAC,EAAE,kBAAkB,EAC3B,kBAAkB,GAAE,kBAA2C,GAC9D,OAAO,CAAC,MAAM,EAAE,GAAG,SAAS,CAAC,CAyD/B"}
|
package/dist/utils/jitoUtils.js
CHANGED
@@ -77,13 +77,14 @@ async function pollBundleStatus(bundleId, interval = 1000, timeout = 40000) {
|
|
77
77
|
await new Promise((resolve) => setTimeout(resolve, interval));
|
78
78
|
const statuses = await getBundleStatus(bundleId);
|
79
79
|
if (statuses?.value?.length > 0) {
|
80
|
+
(0, generalUtils_1.consoleLog)("Statuses:", statuses);
|
80
81
|
const status = statuses.value[0].confirmation_status;
|
81
82
|
if (status === "confirmed") {
|
82
83
|
return statuses?.value[0].transactions;
|
83
84
|
}
|
84
85
|
}
|
85
86
|
}
|
86
|
-
|
87
|
+
throw new web3_js_1.TransactionExpiredBlockheightExceededError("Unable to confirm transaction. Try a higher priority fee.");
|
87
88
|
}
|
88
89
|
async function sendJitoBundle(transactions) {
|
89
90
|
let resp;
|
package/package.json
CHANGED
@@ -530,7 +530,7 @@ export class TransactionsManager {
|
|
530
530
|
let num = 0;
|
531
531
|
|
532
532
|
await retryWithExponentialBackoff(
|
533
|
-
async (attemptNum) => {
|
533
|
+
async (attemptNum, prevError) => {
|
534
534
|
num = attemptNum;
|
535
535
|
|
536
536
|
if (attemptNum > 0) {
|
@@ -546,6 +546,17 @@ export class TransactionsManager {
|
|
546
546
|
for (const set of itemSets) {
|
547
547
|
transactions.push(await set.getSingleTransaction());
|
548
548
|
}
|
549
|
+
transactions = transactions.filter(
|
550
|
+
(x) => x.getInstructions().length > 0
|
551
|
+
);
|
552
|
+
if (transactions.length === 0) {
|
553
|
+
this.updateStatusForSets(
|
554
|
+
itemSets,
|
555
|
+
TransactionStatus.Skipped,
|
556
|
+
attemptNum
|
557
|
+
);
|
558
|
+
return;
|
559
|
+
}
|
549
560
|
|
550
561
|
this.updateStatusForSets(
|
551
562
|
itemSets,
|
@@ -562,7 +573,7 @@ export class TransactionsManager {
|
|
562
573
|
this.txHandler.signer,
|
563
574
|
transactions,
|
564
575
|
this.txType,
|
565
|
-
this.
|
576
|
+
this.getUpdatedPriorityFeeSetting(prevError, attemptNum)
|
566
577
|
);
|
567
578
|
} catch (e: any) {
|
568
579
|
error = e as Error;
|
package/src/utils/jitoUtils.ts
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
import { Connection, PublicKey, VersionedTransaction } from "@solana/web3.js";
|
1
|
+
import { Connection, PublicKey, TransactionExpiredBlockheightExceededError, VersionedTransaction } from "@solana/web3.js";
|
2
2
|
import { toWeb3JsTransaction } from "@metaplex-foundation/umi-web3js-adapters";
|
3
3
|
import { JITO_BLOCK_ENGINE } from "../constants/solautoConstants";
|
4
4
|
import {
|
@@ -118,13 +118,14 @@ async function pollBundleStatus(
|
|
118
118
|
await new Promise((resolve) => setTimeout(resolve, interval));
|
119
119
|
const statuses = await getBundleStatus(bundleId);
|
120
120
|
if (statuses?.value?.length > 0) {
|
121
|
+
consoleLog("Statuses:", statuses);
|
121
122
|
const status = statuses.value[0].confirmation_status;
|
122
123
|
if (status === "confirmed") {
|
123
124
|
return statuses?.value[0].transactions as string[];
|
124
125
|
}
|
125
126
|
}
|
126
127
|
}
|
127
|
-
|
128
|
+
throw new TransactionExpiredBlockheightExceededError("Unable to confirm transaction. Try a higher priority fee.");
|
128
129
|
}
|
129
130
|
|
130
131
|
async function sendJitoBundle(transactions: string[]): Promise<string[]> {
|