@lifi/sdk 4.0.0-alpha.14 → 4.0.0-alpha.17
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/cjs/core/BaseStepExecutionTask.d.ts +5 -0
- package/dist/cjs/core/BaseStepExecutionTask.js +10 -0
- package/dist/cjs/core/BaseStepExecutionTask.js.map +1 -0
- package/dist/cjs/core/BaseStepExecutor.d.ts +7 -3
- package/dist/cjs/core/BaseStepExecutor.js +24 -0
- package/dist/cjs/core/BaseStepExecutor.js.map +1 -1
- package/dist/cjs/core/StatusManager.d.ts +12 -10
- package/dist/cjs/core/StatusManager.js +25 -33
- package/dist/cjs/core/StatusManager.js.map +1 -1
- package/dist/cjs/core/TaskPipeline.d.ts +7 -0
- package/dist/cjs/core/TaskPipeline.js +46 -0
- package/dist/cjs/core/TaskPipeline.js.map +1 -0
- package/dist/cjs/core/actionMessages.js +19 -3
- package/dist/cjs/core/actionMessages.js.map +1 -1
- package/dist/cjs/core/execution.js +13 -1
- package/dist/cjs/core/execution.js.map +1 -1
- package/dist/cjs/core/prepareRestart.js +3 -3
- package/dist/cjs/core/prepareRestart.js.map +1 -1
- package/dist/cjs/core/tasks/CheckBalanceTask.d.ts +5 -0
- package/dist/cjs/core/tasks/CheckBalanceTask.js +26 -0
- package/dist/cjs/core/tasks/CheckBalanceTask.js.map +1 -0
- package/dist/cjs/core/tasks/PrepareTransactionTask.d.ts +5 -0
- package/dist/cjs/core/tasks/PrepareTransactionTask.js +36 -0
- package/dist/cjs/core/tasks/PrepareTransactionTask.js.map +1 -0
- package/dist/cjs/core/tasks/WaitForTransactionStatusTask.d.ts +8 -0
- package/dist/cjs/core/tasks/WaitForTransactionStatusTask.js +73 -0
- package/dist/cjs/core/tasks/WaitForTransactionStatusTask.js.map +1 -0
- package/dist/cjs/core/{checkBalance.d.ts → tasks/helpers/checkBalance.d.ts} +1 -1
- package/dist/cjs/core/{checkBalance.js → tasks/helpers/checkBalance.js} +4 -4
- package/dist/cjs/core/tasks/helpers/checkBalance.js.map +1 -0
- package/dist/cjs/core/tasks/helpers/getTransactionRequestData.d.ts +2 -0
- package/dist/cjs/core/tasks/helpers/getTransactionRequestData.js +30 -0
- package/dist/cjs/core/tasks/helpers/getTransactionRequestData.js.map +1 -0
- package/dist/cjs/core/{stepComparison.d.ts → tasks/helpers/stepComparison.d.ts} +2 -2
- package/dist/cjs/core/{stepComparison.js → tasks/helpers/stepComparison.js} +3 -3
- package/dist/cjs/core/tasks/helpers/stepComparison.js.map +1 -0
- package/dist/cjs/core/{waitForTransactionStatus.d.ts → tasks/helpers/waitForTransactionStatus.d.ts} +2 -2
- package/dist/cjs/core/{waitForTransactionStatus.js → tasks/helpers/waitForTransactionStatus.js} +8 -6
- package/dist/cjs/core/tasks/helpers/waitForTransactionStatus.js.map +1 -0
- package/dist/cjs/errors/constants.d.ts +2 -1
- package/dist/cjs/errors/constants.js +1 -0
- package/dist/cjs/errors/constants.js.map +1 -1
- package/dist/cjs/errors/errors.d.ts +5 -0
- package/dist/cjs/errors/errors.js +9 -1
- package/dist/cjs/errors/errors.js.map +1 -1
- package/dist/cjs/index.d.ts +12 -5
- package/dist/cjs/index.js +21 -7
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/types/core.d.ts +12 -10
- package/dist/cjs/types/execution.d.ts +25 -0
- package/dist/cjs/types/execution.js +3 -0
- package/dist/cjs/types/execution.js.map +1 -0
- package/dist/cjs/utils/waitForResult.d.ts +1 -1
- package/dist/cjs/utils/waitForResult.js +2 -6
- package/dist/cjs/utils/waitForResult.js.map +1 -1
- package/dist/cjs/version.d.ts +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/esm/core/BaseStepExecutionTask.d.ts +5 -0
- package/dist/esm/core/BaseStepExecutionTask.js +6 -0
- package/dist/esm/core/BaseStepExecutionTask.js.map +1 -0
- package/dist/esm/core/BaseStepExecutor.d.ts +7 -3
- package/dist/esm/core/BaseStepExecutor.js +24 -0
- package/dist/esm/core/BaseStepExecutor.js.map +1 -1
- package/dist/esm/core/StatusManager.d.ts +29 -27
- package/dist/esm/core/StatusManager.js +42 -50
- package/dist/esm/core/StatusManager.js.map +1 -1
- package/dist/esm/core/TaskPipeline.d.ts +7 -0
- package/dist/esm/core/TaskPipeline.js +42 -0
- package/dist/esm/core/TaskPipeline.js.map +1 -0
- package/dist/esm/core/actionMessages.js +19 -3
- package/dist/esm/core/actionMessages.js.map +1 -1
- package/dist/esm/core/execution.js +14 -3
- package/dist/esm/core/execution.js.map +1 -1
- package/dist/esm/core/prepareRestart.js +4 -3
- package/dist/esm/core/prepareRestart.js.map +1 -1
- package/dist/esm/core/tasks/CheckBalanceTask.d.ts +5 -0
- package/dist/esm/core/tasks/CheckBalanceTask.js +22 -0
- package/dist/esm/core/tasks/CheckBalanceTask.js.map +1 -0
- package/dist/esm/core/tasks/PrepareTransactionTask.d.ts +5 -0
- package/dist/esm/core/tasks/PrepareTransactionTask.js +32 -0
- package/dist/esm/core/tasks/PrepareTransactionTask.js.map +1 -0
- package/dist/esm/core/tasks/WaitForTransactionStatusTask.d.ts +8 -0
- package/dist/esm/core/tasks/WaitForTransactionStatusTask.js +74 -0
- package/dist/esm/core/tasks/WaitForTransactionStatusTask.js.map +1 -0
- package/dist/esm/core/{checkBalance.d.ts → tasks/helpers/checkBalance.d.ts} +1 -1
- package/dist/esm/core/{checkBalance.js → tasks/helpers/checkBalance.js} +4 -4
- package/dist/esm/core/tasks/helpers/checkBalance.js.map +1 -0
- package/dist/esm/core/tasks/helpers/getTransactionRequestData.d.ts +2 -0
- package/dist/esm/core/tasks/helpers/getTransactionRequestData.js +26 -0
- package/dist/esm/core/tasks/helpers/getTransactionRequestData.js.map +1 -0
- package/dist/esm/core/{stepComparison.d.ts → tasks/helpers/stepComparison.d.ts} +2 -2
- package/dist/esm/core/{stepComparison.js → tasks/helpers/stepComparison.js} +3 -3
- package/dist/esm/core/tasks/helpers/stepComparison.js.map +1 -0
- package/dist/esm/core/{waitForTransactionStatus.d.ts → tasks/helpers/waitForTransactionStatus.d.ts} +2 -2
- package/dist/esm/core/{waitForTransactionStatus.js → tasks/helpers/waitForTransactionStatus.js} +8 -6
- package/dist/esm/core/tasks/helpers/waitForTransactionStatus.js.map +1 -0
- package/dist/esm/errors/constants.d.ts +2 -1
- package/dist/esm/errors/constants.js +1 -0
- package/dist/esm/errors/constants.js.map +1 -1
- package/dist/esm/errors/errors.d.ts +10 -0
- package/dist/esm/errors/errors.js +12 -0
- package/dist/esm/errors/errors.js.map +1 -1
- package/dist/esm/index.d.ts +12 -5
- package/dist/esm/index.js +10 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types/core.d.ts +16 -10
- package/dist/esm/types/execution.d.ts +26 -0
- package/dist/esm/types/execution.js +2 -0
- package/dist/esm/types/execution.js.map +1 -0
- package/dist/esm/utils/waitForResult.d.ts +2 -2
- package/dist/esm/utils/waitForResult.js +3 -7
- package/dist/esm/utils/waitForResult.js.map +1 -1
- package/dist/esm/version.d.ts +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/types/core/BaseStepExecutionTask.d.ts +6 -0
- package/dist/types/core/BaseStepExecutionTask.d.ts.map +1 -0
- package/dist/types/core/BaseStepExecutor.d.ts +7 -3
- package/dist/types/core/BaseStepExecutor.d.ts.map +1 -1
- package/dist/types/core/StatusManager.d.ts +29 -27
- package/dist/types/core/StatusManager.d.ts.map +1 -1
- package/dist/types/core/TaskPipeline.d.ts +8 -0
- package/dist/types/core/TaskPipeline.d.ts.map +1 -0
- package/dist/types/core/actionMessages.d.ts.map +1 -1
- package/dist/types/core/execution.d.ts.map +1 -1
- package/dist/types/core/prepareRestart.d.ts.map +1 -1
- package/dist/types/core/tasks/CheckBalanceTask.d.ts +6 -0
- package/dist/types/core/tasks/CheckBalanceTask.d.ts.map +1 -0
- package/dist/types/core/tasks/PrepareTransactionTask.d.ts +6 -0
- package/dist/types/core/tasks/PrepareTransactionTask.d.ts.map +1 -0
- package/dist/types/core/tasks/WaitForTransactionStatusTask.d.ts +9 -0
- package/dist/types/core/tasks/WaitForTransactionStatusTask.d.ts.map +1 -0
- package/dist/types/core/{checkBalance.d.ts → tasks/helpers/checkBalance.d.ts} +1 -1
- package/dist/types/core/tasks/helpers/checkBalance.d.ts.map +1 -0
- package/dist/types/core/tasks/helpers/getTransactionRequestData.d.ts +3 -0
- package/dist/types/core/tasks/helpers/getTransactionRequestData.d.ts.map +1 -0
- package/dist/types/core/{stepComparison.d.ts → tasks/helpers/stepComparison.d.ts} +2 -2
- package/dist/types/core/tasks/helpers/stepComparison.d.ts.map +1 -0
- package/dist/types/core/{waitForTransactionStatus.d.ts → tasks/helpers/waitForTransactionStatus.d.ts} +2 -2
- package/dist/types/core/tasks/helpers/waitForTransactionStatus.d.ts.map +1 -0
- package/dist/types/errors/constants.d.ts +2 -1
- package/dist/types/errors/constants.d.ts.map +1 -1
- package/dist/types/errors/errors.d.ts +10 -0
- package/dist/types/errors/errors.d.ts.map +1 -1
- package/dist/types/index.d.ts +12 -5
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/types/core.d.ts +16 -10
- package/dist/types/types/core.d.ts.map +1 -1
- package/dist/types/types/execution.d.ts +27 -0
- package/dist/types/types/execution.d.ts.map +1 -0
- package/dist/types/utils/waitForResult.d.ts +2 -2
- package/dist/types/utils/waitForResult.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/package.json +1 -1
- package/src/core/BaseStepExecutionTask.ts +9 -0
- package/src/core/BaseStepExecutor.ts +52 -2
- package/src/core/StatusManager.ts +56 -61
- package/src/core/TaskPipeline.ts +47 -0
- package/src/core/actionMessages.ts +20 -3
- package/src/core/execution.ts +17 -3
- package/src/core/prepareRestart.ts +4 -3
- package/src/core/tasks/CheckBalanceTask.ts +29 -0
- package/src/core/tasks/PrepareTransactionTask.ts +62 -0
- package/src/core/tasks/WaitForTransactionStatusTask.ts +114 -0
- package/src/core/{checkBalance.ts → tasks/helpers/checkBalance.ts} +5 -5
- package/src/core/tasks/helpers/getTransactionRequestData.ts +47 -0
- package/src/core/{stepComparison.ts → tasks/helpers/stepComparison.ts} +5 -5
- package/src/core/{waitForTransactionStatus.ts → tasks/helpers/waitForTransactionStatus.ts} +10 -8
- package/src/errors/constants.ts +1 -0
- package/src/errors/errors.ts +24 -0
- package/src/index.ts +17 -3
- package/src/types/core.ts +19 -18
- package/src/types/execution.ts +40 -0
- package/src/utils/waitForResult.ts +4 -9
- package/src/version.ts +1 -1
- package/dist/cjs/core/checkBalance.js.map +0 -1
- package/dist/cjs/core/stepComparison.js.map +0 -1
- package/dist/cjs/core/waitForDestinationChainTransaction.d.ts +0 -4
- package/dist/cjs/core/waitForDestinationChainTransaction.js +0 -68
- package/dist/cjs/core/waitForDestinationChainTransaction.js.map +0 -1
- package/dist/cjs/core/waitForTransactionStatus.js.map +0 -1
- package/dist/esm/core/checkBalance.js.map +0 -1
- package/dist/esm/core/stepComparison.js.map +0 -1
- package/dist/esm/core/waitForDestinationChainTransaction.d.ts +0 -4
- package/dist/esm/core/waitForDestinationChainTransaction.js +0 -70
- package/dist/esm/core/waitForDestinationChainTransaction.js.map +0 -1
- package/dist/esm/core/waitForTransactionStatus.js.map +0 -1
- package/dist/types/core/checkBalance.d.ts.map +0 -1
- package/dist/types/core/stepComparison.d.ts.map +0 -1
- package/dist/types/core/waitForDestinationChainTransaction.d.ts +0 -5
- package/dist/types/core/waitForDestinationChainTransaction.d.ts.map +0 -1
- package/dist/types/core/waitForTransactionStatus.d.ts.map +0 -1
- package/src/core/waitForDestinationChainTransaction.ts +0 -108
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BaseStepExecutionTask = void 0;
|
|
4
|
+
class BaseStepExecutionTask {
|
|
5
|
+
shouldRun(_context) {
|
|
6
|
+
return Promise.resolve(true);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.BaseStepExecutionTask = BaseStepExecutionTask;
|
|
10
|
+
//# sourceMappingURL=BaseStepExecutionTask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BaseStepExecutionTask.js","sourceRoot":"","sources":["../../../src/core/BaseStepExecutionTask.ts"],"names":[],"mappings":";;;AAEA,MAAsB,qBAAqB;IACzC,SAAS,CAAC,QAA6B;QACrC,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAC9B,CAAC;CAGF;AAND,sDAMC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import type {
|
|
1
|
+
import type { ExecuteStepRetryParams, ExecutionOptions, InteractionSettings, LiFiStepExtended, SDKClient, StepExecutor, StepExecutorOptions } from '../types/core.js';
|
|
2
|
+
import type { StepExecutorBaseContext, StepExecutorContext } from '../types/execution.js';
|
|
3
3
|
import { StatusManager } from './StatusManager.js';
|
|
4
|
+
import type { TaskPipeline } from './TaskPipeline.js';
|
|
4
5
|
export declare abstract class BaseStepExecutor implements StepExecutor {
|
|
5
6
|
protected executionOptions?: ExecutionOptions;
|
|
6
7
|
protected statusManager: StatusManager;
|
|
@@ -8,5 +9,8 @@ export declare abstract class BaseStepExecutor implements StepExecutor {
|
|
|
8
9
|
allowExecution: boolean;
|
|
9
10
|
constructor(options: StepExecutorOptions);
|
|
10
11
|
setInteraction: (settings?: InteractionSettings) => void;
|
|
11
|
-
|
|
12
|
+
private createBaseContext;
|
|
13
|
+
abstract createContext(baseContext: StepExecutorBaseContext): Promise<StepExecutorContext>;
|
|
14
|
+
abstract createPipeline(context: StepExecutorContext): TaskPipeline;
|
|
15
|
+
executeStep: (client: SDKClient, step: LiFiStepExtended, retryParams?: ExecuteStepRetryParams) => Promise<LiFiStepExtended>;
|
|
12
16
|
}
|
|
@@ -25,6 +25,30 @@ class BaseStepExecutor {
|
|
|
25
25
|
this.statusManager.allowUpdates(interactionSettings.allowUpdates);
|
|
26
26
|
this.allowExecution = interactionSettings.allowExecution;
|
|
27
27
|
};
|
|
28
|
+
createBaseContext = async (client, step, retryParams) => {
|
|
29
|
+
const fromChain = await client.getChainById(step.action.fromChainId);
|
|
30
|
+
const toChain = await client.getChainById(step.action.toChainId);
|
|
31
|
+
const isBridgeExecution = fromChain.id !== toChain.id;
|
|
32
|
+
return {
|
|
33
|
+
client,
|
|
34
|
+
step,
|
|
35
|
+
fromChain,
|
|
36
|
+
toChain,
|
|
37
|
+
isBridgeExecution,
|
|
38
|
+
retryParams,
|
|
39
|
+
statusManager: this.statusManager,
|
|
40
|
+
executionOptions: this.executionOptions,
|
|
41
|
+
allowUserInteraction: this.allowUserInteraction,
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
executeStep = async (client, step, retryParams) => {
|
|
45
|
+
step.execution = this.statusManager.initializeExecution(step);
|
|
46
|
+
const baseContext = await this.createBaseContext(client, step, retryParams);
|
|
47
|
+
const context = await this.createContext(baseContext);
|
|
48
|
+
const pipeline = this.createPipeline(context);
|
|
49
|
+
await pipeline.run(context);
|
|
50
|
+
return step;
|
|
51
|
+
};
|
|
28
52
|
}
|
|
29
53
|
exports.BaseStepExecutor = BaseStepExecutor;
|
|
30
54
|
//# sourceMappingURL=BaseStepExecutor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseStepExecutor.js","sourceRoot":"","sources":["../../../src/core/BaseStepExecutor.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"BaseStepExecutor.js","sourceRoot":"","sources":["../../../src/core/BaseStepExecutor.ts"],"names":[],"mappings":";;;AAaA,yDAAkD;AAIlD,MAAM,0BAA0B,GAAG;IACjC,gBAAgB,EAAE,IAAI;IACtB,YAAY,EAAE,IAAI;IAClB,cAAc,EAAE,IAAI;CACrB,CAAA;AAED,MAAsB,gBAAgB;IAC1B,gBAAgB,CAAmB;IACnC,aAAa,CAAe;IAE/B,oBAAoB,GAAG,IAAI,CAAA;IAC3B,cAAc,GAAG,IAAI,CAAA;IAE5B,YAAY,OAA4B;QACtC,IAAI,CAAC,aAAa,GAAG,IAAI,gCAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;QACvD,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAA;IAClD,CAAC;IAED,cAAc,GAAG,CAAC,QAA8B,EAAQ,EAAE;QACxD,MAAM,mBAAmB,GAAG;YAC1B,GAAG,0BAA0B;YAC7B,GAAG,QAAQ;SACZ,CAAA;QACD,IAAI,CAAC,oBAAoB,GAAG,mBAAmB,CAAC,gBAAgB,CAAA;QAChE,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAA;QACjE,IAAI,CAAC,cAAc,GAAG,mBAAmB,CAAC,cAAc,CAAA;IAC1D,CAAC,CAAA;IAEO,iBAAiB,GAAG,KAAK,EAC/B,MAAiB,EACjB,IAAsB,EACtB,WAAoC,EACF,EAAE;QACpC,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;QACpE,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;QAEhE,MAAM,iBAAiB,GAAG,SAAS,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAA;QAErD,OAAO;YACL,MAAM;YACN,IAAI;YACJ,SAAS;YACT,OAAO;YACP,iBAAiB;YACjB,WAAW;YACX,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;SAChD,CAAA;IACH,CAAC,CAAA;IAQD,WAAW,GAAG,KAAK,EACjB,MAAiB,EACjB,IAAsB,EACtB,WAAoC,EACT,EAAE;QAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAA;QAE7D,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,CAAC,CAAA;QAC3E,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAA;QAErD,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAA;QAE7C,MAAM,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAE3B,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;CACF;AAnED,4CAmEC"}
|
|
@@ -1,21 +1,23 @@
|
|
|
1
1
|
import type { ChainId, LiFiStep } from '@lifi/types';
|
|
2
|
-
import type { Execution, ExecutionAction, ExecutionActionStatus, ExecutionActionType,
|
|
3
|
-
type
|
|
2
|
+
import type { Execution, ExecutionAction, ExecutionActionStatus, ExecutionActionType, LiFiStepExtended } from '../types/core.js';
|
|
3
|
+
type ActionProps = {
|
|
4
4
|
step: LiFiStepExtended;
|
|
5
5
|
type: ExecutionActionType;
|
|
6
|
-
chainId
|
|
7
|
-
status
|
|
6
|
+
chainId: ChainId;
|
|
7
|
+
status: ExecutionActionStatus;
|
|
8
8
|
};
|
|
9
9
|
export declare class StatusManager {
|
|
10
10
|
private readonly routeId;
|
|
11
11
|
private shouldUpdate;
|
|
12
12
|
constructor(routeId: string);
|
|
13
|
-
|
|
14
|
-
updateExecution(step: LiFiStepExtended,
|
|
15
|
-
findAction(step: LiFiStepExtended, type: ExecutionActionType
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
13
|
+
initializeExecution: (step: LiFiStepExtended) => Execution;
|
|
14
|
+
updateExecution(step: LiFiStepExtended, execution: Partial<Execution>): LiFiStep;
|
|
15
|
+
findAction(step: LiFiStepExtended, type: ExecutionActionType): ExecutionAction | undefined;
|
|
16
|
+
createAction: ({ step, type, chainId, status, }: ActionProps) => ExecutionAction;
|
|
17
|
+
initializeAction: ({ step, type, chainId, status, }: ActionProps) => ExecutionAction;
|
|
18
|
+
updateAction: (step: LiFiStepExtended, type: ExecutionActionType, status: ExecutionActionStatus, params?: Partial<ExecutionAction & {
|
|
19
|
+
signedAt?: number;
|
|
20
|
+
}>) => ExecutionAction;
|
|
19
21
|
updateStepInRoute: (step: LiFiStep) => LiFiStep;
|
|
20
22
|
allowUpdates(value: boolean): void;
|
|
21
23
|
}
|
|
@@ -9,7 +9,7 @@ class StatusManager {
|
|
|
9
9
|
constructor(routeId) {
|
|
10
10
|
this.routeId = routeId;
|
|
11
11
|
}
|
|
12
|
-
|
|
12
|
+
initializeExecution = (step) => {
|
|
13
13
|
if (!step.execution) {
|
|
14
14
|
step.execution = {
|
|
15
15
|
startedAt: Date.now(),
|
|
@@ -26,46 +26,46 @@ class StatusManager {
|
|
|
26
26
|
}
|
|
27
27
|
return step.execution;
|
|
28
28
|
};
|
|
29
|
-
updateExecution(step,
|
|
29
|
+
updateExecution(step, execution) {
|
|
30
30
|
if (!step.execution) {
|
|
31
31
|
throw Error("Can't update empty execution.");
|
|
32
32
|
}
|
|
33
|
-
step.execution
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
...execution,
|
|
38
|
-
};
|
|
39
|
-
}
|
|
33
|
+
step.execution = {
|
|
34
|
+
...step.execution,
|
|
35
|
+
...execution,
|
|
36
|
+
};
|
|
40
37
|
this.updateStepInRoute(step);
|
|
41
38
|
return step;
|
|
42
39
|
}
|
|
43
|
-
findAction(step, type
|
|
40
|
+
findAction(step, type) {
|
|
44
41
|
if (!step.execution?.actions) {
|
|
45
42
|
throw new Error("Execution hasn't been initialized.");
|
|
46
43
|
}
|
|
47
44
|
const action = step.execution.actions.find((p) => p.type === type);
|
|
48
|
-
if (action && status && action.status !== status) {
|
|
49
|
-
action.status = status;
|
|
50
|
-
this.updateStepInRoute(step);
|
|
51
|
-
}
|
|
52
45
|
return action;
|
|
53
46
|
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
return action;
|
|
47
|
+
createAction = ({ step, type, chainId, status, }) => {
|
|
48
|
+
if (!step.execution) {
|
|
49
|
+
throw new Error("Execution hasn't been initialized.");
|
|
58
50
|
}
|
|
59
51
|
const newAction = {
|
|
60
|
-
type
|
|
61
|
-
message: (0, actionMessages_js_1.getActionMessage)(type, status
|
|
62
|
-
status
|
|
63
|
-
chainId
|
|
52
|
+
type,
|
|
53
|
+
message: (0, actionMessages_js_1.getActionMessage)(type, status),
|
|
54
|
+
status,
|
|
55
|
+
chainId,
|
|
64
56
|
};
|
|
65
57
|
step.execution.actions.push(newAction);
|
|
58
|
+
step.execution.lastActionType = type;
|
|
66
59
|
this.updateStepInRoute(step);
|
|
67
60
|
return newAction;
|
|
68
61
|
};
|
|
62
|
+
initializeAction = ({ step, type, chainId, status, }) => {
|
|
63
|
+
const action = this.findAction(step, type);
|
|
64
|
+
if (action) {
|
|
65
|
+
return this.updateAction(step, type, status);
|
|
66
|
+
}
|
|
67
|
+
return this.createAction({ step, type, chainId, status });
|
|
68
|
+
};
|
|
69
69
|
updateAction = (step, type, status, params) => {
|
|
70
70
|
if (!step.execution) {
|
|
71
71
|
throw new Error("Can't update an empty step execution.");
|
|
@@ -96,12 +96,12 @@ class StatusManager {
|
|
|
96
96
|
default:
|
|
97
97
|
break;
|
|
98
98
|
}
|
|
99
|
+
step.execution.lastActionType = type;
|
|
99
100
|
currentAction.status = status;
|
|
100
101
|
currentAction.message = (0, actionMessages_js_1.getActionMessage)(type, status);
|
|
101
102
|
if (params) {
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
}
|
|
103
|
+
const { signedAt: _signedAt, ...rest } = params;
|
|
104
|
+
Object.assign(currentAction, rest);
|
|
105
105
|
}
|
|
106
106
|
step.execution.actions = [
|
|
107
107
|
...step.execution.actions.filter((action) => action.status === 'DONE'),
|
|
@@ -110,14 +110,6 @@ class StatusManager {
|
|
|
110
110
|
this.updateStepInRoute(step);
|
|
111
111
|
return currentAction;
|
|
112
112
|
};
|
|
113
|
-
removeAction = (step, type) => {
|
|
114
|
-
if (!step.execution) {
|
|
115
|
-
throw new Error("Execution hasn't been initialized.");
|
|
116
|
-
}
|
|
117
|
-
const index = step.execution.actions.findIndex((p) => p.type === type);
|
|
118
|
-
step.execution.actions.splice(index, 1);
|
|
119
|
-
this.updateStepInRoute(step);
|
|
120
|
-
};
|
|
121
113
|
updateStepInRoute = (step) => {
|
|
122
114
|
if (!this.shouldUpdate) {
|
|
123
115
|
return step;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StatusManager.js","sourceRoot":"","sources":["../../../src/core/StatusManager.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"StatusManager.js","sourceRoot":"","sources":["../../../src/core/StatusManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { StepExecutorContext, TaskResult } from '../types/execution.js';
|
|
2
|
+
import type { BaseStepExecutionTask } from './BaseStepExecutionTask.js';
|
|
3
|
+
export declare class TaskPipeline {
|
|
4
|
+
private readonly tasks;
|
|
5
|
+
constructor(tasks: BaseStepExecutionTask[]);
|
|
6
|
+
run(context: StepExecutorContext): Promise<TaskResult>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TaskPipeline = void 0;
|
|
4
|
+
const errors_js_1 = require("../errors/errors.js");
|
|
5
|
+
class TaskPipeline {
|
|
6
|
+
tasks;
|
|
7
|
+
constructor(tasks) {
|
|
8
|
+
this.tasks = tasks;
|
|
9
|
+
}
|
|
10
|
+
async run(context) {
|
|
11
|
+
const { statusManager, step, parseErrors } = context;
|
|
12
|
+
for (const task of this.tasks) {
|
|
13
|
+
try {
|
|
14
|
+
const shouldRun = await task.shouldRun(context);
|
|
15
|
+
if (!shouldRun) {
|
|
16
|
+
continue;
|
|
17
|
+
}
|
|
18
|
+
const result = await task.run(context);
|
|
19
|
+
if (result.status === 'PAUSED') {
|
|
20
|
+
return { status: 'PAUSED' };
|
|
21
|
+
}
|
|
22
|
+
if (result.context && typeof result.context === 'object') {
|
|
23
|
+
Object.assign(context, result.context);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
const action = step?.execution?.lastActionType
|
|
28
|
+
? statusManager.findAction(step, step?.execution?.lastActionType)
|
|
29
|
+
: undefined;
|
|
30
|
+
const parsed = await parseErrors(error, step, action);
|
|
31
|
+
if (!(parsed instanceof errors_js_1.ExecuteStepRetryError) && action) {
|
|
32
|
+
statusManager.updateAction(step, action.type, 'FAILED', {
|
|
33
|
+
error: {
|
|
34
|
+
message: parsed.cause?.message,
|
|
35
|
+
code: parsed.code,
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
throw parsed;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return { status: 'COMPLETED' };
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.TaskPipeline = TaskPipeline;
|
|
46
|
+
//# sourceMappingURL=TaskPipeline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TaskPipeline.js","sourceRoot":"","sources":["../../../src/core/TaskPipeline.ts"],"names":[],"mappings":";;;AAAA,mDAA2D;AAI3D,MAAa,YAAY;IACN,KAAK,CAAyB;IAE/C,YAAY,KAA8B;QACxC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,OAA4B;QACpC,MAAM,EAAE,aAAa,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,OAAO,CAAA;QAEpD,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC9B,IAAI,CAAC;gBACH,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;gBAC/C,IAAI,CAAC,SAAS,EAAE,CAAC;oBACf,SAAQ;gBACV,CAAC;gBACD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;gBACtC,IAAI,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;oBAC/B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAA;gBAC7B,CAAC;gBACD,IAAI,MAAM,CAAC,OAAO,IAAI,OAAO,MAAM,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;oBACzD,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAA;gBACxC,CAAC;YACH,CAAC;YAAC,OAAO,KAAU,EAAE,CAAC;gBACpB,MAAM,MAAM,GAAG,IAAI,EAAE,SAAS,EAAE,cAAc;oBAC5C,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,cAAc,CAAC;oBACjE,CAAC,CAAC,SAAS,CAAA;gBACb,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,CAAA;gBACrD,IAAI,CAAC,CAAC,MAAM,YAAY,iCAAqB,CAAC,IAAI,MAAM,EAAE,CAAC;oBACzD,aAAa,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE;wBACtD,KAAK,EAAE;4BACL,OAAO,EAAE,MAAM,CAAC,KAAK,EAAE,OAAO;4BAC9B,IAAI,EAAE,MAAM,CAAC,IAAI;yBAClB;qBACF,CAAC,CAAA;gBACJ,CAAC;gBACD,MAAM,MAAM,CAAA;YACd,CAAC;QACH,CAAC;QAED,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAA;IAChC,CAAC;CACF;AA1CD,oCA0CC"}
|
|
@@ -3,11 +3,20 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.getActionMessage = getActionMessage;
|
|
4
4
|
exports.getSubstatusMessage = getSubstatusMessage;
|
|
5
5
|
const actionMessages = {
|
|
6
|
-
|
|
6
|
+
CHECK_ALLOWANCE: {
|
|
7
|
+
STARTED: 'Checking token allowance',
|
|
8
|
+
PENDING: 'Waiting for token allowance check',
|
|
9
|
+
DONE: 'Token allowance checked',
|
|
10
|
+
},
|
|
11
|
+
RESET_ALLOWANCE: {
|
|
12
|
+
STARTED: 'Resetting token allowance',
|
|
13
|
+
RESET_REQUIRED: 'Resetting token allowance',
|
|
14
|
+
PENDING: 'Waiting for token allowance reset',
|
|
15
|
+
DONE: 'Token allowance reset',
|
|
16
|
+
},
|
|
17
|
+
SET_ALLOWANCE: {
|
|
7
18
|
STARTED: 'Setting token allowance',
|
|
8
19
|
ACTION_REQUIRED: 'Set token allowance',
|
|
9
|
-
RESET_REQUIRED: 'Resetting token allowance',
|
|
10
|
-
MESSAGE_REQUIRED: 'Sign token allowance message',
|
|
11
20
|
PENDING: 'Waiting for token allowance',
|
|
12
21
|
DONE: 'Token allowance set',
|
|
13
22
|
},
|
|
@@ -26,6 +35,7 @@ const actionMessages = {
|
|
|
26
35
|
DONE: 'Bridge transaction confirmed',
|
|
27
36
|
},
|
|
28
37
|
RECEIVING_CHAIN: {
|
|
38
|
+
STARTED: 'Waiting for destination chain',
|
|
29
39
|
PENDING: 'Waiting for destination chain',
|
|
30
40
|
DONE: 'Bridge completed',
|
|
31
41
|
},
|
|
@@ -35,6 +45,12 @@ const actionMessages = {
|
|
|
35
45
|
PENDING: 'Waiting for permit message',
|
|
36
46
|
DONE: 'Permit message signed',
|
|
37
47
|
},
|
|
48
|
+
NATIVE_PERMIT: {
|
|
49
|
+
STARTED: 'Preparing transaction',
|
|
50
|
+
ACTION_REQUIRED: 'Sign permit message',
|
|
51
|
+
PENDING: 'Waiting for permit message',
|
|
52
|
+
DONE: 'Permit message signed',
|
|
53
|
+
},
|
|
38
54
|
};
|
|
39
55
|
const substatusMessages = {
|
|
40
56
|
PENDING: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"actionMessages.js","sourceRoot":"","sources":["../../../src/core/actionMessages.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"actionMessages.js","sourceRoot":"","sources":["../../../src/core/actionMessages.ts"],"names":[],"mappings":";;AAqFA,4CAMC;AAED,kDASC;AAhGD,MAAM,cAAc,GAGhB;IACF,eAAe,EAAE;QACf,OAAO,EAAE,0BAA0B;QACnC,OAAO,EAAE,mCAAmC;QAC5C,IAAI,EAAE,yBAAyB;KAChC;IACD,eAAe,EAAE;QACf,OAAO,EAAE,2BAA2B;QACpC,cAAc,EAAE,2BAA2B;QAC3C,OAAO,EAAE,mCAAmC;QAC5C,IAAI,EAAE,uBAAuB;KAC9B;IACD,aAAa,EAAE;QACb,OAAO,EAAE,yBAAyB;QAClC,eAAe,EAAE,qBAAqB;QACtC,OAAO,EAAE,6BAA6B;QACtC,IAAI,EAAE,qBAAqB;KAC5B;IACD,IAAI,EAAE;QACJ,OAAO,EAAE,4BAA4B;QACrC,eAAe,EAAE,uBAAuB;QACxC,gBAAgB,EAAE,mBAAmB;QACrC,OAAO,EAAE,8BAA8B;QACvC,IAAI,EAAE,gBAAgB;KACvB;IACD,WAAW,EAAE;QACX,OAAO,EAAE,8BAA8B;QACvC,eAAe,EAAE,yBAAyB;QAC1C,gBAAgB,EAAE,qBAAqB;QACvC,OAAO,EAAE,gCAAgC;QACzC,IAAI,EAAE,8BAA8B;KACrC;IACD,eAAe,EAAE;QACf,OAAO,EAAE,+BAA+B;QACxC,OAAO,EAAE,+BAA+B;QACxC,IAAI,EAAE,kBAAkB;KACzB;IACD,MAAM,EAAE;QACN,OAAO,EAAE,uBAAuB;QAChC,eAAe,EAAE,qBAAqB;QACtC,OAAO,EAAE,4BAA4B;QACrC,IAAI,EAAE,uBAAuB;KAC9B;IACD,aAAa,EAAE;QACb,OAAO,EAAE,uBAAuB;QAChC,eAAe,EAAE,qBAAqB;QACtC,OAAO,EAAE,4BAA4B;QACrC,IAAI,EAAE,uBAAuB;KAC9B;CACF,CAAA;AAED,MAAM,iBAAiB,GAGnB;IACF,OAAO,EAAE;QACP,oBAAoB,EAAE,kDAAkD;QACxE,mBAAmB,EAAE,+CAA+C;QACpE,aAAa,EACX,mFAAmF;QACrF,yBAAyB,EACvB,kHAAkH;QACpH,4BAA4B,EAC1B,4GAA4G;KAC/G;IACD,IAAI,EAAE;QACJ,OAAO,EACL,uEAAuE;QACzE,QAAQ,EAAE,iDAAiD;QAC3D,SAAS,EAAE,2BAA2B;KACvC;IACD,MAAM,EAAE,EAAE;IACV,OAAO,EAAE,EAAE;IACX,SAAS,EAAE,EAAE;CACd,CAAA;AAED,SAAgB,gBAAgB,CAC9B,IAAyB,EACzB,MAA6B;IAE7B,MAAM,aAAa,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAA;IAClD,OAAO,aAAa,CAAA;AACtB,CAAC;AAED,SAAgB,mBAAmB,CACjC,MAAqB,EACrB,SAAqB;IAErB,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,OAAM;IACR,CAAC;IACD,MAAM,OAAO,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,CAAA;IACpD,OAAO,OAAO,CAAA;AAChB,CAAC"}
|
|
@@ -73,7 +73,19 @@ const executeSteps = async (client, route) => {
|
|
|
73
73
|
if (execution.executionOptions) {
|
|
74
74
|
(0, exports.updateRouteExecution)(route, execution.executionOptions);
|
|
75
75
|
}
|
|
76
|
-
|
|
76
|
+
let executedStep;
|
|
77
|
+
try {
|
|
78
|
+
executedStep = await stepExecutor.executeStep(client, step);
|
|
79
|
+
}
|
|
80
|
+
catch (e) {
|
|
81
|
+
if (e instanceof errors_js_1.ExecuteStepRetryError) {
|
|
82
|
+
step.execution = undefined;
|
|
83
|
+
executedStep = await stepExecutor.executeStep(client, step, e.retryParams);
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
throw e;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
77
89
|
if (executedStep.execution?.status !== 'DONE') {
|
|
78
90
|
(0, exports.stopRouteExecution)(route);
|
|
79
91
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"execution.js","sourceRoot":"","sources":["../../../src/core/execution.ts"],"names":[],"mappings":";;;AACA,yDAAsD;AACtD,
|
|
1
|
+
{"version":3,"file":"execution.js","sourceRoot":"","sources":["../../../src/core/execution.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,9 +5,8 @@ const prepareRestart = (route) => {
|
|
|
5
5
|
for (let index = 0; index < route.steps.length; index++) {
|
|
6
6
|
const step = route.steps[index];
|
|
7
7
|
if (step.execution) {
|
|
8
|
-
const lastValidIndex = step.execution.actions.findLastIndex((action) => (
|
|
9
|
-
!!action.taskId
|
|
10
|
-
!!action.signedTypedData?.length) &&
|
|
8
|
+
const lastValidIndex = step.execution.actions.findLastIndex((action) => ['SWAP', 'CROSS_CHAIN', 'RECEIVING_CHAIN'].includes(action.type) &&
|
|
9
|
+
(!!action.txHash || !!action.taskId) &&
|
|
11
10
|
action.status !== 'FAILED');
|
|
12
11
|
if (lastValidIndex >= 0) {
|
|
13
12
|
step.execution.actions = step.execution.actions.slice(0, lastValidIndex + 1);
|
|
@@ -15,6 +14,7 @@ const prepareRestart = (route) => {
|
|
|
15
14
|
else {
|
|
16
15
|
step.execution.actions = [];
|
|
17
16
|
}
|
|
17
|
+
step.execution.lastActionType = undefined;
|
|
18
18
|
}
|
|
19
19
|
step.transactionRequest = undefined;
|
|
20
20
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareRestart.js","sourceRoot":"","sources":["../../../src/core/prepareRestart.ts"],"names":[],"mappings":";;;AAEO,MAAM,cAAc,GAAG,CAAC,KAAoB,EAAE,EAAE;IACrD,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;QACxD,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QAC/B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YAEnB,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CACzD,CAAC,MAAM,EAAE,EAAE,CACT,CAAC,CAAC,CAAC,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"prepareRestart.js","sourceRoot":"","sources":["../../../src/core/prepareRestart.ts"],"names":[],"mappings":";;;AAEO,MAAM,cAAc,GAAG,CAAC,KAAoB,EAAE,EAAE;IACrD,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;QACxD,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QAC/B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YAEnB,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CACzD,CAAC,MAAM,EAAE,EAAE,CACT,CAAC,MAAM,EAAE,aAAa,EAAE,iBAAiB,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC;gBAChE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;gBACpC,MAAM,CAAC,MAAM,KAAK,QAAQ,CAC7B,CAAA;YAGD,IAAI,cAAc,IAAI,CAAC,EAAE,CAAC;gBACxB,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CACnD,CAAC,EACD,cAAc,GAAG,CAAC,CACnB,CAAA;YACH,CAAC;iBAAM,CAAC;gBAEN,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,EAAE,CAAA;YAC7B,CAAC;YAED,IAAI,CAAC,SAAS,CAAC,cAAc,GAAG,SAAS,CAAA;QAC3C,CAAC;QACD,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAA;IACrC,CAAC;AACH,CAAC,CAAA;AA3BY,QAAA,cAAc,kBA2B1B"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { StepExecutorContext, TaskResult } from '../../types/execution.js';
|
|
2
|
+
import { BaseStepExecutionTask } from '../BaseStepExecutionTask.js';
|
|
3
|
+
export declare class CheckBalanceTask extends BaseStepExecutionTask {
|
|
4
|
+
run(context: StepExecutorContext): Promise<TaskResult>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CheckBalanceTask = void 0;
|
|
4
|
+
const constants_js_1 = require("../../errors/constants.js");
|
|
5
|
+
const errors_js_1 = require("../../errors/errors.js");
|
|
6
|
+
const BaseStepExecutionTask_js_1 = require("../BaseStepExecutionTask.js");
|
|
7
|
+
const checkBalance_js_1 = require("./helpers/checkBalance.js");
|
|
8
|
+
class CheckBalanceTask extends BaseStepExecutionTask_js_1.BaseStepExecutionTask {
|
|
9
|
+
async run(context) {
|
|
10
|
+
const { client, step, statusManager, isBridgeExecution } = context;
|
|
11
|
+
statusManager.initializeAction({
|
|
12
|
+
step,
|
|
13
|
+
type: isBridgeExecution ? 'CROSS_CHAIN' : 'SWAP',
|
|
14
|
+
chainId: step.action.fromChainId,
|
|
15
|
+
status: 'STARTED',
|
|
16
|
+
});
|
|
17
|
+
const walletAddress = step.action.fromAddress;
|
|
18
|
+
if (!walletAddress) {
|
|
19
|
+
throw new errors_js_1.TransactionError(constants_js_1.LiFiErrorCode.InternalError, 'The wallet address is undefined.');
|
|
20
|
+
}
|
|
21
|
+
await (0, checkBalance_js_1.checkBalance)(client, walletAddress, step);
|
|
22
|
+
return { status: 'COMPLETED' };
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.CheckBalanceTask = CheckBalanceTask;
|
|
26
|
+
//# sourceMappingURL=CheckBalanceTask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CheckBalanceTask.js","sourceRoot":"","sources":["../../../../src/core/tasks/CheckBalanceTask.ts"],"names":[],"mappings":";;;AAAA,4DAAyD;AACzD,sDAAyD;AAEzD,0EAAmE;AACnE,+DAAwD;AAExD,MAAa,gBAAiB,SAAQ,gDAAqB;IACzD,KAAK,CAAC,GAAG,CAAC,OAA4B;QACpC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,iBAAiB,EAAE,GAAG,OAAO,CAAA;QAElE,aAAa,CAAC,gBAAgB,CAAC;YAC7B,IAAI;YACJ,IAAI,EAAE,iBAAiB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM;YAChD,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW;YAChC,MAAM,EAAE,SAAS;SAClB,CAAC,CAAA;QAEF,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAA;QAC7C,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,MAAM,IAAI,4BAAgB,CACxB,4BAAa,CAAC,aAAa,EAC3B,kCAAkC,CACnC,CAAA;QACH,CAAC;QAED,MAAM,IAAA,8BAAY,EAAC,MAAM,EAAE,aAAa,EAAE,IAAI,CAAC,CAAA;QAC/C,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAA;IAChC,CAAC;CACF;AAtBD,4CAsBC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { StepExecutorContext, TaskResult } from '../../types/execution.js';
|
|
2
|
+
import { BaseStepExecutionTask } from '../BaseStepExecutionTask.js';
|
|
3
|
+
export declare class PrepareTransactionTask extends BaseStepExecutionTask {
|
|
4
|
+
run(context: StepExecutorContext): Promise<TaskResult>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PrepareTransactionTask = void 0;
|
|
4
|
+
const getStepTransaction_js_1 = require("../../actions/getStepTransaction.js");
|
|
5
|
+
const constants_js_1 = require("../../errors/constants.js");
|
|
6
|
+
const errors_js_1 = require("../../errors/errors.js");
|
|
7
|
+
const BaseStepExecutionTask_js_1 = require("../BaseStepExecutionTask.js");
|
|
8
|
+
const stepComparison_js_1 = require("./helpers/stepComparison.js");
|
|
9
|
+
class PrepareTransactionTask extends BaseStepExecutionTask_js_1.BaseStepExecutionTask {
|
|
10
|
+
async run(context) {
|
|
11
|
+
const { client, step, statusManager, allowUserInteraction, executionOptions, isBridgeExecution, } = context;
|
|
12
|
+
const action = statusManager.findAction(step, isBridgeExecution ? 'CROSS_CHAIN' : 'SWAP');
|
|
13
|
+
if (!action) {
|
|
14
|
+
throw new errors_js_1.TransactionError(constants_js_1.LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction. Action not found.');
|
|
15
|
+
}
|
|
16
|
+
if (!step.transactionRequest) {
|
|
17
|
+
const { execution, ...stepBase } = step;
|
|
18
|
+
const updatedStep = await (0, getStepTransaction_js_1.getStepTransaction)(client, stepBase);
|
|
19
|
+
const comparedStep = await (0, stepComparison_js_1.stepComparison)(statusManager, step, updatedStep, allowUserInteraction, executionOptions);
|
|
20
|
+
Object.assign(step, {
|
|
21
|
+
...comparedStep,
|
|
22
|
+
execution: step.execution,
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
if (!step.transactionRequest?.data) {
|
|
26
|
+
throw new errors_js_1.TransactionError(constants_js_1.LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction. Transaction request data is not found.');
|
|
27
|
+
}
|
|
28
|
+
statusManager.updateAction(step, action.type, 'ACTION_REQUIRED');
|
|
29
|
+
if (!allowUserInteraction) {
|
|
30
|
+
return { status: 'PAUSED' };
|
|
31
|
+
}
|
|
32
|
+
return { status: 'COMPLETED' };
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.PrepareTransactionTask = PrepareTransactionTask;
|
|
36
|
+
//# sourceMappingURL=PrepareTransactionTask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PrepareTransactionTask.js","sourceRoot":"","sources":["../../../../src/core/tasks/PrepareTransactionTask.ts"],"names":[],"mappings":";;;AAAA,+EAAwE;AACxE,4DAAyD;AACzD,sDAAyD;AAEzD,0EAAmE;AACnE,mEAA4D;AAE5D,MAAa,sBAAuB,SAAQ,gDAAqB;IAC/D,KAAK,CAAC,GAAG,CAAC,OAA4B;QACpC,MAAM,EACJ,MAAM,EACN,IAAI,EACJ,aAAa,EACb,oBAAoB,EACpB,gBAAgB,EAChB,iBAAiB,GAClB,GAAG,OAAO,CAAA;QAEX,MAAM,MAAM,GAAG,aAAa,CAAC,UAAU,CACrC,IAAI,EACJ,iBAAiB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAC3C,CAAA;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,4BAAgB,CACxB,4BAAa,CAAC,qBAAqB,EACnC,kDAAkD,CACnD,CAAA;QACH,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,MAAM,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAA;YACvC,MAAM,WAAW,GAAG,MAAM,IAAA,0CAAkB,EAAC,MAAM,EAAE,QAAQ,CAAC,CAAA;YAC9D,MAAM,YAAY,GAAG,MAAM,IAAA,kCAAc,EACvC,aAAa,EACb,IAAI,EACJ,WAAW,EACX,oBAAoB,EACpB,gBAAgB,CACjB,CAAA;YACD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE;gBAClB,GAAG,YAAY;gBACf,SAAS,EAAE,IAAI,CAAC,SAAS;aAC1B,CAAC,CAAA;QACJ,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,EAAE,CAAC;YACnC,MAAM,IAAI,4BAAgB,CACxB,4BAAa,CAAC,qBAAqB,EACnC,uEAAuE,CACxE,CAAA;QACH,CAAC;QAED,aAAa,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAA;QAEhE,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC1B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAA;QAC7B,CAAC;QAED,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAA;IAChC,CAAC;CACF;AAtDD,wDAsDC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ExecutionActionType } from '../../types/core.js';
|
|
2
|
+
import type { StepExecutorContext, TaskResult } from '../../types/execution.js';
|
|
3
|
+
import { BaseStepExecutionTask } from '../BaseStepExecutionTask.js';
|
|
4
|
+
export declare class WaitForTransactionStatusTask extends BaseStepExecutionTask {
|
|
5
|
+
readonly actionType: ExecutionActionType;
|
|
6
|
+
constructor(actionType: ExecutionActionType);
|
|
7
|
+
run(context: StepExecutorContext): Promise<TaskResult>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.WaitForTransactionStatusTask = void 0;
|
|
4
|
+
const constants_js_1 = require("../../errors/constants.js");
|
|
5
|
+
const errors_js_1 = require("../../errors/errors.js");
|
|
6
|
+
const getTransactionMessage_js_1 = require("../../utils/getTransactionMessage.js");
|
|
7
|
+
const BaseStepExecutionTask_js_1 = require("../BaseStepExecutionTask.js");
|
|
8
|
+
const waitForTransactionStatus_js_1 = require("./helpers/waitForTransactionStatus.js");
|
|
9
|
+
class WaitForTransactionStatusTask extends BaseStepExecutionTask_js_1.BaseStepExecutionTask {
|
|
10
|
+
actionType;
|
|
11
|
+
constructor(actionType) {
|
|
12
|
+
super();
|
|
13
|
+
this.actionType = actionType;
|
|
14
|
+
}
|
|
15
|
+
async run(context) {
|
|
16
|
+
const { client, step, statusManager, pollingIntervalMs, toChain, isBridgeExecution, } = context;
|
|
17
|
+
let transactionHash;
|
|
18
|
+
try {
|
|
19
|
+
const swapOrBridgeAction = statusManager.findAction(step, isBridgeExecution ? 'CROSS_CHAIN' : 'SWAP');
|
|
20
|
+
transactionHash = swapOrBridgeAction?.txHash || swapOrBridgeAction?.taskId;
|
|
21
|
+
if (!transactionHash) {
|
|
22
|
+
throw new Error('Transaction hash is undefined.');
|
|
23
|
+
}
|
|
24
|
+
const action = statusManager.initializeAction({
|
|
25
|
+
step,
|
|
26
|
+
type: this.actionType,
|
|
27
|
+
chainId: this.actionType === 'RECEIVING_CHAIN'
|
|
28
|
+
? step.action.toChainId
|
|
29
|
+
: step.action.fromChainId,
|
|
30
|
+
status: 'PENDING',
|
|
31
|
+
});
|
|
32
|
+
const statusResponse = (await (0, waitForTransactionStatus_js_1.waitForTransactionStatus)(client, statusManager, transactionHash, step, action.type, pollingIntervalMs));
|
|
33
|
+
const statusReceiving = statusResponse.receiving;
|
|
34
|
+
statusManager.updateAction(step, action.type, 'DONE', {
|
|
35
|
+
chainId: statusReceiving?.chainId || toChain.id,
|
|
36
|
+
substatus: statusResponse.substatus,
|
|
37
|
+
substatusMessage: statusResponse.substatusMessage,
|
|
38
|
+
txHash: statusReceiving?.txHash,
|
|
39
|
+
txLink: statusReceiving?.txLink ||
|
|
40
|
+
`${toChain.metamask.blockExplorerUrls[0]}tx/${statusReceiving?.txHash}`,
|
|
41
|
+
});
|
|
42
|
+
statusManager.updateExecution(step, {
|
|
43
|
+
status: 'DONE',
|
|
44
|
+
...(statusResponse.sending.amount && {
|
|
45
|
+
fromAmount: statusResponse.sending.amount,
|
|
46
|
+
}),
|
|
47
|
+
...(statusReceiving?.amount && { toAmount: statusReceiving.amount }),
|
|
48
|
+
...(statusReceiving?.token && { toToken: statusReceiving.token }),
|
|
49
|
+
internalTxLink: statusResponse?.lifiExplorerLink,
|
|
50
|
+
externalTxLink: statusResponse?.bridgeExplorerLink,
|
|
51
|
+
gasCosts: [
|
|
52
|
+
{
|
|
53
|
+
amount: statusResponse.sending.gasAmount,
|
|
54
|
+
amountUSD: statusResponse.sending.gasAmountUSD,
|
|
55
|
+
token: statusResponse.sending.gasToken,
|
|
56
|
+
estimate: statusResponse.sending.gasUsed,
|
|
57
|
+
limit: statusResponse.sending.gasUsed,
|
|
58
|
+
price: statusResponse.sending.gasPrice,
|
|
59
|
+
type: 'SEND',
|
|
60
|
+
},
|
|
61
|
+
],
|
|
62
|
+
});
|
|
63
|
+
return { status: 'COMPLETED' };
|
|
64
|
+
}
|
|
65
|
+
catch (e) {
|
|
66
|
+
const htmlMessage = await (0, getTransactionMessage_js_1.getTransactionFailedMessage)(client, step, `${toChain.metamask.blockExplorerUrls[0]}tx/${transactionHash}`);
|
|
67
|
+
throw new errors_js_1.TransactionError(constants_js_1.LiFiErrorCode.TransactionFailed, htmlMessage ??
|
|
68
|
+
'Failed while waiting for status of destination chain transaction.', e);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
exports.WaitForTransactionStatusTask = WaitForTransactionStatusTask;
|
|
73
|
+
//# sourceMappingURL=WaitForTransactionStatusTask.js.map
|