@instadapp/interop-x 0.0.0-dev.051cd4e → 0.0.0-dev.098229d
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/package.json +3 -2
- package/dist/src/api/index.js +2 -2
- package/dist/src/index.js +1 -1
- package/dist/src/net/pool/index.js +3 -0
- package/dist/src/net/protocol/dial/SignatureDialProtocol.1.js +28 -0
- package/dist/src/net/protocol/index.js +11 -0
- package/dist/src/tasks/AutoUpdateTask.js +19 -16
- package/dist/src/tasks/BaseTask.js +7 -3
- package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +53 -0
- package/dist/src/tasks/index.js +2 -0
- package/package.json +3 -2
- package/src/api/index.ts +1 -1
- package/src/net/pool/index.ts +3 -1
- package/src/net/protocol/dial/SignatureDialProtocol.1.ts +31 -0
- package/src/net/protocol/index.ts +12 -0
- package/src/tasks/AutoUpdateTask.ts +23 -17
- package/src/tasks/BaseTask.ts +8 -3
- package/src/tasks/Transactions/SyncTransactionStatusTask.ts +65 -0
- package/src/tasks/index.ts +2 -0
package/dist/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@instadapp/interop-x",
|
3
|
-
"version": "0.0.0-dev.
|
3
|
+
"version": "0.0.0-dev.098229d",
|
4
4
|
"license": "MIT",
|
5
5
|
"main": "dist/index.js",
|
6
6
|
"engines": {
|
@@ -24,6 +24,8 @@
|
|
24
24
|
},
|
25
25
|
"dependencies": {
|
26
26
|
"@achingbrain/libp2p-gossipsub": "^0.12.2",
|
27
|
+
"@fastify/cors": "^7.0.0",
|
28
|
+
"await-spawn": "^4.0.2",
|
27
29
|
"axios": "^0.27.1",
|
28
30
|
"axios-retry": "^3.2.4",
|
29
31
|
"bignumber.js": "^9.0.2",
|
@@ -34,7 +36,6 @@
|
|
34
36
|
"ethers-multisend": "^2.1.1",
|
35
37
|
"expand-home-dir": "^0.0.3",
|
36
38
|
"fastify": "^3.28.0",
|
37
|
-
"fastify-cors": "^6.0.3",
|
38
39
|
"libp2p": "^0.36.2",
|
39
40
|
"libp2p-bootstrap": "^0.14.0",
|
40
41
|
"libp2p-kad-dht": "^0.28.6",
|
package/dist/src/api/index.js
CHANGED
@@ -5,12 +5,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
6
|
exports.startApiServer = void 0;
|
7
7
|
const fastify_1 = __importDefault(require("fastify"));
|
8
|
-
const
|
8
|
+
const cors_1 = __importDefault(require("@fastify/cors"));
|
9
9
|
const logger_1 = __importDefault(require("@/logger"));
|
10
10
|
const db_1 = require("@/db");
|
11
11
|
const logger = new logger_1.default("RPC");
|
12
12
|
const server = (0, fastify_1.default)({ logger: false });
|
13
|
-
server.register(
|
13
|
+
server.register(cors_1.default, {});
|
14
14
|
server.get('/', async () => 'Interop X API');
|
15
15
|
const startApiServer = async () => {
|
16
16
|
const HOST = process.env.API_HOST || '0.0.0.0';
|
package/dist/src/index.js
CHANGED
@@ -37,7 +37,7 @@ if (process.argv.at(-1) === 'help') {
|
|
37
37
|
printUsage();
|
38
38
|
process.exit(0);
|
39
39
|
}
|
40
|
-
const GIT_SHORT_HASH = '
|
40
|
+
const GIT_SHORT_HASH = '098229d';
|
41
41
|
if (process.argv.at(-1) === 'version') {
|
42
42
|
console.log(`Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
|
43
43
|
process.exit(0);
|
@@ -111,6 +111,9 @@ class PeerPool {
|
|
111
111
|
}
|
112
112
|
return (0, utils_1.getAddress)(peer.publicAddress) === (0, utils_1.getAddress)(config_1.default.leadNodeAddress);
|
113
113
|
}
|
114
|
+
getLeadPeer() {
|
115
|
+
return this.peers.find((p) => this.isLeadNode(p.id));
|
116
|
+
}
|
114
117
|
cleanup() {
|
115
118
|
// let compDate = Date.now() - this.PEERS_CLEANUP_TIME_LIMIT * 60
|
116
119
|
// this.peers.forEach((peerInfo) => {
|
@@ -0,0 +1,28 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.TransactionStatusDialProtocol = void 0;
|
4
|
+
const BaseDialProtocol_1 = require("./BaseDialProtocol");
|
5
|
+
const db_1 = require("@/db");
|
6
|
+
class TransactionStatusDialProtocol extends BaseDialProtocol_1.BaseDialProtocol {
|
7
|
+
constructor(libp2p) {
|
8
|
+
super(libp2p, '/interop-x/transaction-status');
|
9
|
+
this.timeout = 30000;
|
10
|
+
}
|
11
|
+
async response(transactionHash) {
|
12
|
+
const transaction = await db_1.Transaction.findOne({ where: { transactionHash } });
|
13
|
+
if (!transaction) {
|
14
|
+
return null;
|
15
|
+
}
|
16
|
+
return {
|
17
|
+
transactionHash: transaction.transactionHash,
|
18
|
+
sourceStatus: transaction.sourceStatus,
|
19
|
+
sourceTransactionHash: transaction.sourceTransactionHash,
|
20
|
+
sourceErrors: transaction.sourceErrors,
|
21
|
+
targetStatus: transaction.targetStatus,
|
22
|
+
targetTransactionHash: transaction.targetTransactionHash,
|
23
|
+
targetErrors: transaction.targetErrors,
|
24
|
+
status: transaction.status,
|
25
|
+
};
|
26
|
+
}
|
27
|
+
}
|
28
|
+
exports.TransactionStatusDialProtocol = TransactionStatusDialProtocol;
|
@@ -10,6 +10,7 @@ const SignatureDialProtocol_1 = require("./dial/SignatureDialProtocol");
|
|
10
10
|
const __1 = require("..");
|
11
11
|
const config_1 = __importDefault(require("@/config"));
|
12
12
|
const types_1 = require("@/types");
|
13
|
+
const SignatureDialProtocol_1_1 = require("./dial/SignatureDialProtocol.1");
|
13
14
|
class Protocol extends stream_1.EventEmitter {
|
14
15
|
constructor() {
|
15
16
|
super(...arguments);
|
@@ -64,6 +65,7 @@ class Protocol extends stream_1.EventEmitter {
|
|
64
65
|
});
|
65
66
|
});
|
66
67
|
this.signature = new SignatureDialProtocol_1.SignatureDialProtocol(this.libp2p);
|
68
|
+
this.transactionStatus = new SignatureDialProtocol_1_1.TransactionStatusDialProtocol(this.libp2p);
|
67
69
|
}
|
68
70
|
init() {
|
69
71
|
this.libp2p.pubsub.subscribe(this.topic);
|
@@ -117,5 +119,14 @@ class Protocol extends stream_1.EventEmitter {
|
|
117
119
|
return [];
|
118
120
|
}
|
119
121
|
}
|
122
|
+
async requestTransactionStatus(transactionHash, peerId) {
|
123
|
+
try {
|
124
|
+
return await this.transactionStatus.send(transactionHash, peerId);
|
125
|
+
}
|
126
|
+
catch (error) {
|
127
|
+
console.log(error);
|
128
|
+
return null;
|
129
|
+
}
|
130
|
+
}
|
120
131
|
}
|
121
132
|
exports.protocol = new Protocol();
|
@@ -5,41 +5,44 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
6
|
const BaseTask_1 = require("./BaseTask");
|
7
7
|
const logger_1 = __importDefault(require("@/logger"));
|
8
|
-
const package_json_1 = __importDefault(require("../../package.json"));
|
9
8
|
const utils_1 = require("@/utils");
|
10
|
-
const
|
9
|
+
const await_spawn_1 = __importDefault(require("await-spawn"));
|
11
10
|
const config_1 = __importDefault(require("@/config"));
|
12
|
-
const
|
11
|
+
const waait_1 = __importDefault(require("waait"));
|
13
12
|
class AutoUpdateTask extends BaseTask_1.BaseTask {
|
14
13
|
constructor() {
|
15
14
|
super({
|
16
15
|
logger: new logger_1.default("AutoUpdateTask"),
|
17
16
|
});
|
18
|
-
this.pollIntervalMs = 60 * 1000;
|
17
|
+
this.pollIntervalMs = 60 * 5 * 1000;
|
19
18
|
}
|
20
19
|
prePollHandler() {
|
21
20
|
return config_1.default.autoUpdate && !config_1.default.isLeadNode();
|
22
21
|
}
|
22
|
+
getCurrentVersion() {
|
23
|
+
return require('../../package.json').version;
|
24
|
+
}
|
23
25
|
async pollHandler() {
|
24
26
|
const { data } = await utils_1.http.get('https://registry.npmjs.org/@instadapp/interop-x');
|
25
27
|
const version = data['dist-tags'].latest;
|
28
|
+
const currentVersion = this.getCurrentVersion();
|
26
29
|
if (version === currentVersion) {
|
27
30
|
return;
|
28
31
|
}
|
29
32
|
this.logger.warn(`New version ${version} available.`);
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
this.logger.warn(`
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
});
|
33
|
+
await (0, await_spawn_1.default)('npm', ['-g', 'install', '@instadapp/interop-x', '-f']);
|
34
|
+
await (0, waait_1.default)(5000);
|
35
|
+
if (currentVersion === this.getCurrentVersion()) {
|
36
|
+
this.logger.warn(`failed to install ${version}, retrying in 5 minutes`);
|
37
|
+
return;
|
38
|
+
}
|
39
|
+
this.logger.warn(`Installed version ${version}`);
|
40
|
+
this.logger.warn(`Restarting...`);
|
41
|
+
(0, await_spawn_1.default)(process.argv[0], process.argv.slice(1), {
|
42
|
+
cwd: process.cwd(),
|
43
|
+
stdio: "inherit"
|
42
44
|
});
|
45
|
+
process.exit();
|
43
46
|
}
|
44
47
|
}
|
45
48
|
exports.default = AutoUpdateTask;
|
@@ -14,6 +14,7 @@ class BaseTask extends events_1.default {
|
|
14
14
|
this.started = false;
|
15
15
|
this.pollIntervalMs = 10 * 1000;
|
16
16
|
this.leadNodeOnly = false;
|
17
|
+
this.exceptLeadNode = false;
|
17
18
|
this.logger = logger !== null && logger !== void 0 ? logger : new logger_1.default('BaseTask');
|
18
19
|
}
|
19
20
|
async pollCheck() {
|
@@ -34,10 +35,13 @@ class BaseTask extends events_1.default {
|
|
34
35
|
}
|
35
36
|
}
|
36
37
|
prePollHandler() {
|
37
|
-
if (
|
38
|
-
return
|
38
|
+
if (this.exceptLeadNode) {
|
39
|
+
return !config_1.default.isLeadNode();
|
39
40
|
}
|
40
|
-
|
41
|
+
if (this.leadNodeOnly) {
|
42
|
+
return config_1.default.isLeadNode();
|
43
|
+
}
|
44
|
+
return true;
|
41
45
|
}
|
42
46
|
async pollHandler() {
|
43
47
|
this.logger.warn('pollHandler not implemented');
|
@@ -0,0 +1,53 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
const BaseTask_1 = require("../BaseTask");
|
7
|
+
const logger_1 = __importDefault(require("@/logger"));
|
8
|
+
const net_1 = require("@/net");
|
9
|
+
const db_1 = require("@/db");
|
10
|
+
const sequelize_1 = require("sequelize");
|
11
|
+
class SyncTransactionStatusTask extends BaseTask_1.BaseTask {
|
12
|
+
constructor() {
|
13
|
+
super({
|
14
|
+
logger: new logger_1.default("SyncTransactionStatusTask"),
|
15
|
+
});
|
16
|
+
this.pollIntervalMs = 60 * 1000;
|
17
|
+
this.exceptLeadNode = true;
|
18
|
+
}
|
19
|
+
async pollHandler() {
|
20
|
+
// if transaction is pending for more than 1 hour, check lead node for status
|
21
|
+
const leadNode = net_1.peerPool.getLeadPeer();
|
22
|
+
if (!leadNode) {
|
23
|
+
return;
|
24
|
+
}
|
25
|
+
const transaction = await db_1.Transaction.findOne({
|
26
|
+
where: {
|
27
|
+
status: 'pending',
|
28
|
+
sourceCreatedAt: {
|
29
|
+
[sequelize_1.Op.gte]: new Date(Date.now() - 60 * 60 * 1000),
|
30
|
+
},
|
31
|
+
}
|
32
|
+
});
|
33
|
+
if (!transaction) {
|
34
|
+
return;
|
35
|
+
}
|
36
|
+
this.logger.info(`Requesting transaction status for ${transaction.transactionHash}`);
|
37
|
+
const transactionStatus = await net_1.protocol.requestTransactionStatus(transaction.transactionHash, leadNode.id);
|
38
|
+
if (!transactionStatus) {
|
39
|
+
return;
|
40
|
+
}
|
41
|
+
this.logger.info(`Received transaction status for ${transaction.transactionHash}`);
|
42
|
+
transaction.sourceStatus = transactionStatus.sourceStatus;
|
43
|
+
transaction.sourceTransactionHash = transactionStatus.sourceTransactionHash;
|
44
|
+
transaction.sourceErrors = transactionStatus.sourceErrors;
|
45
|
+
transaction.targetStatus = transactionStatus.targetStatus;
|
46
|
+
transaction.targetTransactionHash = transactionStatus.targetTransactionHash;
|
47
|
+
transaction.targetErrors = transactionStatus.targetErrors;
|
48
|
+
transaction.status = transactionStatus.status;
|
49
|
+
await transaction.save();
|
50
|
+
this.logger.info(`Updated transaction status for ${transaction.transactionHash}`);
|
51
|
+
}
|
52
|
+
}
|
53
|
+
exports.default = SyncTransactionStatusTask;
|
package/dist/src/tasks/index.js
CHANGED
@@ -9,9 +9,11 @@ const SyncDepositEvents_1 = __importDefault(require("./InteropXGateway/SyncDepos
|
|
9
9
|
const SyncWithdrawEvents_1 = __importDefault(require("./InteropBridge/SyncWithdrawEvents"));
|
10
10
|
const ProcessWithdrawEvents_1 = __importDefault(require("./InteropBridge/ProcessWithdrawEvents"));
|
11
11
|
const AutoUpdateTask_1 = __importDefault(require("./AutoUpdateTask"));
|
12
|
+
const SyncTransactionStatusTask_1 = __importDefault(require("./Transactions/SyncTransactionStatusTask"));
|
12
13
|
class Tasks {
|
13
14
|
constructor() {
|
14
15
|
this.tasks = [
|
16
|
+
new SyncTransactionStatusTask_1.default(),
|
15
17
|
new AutoUpdateTask_1.default(),
|
16
18
|
new SyncDepositEvents_1.default({
|
17
19
|
chainId: 43114
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@instadapp/interop-x",
|
3
|
-
"version": "0.0.0-dev.
|
3
|
+
"version": "0.0.0-dev.098229d",
|
4
4
|
"license": "MIT",
|
5
5
|
"main": "dist/index.js",
|
6
6
|
"engines": {
|
@@ -24,6 +24,8 @@
|
|
24
24
|
},
|
25
25
|
"dependencies": {
|
26
26
|
"@achingbrain/libp2p-gossipsub": "^0.12.2",
|
27
|
+
"@fastify/cors": "^7.0.0",
|
28
|
+
"await-spawn": "^4.0.2",
|
27
29
|
"axios": "^0.27.1",
|
28
30
|
"axios-retry": "^3.2.4",
|
29
31
|
"bignumber.js": "^9.0.2",
|
@@ -34,7 +36,6 @@
|
|
34
36
|
"ethers-multisend": "^2.1.1",
|
35
37
|
"expand-home-dir": "^0.0.3",
|
36
38
|
"fastify": "^3.28.0",
|
37
|
-
"fastify-cors": "^6.0.3",
|
38
39
|
"libp2p": "^0.36.2",
|
39
40
|
"libp2p-bootstrap": "^0.14.0",
|
40
41
|
"libp2p-kad-dht": "^0.28.6",
|
package/src/api/index.ts
CHANGED
package/src/net/pool/index.ts
CHANGED
@@ -123,7 +123,6 @@ export class PeerPool {
|
|
123
123
|
return this.activePeers.map((p) => p.id)
|
124
124
|
}
|
125
125
|
|
126
|
-
|
127
126
|
getPeer(id: string){
|
128
127
|
return this.pool.get(id);
|
129
128
|
}
|
@@ -138,6 +137,9 @@ export class PeerPool {
|
|
138
137
|
return getAddress(peer.publicAddress) === getAddress(config.leadNodeAddress)
|
139
138
|
}
|
140
139
|
|
140
|
+
getLeadPeer() {
|
141
|
+
return this.peers.find((p) => this.isLeadNode(p.id))
|
142
|
+
}
|
141
143
|
|
142
144
|
cleanup() {
|
143
145
|
// let compDate = Date.now() - this.PEERS_CLEANUP_TIME_LIMIT * 60
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import { BaseDialProtocol } from "./BaseDialProtocol";
|
2
|
+
import { Transaction } from "@/db";
|
3
|
+
|
4
|
+
export class TransactionStatusDialProtocol extends BaseDialProtocol<string, Pick<Transaction, 'transactionHash' | 'sourceStatus' | 'sourceTransactionHash' | 'sourceErrors' | 'targetStatus' | 'targetTransactionHash' | 'targetErrors' | 'status'> | null> {
|
5
|
+
protected timeout = 30000;
|
6
|
+
|
7
|
+
constructor(libp2p) {
|
8
|
+
super(libp2p, '/interop-x/transaction-status')
|
9
|
+
}
|
10
|
+
|
11
|
+
async response(transactionHash: string){
|
12
|
+
const transaction = await Transaction.findOne({ where: { transactionHash } })
|
13
|
+
|
14
|
+
if(! transaction){
|
15
|
+
return null
|
16
|
+
}
|
17
|
+
return {
|
18
|
+
transactionHash: transaction.transactionHash,
|
19
|
+
|
20
|
+
sourceStatus: transaction.sourceStatus,
|
21
|
+
sourceTransactionHash: transaction.sourceTransactionHash,
|
22
|
+
sourceErrors: transaction.sourceErrors,
|
23
|
+
|
24
|
+
targetStatus: transaction.targetStatus,
|
25
|
+
targetTransactionHash: transaction.targetTransactionHash,
|
26
|
+
targetErrors: transaction.targetErrors,
|
27
|
+
|
28
|
+
status: transaction.status,
|
29
|
+
}
|
30
|
+
}
|
31
|
+
}
|
@@ -6,6 +6,7 @@ import { IPeerInfo, peerPool } from "..";
|
|
6
6
|
import config from "@/config";
|
7
7
|
import { Event } from "@/types";
|
8
8
|
import { Transaction } from "@/db";
|
9
|
+
import { TransactionStatusDialProtocol } from "./dial/SignatureDialProtocol.1";
|
9
10
|
|
10
11
|
export interface ProtocolOptions {
|
11
12
|
/* Handshake timeout in ms (default: 8000) */
|
@@ -90,6 +91,7 @@ class Protocol extends EventEmitter {
|
|
90
91
|
},
|
91
92
|
];
|
92
93
|
private signature: SignatureDialProtocol;
|
94
|
+
private transactionStatus: TransactionStatusDialProtocol;
|
93
95
|
|
94
96
|
|
95
97
|
start({ libp2p, topic = null, }) {
|
@@ -109,6 +111,7 @@ class Protocol extends EventEmitter {
|
|
109
111
|
})
|
110
112
|
|
111
113
|
this.signature = new SignatureDialProtocol(this.libp2p);
|
114
|
+
this.transactionStatus = new TransactionStatusDialProtocol(this.libp2p);
|
112
115
|
}
|
113
116
|
|
114
117
|
|
@@ -177,6 +180,15 @@ class Protocol extends EventEmitter {
|
|
177
180
|
return []
|
178
181
|
}
|
179
182
|
}
|
183
|
+
|
184
|
+
async requestTransactionStatus(transactionHash: string, peerId: string) {
|
185
|
+
try {
|
186
|
+
return await this.transactionStatus.send(transactionHash, peerId);
|
187
|
+
} catch (error) {
|
188
|
+
console.log(error);
|
189
|
+
return null
|
190
|
+
}
|
191
|
+
}
|
180
192
|
}
|
181
193
|
|
182
194
|
export const protocol = new Protocol();
|
@@ -1,13 +1,12 @@
|
|
1
1
|
import { BaseTask } from "./BaseTask";
|
2
2
|
import Logger from '@/logger';
|
3
|
-
import packageJson from '../../package.json'
|
4
3
|
import { http } from "@/utils";
|
5
|
-
import
|
4
|
+
import spawn from 'await-spawn';
|
6
5
|
import config from "@/config";
|
7
|
-
|
6
|
+
import wait from "waait";
|
8
7
|
|
9
8
|
class AutoUpdateTask extends BaseTask {
|
10
|
-
pollIntervalMs: number = 60 * 1000
|
9
|
+
pollIntervalMs: number = 60 * 5 * 1000
|
11
10
|
|
12
11
|
constructor() {
|
13
12
|
super({
|
@@ -19,11 +18,15 @@ class AutoUpdateTask extends BaseTask {
|
|
19
18
|
return config.autoUpdate && !config.isLeadNode();
|
20
19
|
}
|
21
20
|
|
21
|
+
getCurrentVersion() {
|
22
|
+
return require('../../package.json').version
|
23
|
+
}
|
22
24
|
async pollHandler() {
|
23
25
|
|
24
26
|
const { data } = await http.get('https://registry.npmjs.org/@instadapp/interop-x')
|
25
27
|
|
26
28
|
const version = data['dist-tags'].latest
|
29
|
+
const currentVersion = this.getCurrentVersion()
|
27
30
|
|
28
31
|
if (version === currentVersion) {
|
29
32
|
return;
|
@@ -32,22 +35,25 @@ class AutoUpdateTask extends BaseTask {
|
|
32
35
|
this.logger.warn(`New version ${version} available.`)
|
33
36
|
|
34
37
|
|
35
|
-
|
38
|
+
await spawn('npm', ['-g', 'install', '@instadapp/interop-x', '-f']);
|
36
39
|
|
37
|
-
update.on("close", () => {
|
38
|
-
this.logger.warn(`Installed version ${version}`)
|
39
|
-
this.logger.warn(`Restarting...`)
|
40
40
|
|
41
|
-
|
42
|
-
cwd: process.cwd(),
|
43
|
-
detached: true,
|
44
|
-
stdio: "inherit"
|
45
|
-
});
|
41
|
+
await wait(5000)
|
46
42
|
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
}
|
43
|
+
if (currentVersion === this.getCurrentVersion()) {
|
44
|
+
this.logger.warn(`failed to install ${version}, retrying in 5 minutes`)
|
45
|
+
return;
|
46
|
+
}
|
47
|
+
|
48
|
+
this.logger.warn(`Installed version ${version}`)
|
49
|
+
this.logger.warn(`Restarting...`)
|
50
|
+
|
51
|
+
spawn(process.argv[0], process.argv.slice(1), {
|
52
|
+
cwd: process.cwd(),
|
53
|
+
stdio: "inherit"
|
54
|
+
});
|
55
|
+
|
56
|
+
process.exit()
|
51
57
|
}
|
52
58
|
}
|
53
59
|
|
package/src/tasks/BaseTask.ts
CHANGED
@@ -19,6 +19,7 @@ export class BaseTask extends EventEmitter implements IBaseTask {
|
|
19
19
|
started: boolean = false
|
20
20
|
pollIntervalMs: number = 10 * 1000
|
21
21
|
leadNodeOnly: boolean = false
|
22
|
+
exceptLeadNode: boolean = false
|
22
23
|
|
23
24
|
public constructor({ logger }: { logger?: Logger }) {
|
24
25
|
super()
|
@@ -45,11 +46,15 @@ export class BaseTask extends EventEmitter implements IBaseTask {
|
|
45
46
|
}
|
46
47
|
|
47
48
|
prePollHandler(): boolean {
|
48
|
-
if (
|
49
|
-
return
|
49
|
+
if (this.exceptLeadNode) {
|
50
|
+
return !config.isLeadNode();
|
50
51
|
}
|
51
52
|
|
52
|
-
|
53
|
+
if (this.leadNodeOnly) {
|
54
|
+
return config.isLeadNode()
|
55
|
+
}
|
56
|
+
|
57
|
+
return true
|
53
58
|
}
|
54
59
|
|
55
60
|
async pollHandler() {
|
@@ -0,0 +1,65 @@
|
|
1
|
+
import { BaseTask } from "../BaseTask";
|
2
|
+
import Logger from '@/logger';
|
3
|
+
import config from "@/config";
|
4
|
+
import { peerPool, protocol } from "@/net";
|
5
|
+
import { Transaction } from "@/db";
|
6
|
+
import { Op } from "sequelize";
|
7
|
+
|
8
|
+
class SyncTransactionStatusTask extends BaseTask {
|
9
|
+
pollIntervalMs: number = 60 * 1000
|
10
|
+
exceptLeadNode: boolean = true;
|
11
|
+
|
12
|
+
constructor() {
|
13
|
+
super({
|
14
|
+
logger: new Logger("SyncTransactionStatusTask"),
|
15
|
+
})
|
16
|
+
}
|
17
|
+
|
18
|
+
async pollHandler() {
|
19
|
+
// if transaction is pending for more than 1 hour, check lead node for status
|
20
|
+
const leadNode = peerPool.getLeadPeer();
|
21
|
+
|
22
|
+
if (!leadNode) {
|
23
|
+
return;
|
24
|
+
}
|
25
|
+
|
26
|
+
const transaction = await Transaction.findOne({
|
27
|
+
where: {
|
28
|
+
status: 'pending',
|
29
|
+
sourceCreatedAt: {
|
30
|
+
[Op.gte]: new Date(Date.now() - 60 * 60 * 1000),
|
31
|
+
},
|
32
|
+
}
|
33
|
+
})
|
34
|
+
|
35
|
+
if (!transaction) {
|
36
|
+
return;
|
37
|
+
}
|
38
|
+
|
39
|
+
this.logger.info(`Requesting transaction status for ${transaction.transactionHash}`)
|
40
|
+
|
41
|
+
const transactionStatus = await protocol.requestTransactionStatus(transaction.transactionHash, leadNode.id);
|
42
|
+
|
43
|
+
if (!transactionStatus) {
|
44
|
+
return;
|
45
|
+
}
|
46
|
+
|
47
|
+
this.logger.info(`Received transaction status for ${transaction.transactionHash}`)
|
48
|
+
|
49
|
+
transaction.sourceStatus = transactionStatus.sourceStatus
|
50
|
+
transaction.sourceTransactionHash = transactionStatus.sourceTransactionHash
|
51
|
+
transaction.sourceErrors = transactionStatus.sourceErrors
|
52
|
+
|
53
|
+
transaction.targetStatus = transactionStatus.targetStatus
|
54
|
+
transaction.targetTransactionHash = transactionStatus.targetTransactionHash
|
55
|
+
transaction.targetErrors = transactionStatus.targetErrors
|
56
|
+
|
57
|
+
transaction.status = transactionStatus.status
|
58
|
+
|
59
|
+
await transaction.save()
|
60
|
+
|
61
|
+
this.logger.info(`Updated transaction status for ${transaction.transactionHash}`)
|
62
|
+
}
|
63
|
+
}
|
64
|
+
|
65
|
+
export default SyncTransactionStatusTask;
|
package/src/tasks/index.ts
CHANGED
@@ -5,10 +5,12 @@ import InteropXGatewaySyncDepositEvents from "./InteropXGateway/SyncDepositEvent
|
|
5
5
|
import InteropBridgeSyncWithdrawEvents from "./InteropBridge/SyncWithdrawEvents";
|
6
6
|
import InteropBridgeProcessWithdrawEvents from "./InteropBridge/ProcessWithdrawEvents";
|
7
7
|
import AutoUpdateTask from "./AutoUpdateTask";
|
8
|
+
import SyncTransactionStatusTask from "./Transactions/SyncTransactionStatusTask";
|
8
9
|
|
9
10
|
export class Tasks {
|
10
11
|
|
11
12
|
tasks: BaseTask[] = [
|
13
|
+
new SyncTransactionStatusTask(),
|
12
14
|
new AutoUpdateTask(),
|
13
15
|
|
14
16
|
new InteropXGatewaySyncDepositEvents({
|