@bsv/wallet-toolbox-client 1.2.11 → 1.2.12
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/out/src/monitor/Monitor.d.ts.map +1 -1
- package/out/src/monitor/Monitor.js +8 -2
- package/out/src/monitor/Monitor.js.map +1 -1
- package/out/src/monitor/tasks/TaskCheckForProofs.d.ts +20 -20
- package/out/src/monitor/tasks/TaskCheckForProofs.d.ts.map +1 -1
- package/out/src/monitor/tasks/TaskCheckForProofs.js +131 -130
- package/out/src/monitor/tasks/TaskCheckForProofs.js.map +1 -1
- package/out/src/monitor/tasks/TaskCheckNoSends.d.ts +33 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.d.ts.map +1 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.js +65 -0
- package/out/src/monitor/tasks/TaskCheckNoSends.js.map +1 -0
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Monitor.d.ts","sourceRoot":"","sources":["../../../../src/monitor/Monitor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAQ,QAAQ,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAA;AAC3E,OAAO,EAAE,WAAW,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAA;AAChF,OAAO,EAAa,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAM9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;
|
|
1
|
+
{"version":3,"file":"Monitor.d.ts","sourceRoot":"","sources":["../../../../src/monitor/Monitor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAQ,QAAQ,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAA;AAC3E,OAAO,EAAE,WAAW,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAA;AAChF,OAAO,EAAa,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAM9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AAM7D,MAAM,MAAM,cAAc,GAAG,oBAAoB,CAAA;AAIjD,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,GAAG,CAAC,KAAK,CAAA;IAEhB,QAAQ,EAAE,QAAQ,CAAA;IAElB,OAAO,EAAE,cAAc,CAAA;IAEvB,WAAW,EAAE,wBAAwB,CAAA;IAErC;;OAEG;IACH,iCAAiC,EAAE,MAAM,CAAA;IAEzC,gBAAgB,EAAE,MAAM,CAAA;IAExB,cAAc,EAAE,MAAM,CAAA;IAEtB,yBAAyB,EAAE,MAAM,CAAA;IAEjC,yBAAyB,EAAE,MAAM,CAAA;CAClC;AAED;;;GAGG;AACH,qBAAa,OAAO;IAClB,MAAM,CAAC,iCAAiC,CACtC,KAAK,EAAE,GAAG,CAAC,KAAK,EAChB,OAAO,EAAE,cAAc,EACvB,QAAQ,CAAC,EAAE,QAAQ,GAClB,cAAc;IAiBjB,OAAO,EAAE,cAAc,CAAA;IACvB,QAAQ,EAAE,QAAQ,CAAA;IAClB,KAAK,EAAE,GAAG,CAAC,KAAK,CAAA;IAChB,OAAO,EAAE,cAAc,CAAA;IACvB,WAAW,EAAE,wBAAwB,CAAA;gBAEzB,OAAO,EAAE,cAAc;IAQnC,SAAS,SAAO;IAChB,SAAS,SAAsB;IAC/B,OAAO,SAAsB;IAC7B,MAAM,SAAoB;IAC1B,OAAO,SAAkB;IACzB;;OAEG;IACH,MAAM,EAAE,iBAAiB,EAAE,CAAK;IAChC;;OAEG;IACH,WAAW,EAAE,iBAAiB,EAAE,CAAK;IACrC,aAAa,UAAQ;IAErB,kBAAkB,EAAE,eAAe,CAOlC;IAED,kBAAkB,IAAI,IAAI;IAa1B;;;OAGG;IACH,eAAe,IAAI,IAAI;IAavB;;;OAGG;IACH,iBAAiB,IAAI,IAAI;IAazB,OAAO,CAAC,IAAI,EAAE,iBAAiB,GAAG,IAAI;IAMtC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAIxB,yBAAyB,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ1C,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAWtC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAmD9B,cAAc,EAAE,OAAO,CAAO;IAExB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAY3B,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAY9D,SAAS,IAAI,IAAI;IAIjB,aAAa,EAAE,WAAW,GAAG,SAAS,CAAA;IACtC,iBAAiB,EAAE,IAAI,GAAG,SAAS,CAAA;IAEnC;;;;;;OAMG;IACH,qBAAqB,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IAShD;;;;;;;;;OASG;IAEH,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,GAAG,IAAI;CAG5E"}
|
|
@@ -11,6 +11,7 @@ const TaskSendWaiting_1 = require("./tasks/TaskSendWaiting");
|
|
|
11
11
|
const TaskClock_1 = require("./tasks/TaskClock");
|
|
12
12
|
const TaskNewHeader_1 = require("./tasks/TaskNewHeader");
|
|
13
13
|
const TaskUnFail_1 = require("./tasks/TaskUnFail");
|
|
14
|
+
const TaskCheckNoSends_1 = require("./tasks/TaskCheckNoSends");
|
|
14
15
|
/**
|
|
15
16
|
* Background task to make sure transactions are processed, transaction proofs are received and propagated,
|
|
16
17
|
* and potentially that reorgs update proofs that were already received.
|
|
@@ -70,6 +71,7 @@ class Monitor {
|
|
|
70
71
|
this._otherTasks.push(new TaskReviewStatus_1.TaskReviewStatus(this));
|
|
71
72
|
this._otherTasks.push(new TaskSendWaiting_1.TaskSendWaiting(this));
|
|
72
73
|
this._otherTasks.push(new TaskCheckForProofs_1.TaskCheckForProofs(this));
|
|
74
|
+
this._otherTasks.push(new TaskCheckNoSends_1.TaskCheckNoSends(this));
|
|
73
75
|
this._otherTasks.push(new TaskFailAbandoned_1.TaskFailAbandoned(this));
|
|
74
76
|
this._otherTasks.push(new TaskSyncWhenIdle_1.TaskSyncWhenIdle(this));
|
|
75
77
|
}
|
|
@@ -82,8 +84,10 @@ class Monitor {
|
|
|
82
84
|
this._tasks.push(new TaskNewHeader_1.TaskNewHeader(this));
|
|
83
85
|
this._tasks.push(new TaskSendWaiting_1.TaskSendWaiting(this, 8 * this.oneSecond, 7 * this.oneSecond)); // Check every 8 seconds but must be 7 seconds old
|
|
84
86
|
this._tasks.push(new TaskCheckForProofs_1.TaskCheckForProofs(this, 2 * this.oneHour)); // Every two hours if no block found
|
|
87
|
+
this._tasks.push(new TaskCheckNoSends_1.TaskCheckNoSends(this));
|
|
85
88
|
this._tasks.push(new TaskFailAbandoned_1.TaskFailAbandoned(this, 8 * this.oneMinute));
|
|
86
|
-
|
|
89
|
+
// No purging until invalid transactions are really invalid...
|
|
90
|
+
//this._tasks.push(new TaskPurge(this, this.defaultPurgeParams, 6 * this.oneHour))
|
|
87
91
|
this._tasks.push(new TaskReviewStatus_1.TaskReviewStatus(this));
|
|
88
92
|
this._tasks.push(new TaskUnFail_1.TaskUnFail(this));
|
|
89
93
|
}
|
|
@@ -96,8 +100,10 @@ class Monitor {
|
|
|
96
100
|
this._tasks.push(new TaskNewHeader_1.TaskNewHeader(this));
|
|
97
101
|
this._tasks.push(new TaskSendWaiting_1.TaskSendWaiting(this, 8 * this.oneSecond, 7 * this.oneSecond)); // Check every 8 seconds but must be 7 seconds old
|
|
98
102
|
this._tasks.push(new TaskCheckForProofs_1.TaskCheckForProofs(this, 2 * this.oneHour)); // Every two hours if no block found
|
|
103
|
+
this._tasks.push(new TaskCheckNoSends_1.TaskCheckNoSends(this));
|
|
99
104
|
this._tasks.push(new TaskFailAbandoned_1.TaskFailAbandoned(this, 8 * this.oneMinute));
|
|
100
|
-
|
|
105
|
+
// No purging until invalid transactions are really invalid...
|
|
106
|
+
//this._tasks.push(new TaskPurge(this, this.defaultPurgeParams, 6 * this.oneHour))
|
|
101
107
|
this._tasks.push(new TaskReviewStatus_1.TaskReviewStatus(this));
|
|
102
108
|
this._tasks.push(new TaskUnFail_1.TaskUnFail(this));
|
|
103
109
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Monitor.js","sourceRoot":"","sources":["../../../../src/monitor/Monitor.ts"],"names":[],"mappings":";;;AAAA,kDAA2E;AAE3E,iDAA8D;AAC9D,+DAA2D;AAC3D,+DAA2D;AAC3D,iEAA6D;AAC7D,mEAA+D;AAC/D,6DAAyD;AAEzD,iDAA6C;AAC7C,yDAAsE;AACtE,mDAA+C;
|
|
1
|
+
{"version":3,"file":"Monitor.js","sourceRoot":"","sources":["../../../../src/monitor/Monitor.ts"],"names":[],"mappings":"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"}
|
|
@@ -29,25 +29,25 @@ export declare class TaskCheckForProofs extends WalletMonitorTask {
|
|
|
29
29
|
run: boolean;
|
|
30
30
|
};
|
|
31
31
|
runTask(): Promise<string>;
|
|
32
|
-
/**
|
|
33
|
-
* Process an array of table.ProvenTxReq (typically with status 'unmined' or 'unknown')
|
|
34
|
-
*
|
|
35
|
-
* If req is invalid, set status 'invalid'
|
|
36
|
-
*
|
|
37
|
-
* Verify the requests are valid, lookup proofs or updated transaction status using the array of getProofServices,
|
|
38
|
-
*
|
|
39
|
-
* When proofs are found, create new ProvenTxApi records and transition the requests' status to 'unconfirmed' or 'notifying',
|
|
40
|
-
* depending on chaintracks succeeding on proof verification.
|
|
41
|
-
*
|
|
42
|
-
* Increments attempts if proofs where requested.
|
|
43
|
-
*
|
|
44
|
-
* @param reqs
|
|
45
|
-
* @returns reqs partitioned by status
|
|
46
|
-
*/
|
|
47
|
-
getProofs(reqs: TableProvenTxReq[], indent?: number, countsAsAttempt?: boolean, ignoreStatus?: boolean): Promise<{
|
|
48
|
-
proven: TableProvenTxReq[];
|
|
49
|
-
invalid: TableProvenTxReq[];
|
|
50
|
-
log: string;
|
|
51
|
-
}>;
|
|
52
32
|
}
|
|
33
|
+
/**
|
|
34
|
+
* Process an array of table.ProvenTxReq (typically with status 'unmined' or 'unknown')
|
|
35
|
+
*
|
|
36
|
+
* If req is invalid, set status 'invalid'
|
|
37
|
+
*
|
|
38
|
+
* Verify the requests are valid, lookup proofs or updated transaction status using the array of getProofServices,
|
|
39
|
+
*
|
|
40
|
+
* When proofs are found, create new ProvenTxApi records and transition the requests' status to 'unconfirmed' or 'notifying',
|
|
41
|
+
* depending on chaintracks succeeding on proof verification.
|
|
42
|
+
*
|
|
43
|
+
* Increments attempts if proofs where requested.
|
|
44
|
+
*
|
|
45
|
+
* @param reqs
|
|
46
|
+
* @returns reqs partitioned by status
|
|
47
|
+
*/
|
|
48
|
+
export declare function getProofs(task: WalletMonitorTask, reqs: TableProvenTxReq[], indent?: number, countsAsAttempt?: boolean, ignoreStatus?: boolean): Promise<{
|
|
49
|
+
proven: TableProvenTxReq[];
|
|
50
|
+
invalid: TableProvenTxReq[];
|
|
51
|
+
log: string;
|
|
52
|
+
}>;
|
|
53
53
|
//# sourceMappingURL=TaskCheckForProofs.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TaskCheckForProofs.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckForProofs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACvH,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD;;;;;;;;;;;GAWG;
|
|
1
|
+
{"version":3,"file":"TaskCheckForProofs.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckForProofs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACvH,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD;;;;;;;;;;;GAWG;AACH,qBAAa,kBAAmB,SAAQ,iBAAiB;IAW9C,YAAY;IAVrB,MAAM,CAAC,QAAQ,SAAmB;IAElC;;;OAGG;IACH,MAAM,CAAC,QAAQ,UAAQ;gBAGrB,OAAO,EAAE,OAAO,EACT,YAAY,SAAI;IAKzB;;OAEG;IACH,OAAO,CAAC,kBAAkB,EAAE,MAAM,GAAG;QAAE,GAAG,EAAE,OAAO,CAAA;KAAE;IAQ/C,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;CAuBjC;AAED;;;;;;;;;;;;;;GAcG;AACH,wBAAsB,SAAS,CAC7B,IAAI,EAAE,iBAAiB,EACvB,IAAI,EAAE,gBAAgB,EAAE,EACxB,MAAM,SAAI,EACV,eAAe,UAAQ,EACvB,YAAY,UAAQ,GACnB,OAAO,CAAC;IACT,MAAM,EAAE,gBAAgB,EAAE,CAAA;IAC1B,OAAO,EAAE,gBAAgB,EAAE,CAAA;IAC3B,GAAG,EAAE,MAAM,CAAA;CACZ,CAAC,CA6HD"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.TaskCheckForProofs = void 0;
|
|
4
|
+
exports.getProofs = getProofs;
|
|
4
5
|
const index_client_1 = require("../../index.client");
|
|
5
6
|
const WalletMonitorTask_1 = require("./WalletMonitorTask");
|
|
6
7
|
/**
|
|
@@ -38,13 +39,13 @@ class TaskCheckForProofs extends WalletMonitorTask_1.WalletMonitorTask {
|
|
|
38
39
|
for (;;) {
|
|
39
40
|
const reqs = await this.storage.findProvenTxReqs({
|
|
40
41
|
partial: {},
|
|
41
|
-
status: ['callback', 'unmined', '
|
|
42
|
+
status: ['callback', 'unmined', 'sending', 'unknown', 'unconfirmed'],
|
|
42
43
|
paged: { limit, offset }
|
|
43
44
|
});
|
|
44
45
|
if (reqs.length === 0)
|
|
45
46
|
break;
|
|
46
|
-
log += `${reqs.length} reqs with status 'callback', 'unmined', '
|
|
47
|
-
const r = await
|
|
47
|
+
log += `${reqs.length} reqs with status 'callback', 'unmined', 'sending', 'unknown', or 'unconfirmed'\n`;
|
|
48
|
+
const r = await getProofs(this, reqs, 2, countsAsAttempt);
|
|
48
49
|
log += `${r.log}\n`;
|
|
49
50
|
//console.log(log);
|
|
50
51
|
if (reqs.length < limit)
|
|
@@ -53,133 +54,6 @@ class TaskCheckForProofs extends WalletMonitorTask_1.WalletMonitorTask {
|
|
|
53
54
|
}
|
|
54
55
|
return log;
|
|
55
56
|
}
|
|
56
|
-
/**
|
|
57
|
-
* Process an array of table.ProvenTxReq (typically with status 'unmined' or 'unknown')
|
|
58
|
-
*
|
|
59
|
-
* If req is invalid, set status 'invalid'
|
|
60
|
-
*
|
|
61
|
-
* Verify the requests are valid, lookup proofs or updated transaction status using the array of getProofServices,
|
|
62
|
-
*
|
|
63
|
-
* When proofs are found, create new ProvenTxApi records and transition the requests' status to 'unconfirmed' or 'notifying',
|
|
64
|
-
* depending on chaintracks succeeding on proof verification.
|
|
65
|
-
*
|
|
66
|
-
* Increments attempts if proofs where requested.
|
|
67
|
-
*
|
|
68
|
-
* @param reqs
|
|
69
|
-
* @returns reqs partitioned by status
|
|
70
|
-
*/
|
|
71
|
-
async getProofs(reqs, indent = 0, countsAsAttempt = false, ignoreStatus = false) {
|
|
72
|
-
const proven = [];
|
|
73
|
-
const invalid = [];
|
|
74
|
-
let log = '';
|
|
75
|
-
for (const reqApi of reqs) {
|
|
76
|
-
log += ' '.repeat(indent);
|
|
77
|
-
log += `reqId ${reqApi.provenTxReqId} txid ${reqApi.txid}: `;
|
|
78
|
-
if (!ignoreStatus &&
|
|
79
|
-
reqApi.status !== 'callback' &&
|
|
80
|
-
reqApi.status !== 'unmined' &&
|
|
81
|
-
reqApi.status !== 'unknown' &&
|
|
82
|
-
reqApi.status !== 'unconfirmed' &&
|
|
83
|
-
reqApi.status !== 'nosend' &&
|
|
84
|
-
reqApi.status !== 'sending') {
|
|
85
|
-
log += `status of '${reqApi.status}' is not ready to be proven.\n`;
|
|
86
|
-
continue;
|
|
87
|
-
}
|
|
88
|
-
const req = new index_client_1.EntityProvenTxReq(reqApi);
|
|
89
|
-
if (Number.isInteger(req.provenTxId)) {
|
|
90
|
-
log += `Already linked to provenTxId ${req.provenTxId}.\n`;
|
|
91
|
-
req.notified = false;
|
|
92
|
-
req.status = 'completed';
|
|
93
|
-
await req.updateStorageDynamicProperties(this.storage);
|
|
94
|
-
proven.push(reqApi);
|
|
95
|
-
continue;
|
|
96
|
-
}
|
|
97
|
-
log += '\n';
|
|
98
|
-
let reqIsValid = false;
|
|
99
|
-
if (req.rawTx) {
|
|
100
|
-
const txid = (0, index_client_1.asString)((0, index_client_1.doubleSha256BE)(req.rawTx));
|
|
101
|
-
if (txid === req.txid)
|
|
102
|
-
reqIsValid = true;
|
|
103
|
-
}
|
|
104
|
-
if (!reqIsValid) {
|
|
105
|
-
log += ` rawTx doesn't hash to txid. status => invalid.\n`;
|
|
106
|
-
req.notified = false;
|
|
107
|
-
req.status = 'invalid';
|
|
108
|
-
await req.updateStorageDynamicProperties(this.storage);
|
|
109
|
-
invalid.push(reqApi);
|
|
110
|
-
continue;
|
|
111
|
-
}
|
|
112
|
-
const limit = this.monitor.chain === 'main'
|
|
113
|
-
? this.monitor.options.unprovenAttemptsLimitMain
|
|
114
|
-
: this.monitor.options.unprovenAttemptsLimitTest;
|
|
115
|
-
if (!ignoreStatus && req.attempts > limit) {
|
|
116
|
-
log += ` too many failed attempts ${req.attempts}\n`;
|
|
117
|
-
req.notified = false;
|
|
118
|
-
req.status = 'invalid';
|
|
119
|
-
await req.updateStorageDynamicProperties(this.storage);
|
|
120
|
-
invalid.push(reqApi);
|
|
121
|
-
continue;
|
|
122
|
-
}
|
|
123
|
-
const since = new Date();
|
|
124
|
-
let r;
|
|
125
|
-
let ptx;
|
|
126
|
-
// External services will try multiple providers until one returns a proof,
|
|
127
|
-
// or they all fail.
|
|
128
|
-
// There may also be an array of proofs to consider when a transaction
|
|
129
|
-
// is recently mined and appears in orphan blocks in addition to active chain blocks.
|
|
130
|
-
// Since orphan blocks can end up on chain again, multiple proofs has value.
|
|
131
|
-
//
|
|
132
|
-
// On failure, there may be a mapi response, or an error.
|
|
133
|
-
//
|
|
134
|
-
// The proofs returned are considered sequentially, validating and chaintracks confirming.
|
|
135
|
-
//
|
|
136
|
-
// If a good proof is found, proceed to using it.
|
|
137
|
-
//
|
|
138
|
-
// When all received proofs fail, force a bump to the next service provider and try
|
|
139
|
-
// one more time.
|
|
140
|
-
//
|
|
141
|
-
r = await this.monitor.services.getMerklePath(req.txid);
|
|
142
|
-
ptx = await index_client_1.EntityProvenTx.fromReq(req, r, countsAsAttempt && req.status !== 'nosend');
|
|
143
|
-
if (ptx) {
|
|
144
|
-
// We have a merklePath proof for the request (and a block header)
|
|
145
|
-
await req.updateStorageDynamicProperties(this.storage);
|
|
146
|
-
await req.refreshFromStorage(this.storage);
|
|
147
|
-
const { provenTxReqId, status, txid, attempts, history } = req.toApi();
|
|
148
|
-
const { index, height, blockHash, merklePath, merkleRoot } = ptx.toApi();
|
|
149
|
-
const r = await this.storage.runAsStorageProvider(async (sp) => {
|
|
150
|
-
return await sp.updateProvenTxReqWithNewProvenTx({
|
|
151
|
-
provenTxReqId,
|
|
152
|
-
status,
|
|
153
|
-
txid,
|
|
154
|
-
attempts,
|
|
155
|
-
history,
|
|
156
|
-
index,
|
|
157
|
-
height,
|
|
158
|
-
blockHash,
|
|
159
|
-
merklePath,
|
|
160
|
-
merkleRoot
|
|
161
|
-
});
|
|
162
|
-
});
|
|
163
|
-
req.status = r.status;
|
|
164
|
-
req.apiHistory = r.history;
|
|
165
|
-
req.provenTxId = r.provenTxId;
|
|
166
|
-
req.notified = true;
|
|
167
|
-
}
|
|
168
|
-
else {
|
|
169
|
-
if (countsAsAttempt && req.status !== 'nosend') {
|
|
170
|
-
req.attempts++;
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
await req.updateStorageDynamicProperties(this.storage);
|
|
174
|
-
await req.refreshFromStorage(this.storage);
|
|
175
|
-
log += req.historyPretty(since, indent + 2) + '\n';
|
|
176
|
-
if (req.status === 'completed')
|
|
177
|
-
proven.push(req.api);
|
|
178
|
-
if (req.status === 'invalid')
|
|
179
|
-
invalid.push(req.api);
|
|
180
|
-
}
|
|
181
|
-
return { proven, invalid, log };
|
|
182
|
-
}
|
|
183
57
|
}
|
|
184
58
|
exports.TaskCheckForProofs = TaskCheckForProofs;
|
|
185
59
|
TaskCheckForProofs.taskName = 'CheckForProofs';
|
|
@@ -188,4 +62,131 @@ TaskCheckForProofs.taskName = 'CheckForProofs';
|
|
|
188
62
|
* listener can set this true to cause
|
|
189
63
|
*/
|
|
190
64
|
TaskCheckForProofs.checkNow = false;
|
|
65
|
+
/**
|
|
66
|
+
* Process an array of table.ProvenTxReq (typically with status 'unmined' or 'unknown')
|
|
67
|
+
*
|
|
68
|
+
* If req is invalid, set status 'invalid'
|
|
69
|
+
*
|
|
70
|
+
* Verify the requests are valid, lookup proofs or updated transaction status using the array of getProofServices,
|
|
71
|
+
*
|
|
72
|
+
* When proofs are found, create new ProvenTxApi records and transition the requests' status to 'unconfirmed' or 'notifying',
|
|
73
|
+
* depending on chaintracks succeeding on proof verification.
|
|
74
|
+
*
|
|
75
|
+
* Increments attempts if proofs where requested.
|
|
76
|
+
*
|
|
77
|
+
* @param reqs
|
|
78
|
+
* @returns reqs partitioned by status
|
|
79
|
+
*/
|
|
80
|
+
async function getProofs(task, reqs, indent = 0, countsAsAttempt = false, ignoreStatus = false) {
|
|
81
|
+
const proven = [];
|
|
82
|
+
const invalid = [];
|
|
83
|
+
let log = '';
|
|
84
|
+
for (const reqApi of reqs) {
|
|
85
|
+
log += ' '.repeat(indent);
|
|
86
|
+
log += `reqId ${reqApi.provenTxReqId} txid ${reqApi.txid}: `;
|
|
87
|
+
if (!ignoreStatus &&
|
|
88
|
+
reqApi.status !== 'callback' &&
|
|
89
|
+
reqApi.status !== 'unmined' &&
|
|
90
|
+
reqApi.status !== 'unknown' &&
|
|
91
|
+
reqApi.status !== 'unconfirmed' &&
|
|
92
|
+
reqApi.status !== 'nosend' &&
|
|
93
|
+
reqApi.status !== 'sending') {
|
|
94
|
+
log += `status of '${reqApi.status}' is not ready to be proven.\n`;
|
|
95
|
+
continue;
|
|
96
|
+
}
|
|
97
|
+
const req = new index_client_1.EntityProvenTxReq(reqApi);
|
|
98
|
+
if (Number.isInteger(req.provenTxId)) {
|
|
99
|
+
log += `Already linked to provenTxId ${req.provenTxId}.\n`;
|
|
100
|
+
req.notified = false;
|
|
101
|
+
req.status = 'completed';
|
|
102
|
+
await req.updateStorageDynamicProperties(task.storage);
|
|
103
|
+
proven.push(reqApi);
|
|
104
|
+
continue;
|
|
105
|
+
}
|
|
106
|
+
log += '\n';
|
|
107
|
+
let reqIsValid = false;
|
|
108
|
+
if (req.rawTx) {
|
|
109
|
+
const txid = (0, index_client_1.asString)((0, index_client_1.doubleSha256BE)(req.rawTx));
|
|
110
|
+
if (txid === req.txid)
|
|
111
|
+
reqIsValid = true;
|
|
112
|
+
}
|
|
113
|
+
if (!reqIsValid) {
|
|
114
|
+
log += ` rawTx doesn't hash to txid. status => invalid.\n`;
|
|
115
|
+
req.notified = false;
|
|
116
|
+
req.status = 'invalid';
|
|
117
|
+
await req.updateStorageDynamicProperties(task.storage);
|
|
118
|
+
invalid.push(reqApi);
|
|
119
|
+
continue;
|
|
120
|
+
}
|
|
121
|
+
const limit = task.monitor.chain === 'main'
|
|
122
|
+
? task.monitor.options.unprovenAttemptsLimitMain
|
|
123
|
+
: task.monitor.options.unprovenAttemptsLimitTest;
|
|
124
|
+
if (!ignoreStatus && req.attempts > limit) {
|
|
125
|
+
log += ` too many failed attempts ${req.attempts}\n`;
|
|
126
|
+
req.notified = false;
|
|
127
|
+
req.status = 'invalid';
|
|
128
|
+
await req.updateStorageDynamicProperties(task.storage);
|
|
129
|
+
invalid.push(reqApi);
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
const since = new Date();
|
|
133
|
+
let r;
|
|
134
|
+
let ptx;
|
|
135
|
+
// External services will try multiple providers until one returns a proof,
|
|
136
|
+
// or they all fail.
|
|
137
|
+
// There may also be an array of proofs to consider when a transaction
|
|
138
|
+
// is recently mined and appears in orphan blocks in addition to active chain blocks.
|
|
139
|
+
// Since orphan blocks can end up on chain again, multiple proofs has value.
|
|
140
|
+
//
|
|
141
|
+
// On failure, there may be a mapi response, or an error.
|
|
142
|
+
//
|
|
143
|
+
// The proofs returned are considered sequentially, validating and chaintracks confirming.
|
|
144
|
+
//
|
|
145
|
+
// If a good proof is found, proceed to using it.
|
|
146
|
+
//
|
|
147
|
+
// When all received proofs fail, force a bump to the next service provider and try
|
|
148
|
+
// one more time.
|
|
149
|
+
//
|
|
150
|
+
r = await task.monitor.services.getMerklePath(req.txid);
|
|
151
|
+
ptx = await index_client_1.EntityProvenTx.fromReq(req, r, countsAsAttempt && req.status !== 'nosend');
|
|
152
|
+
if (ptx) {
|
|
153
|
+
// We have a merklePath proof for the request (and a block header)
|
|
154
|
+
await req.updateStorageDynamicProperties(task.storage);
|
|
155
|
+
await req.refreshFromStorage(task.storage);
|
|
156
|
+
const { provenTxReqId, status, txid, attempts, history } = req.toApi();
|
|
157
|
+
const { index, height, blockHash, merklePath, merkleRoot } = ptx.toApi();
|
|
158
|
+
const r = await task.storage.runAsStorageProvider(async (sp) => {
|
|
159
|
+
return await sp.updateProvenTxReqWithNewProvenTx({
|
|
160
|
+
provenTxReqId,
|
|
161
|
+
status,
|
|
162
|
+
txid,
|
|
163
|
+
attempts,
|
|
164
|
+
history,
|
|
165
|
+
index,
|
|
166
|
+
height,
|
|
167
|
+
blockHash,
|
|
168
|
+
merklePath,
|
|
169
|
+
merkleRoot
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
req.status = r.status;
|
|
173
|
+
req.apiHistory = r.history;
|
|
174
|
+
req.provenTxId = r.provenTxId;
|
|
175
|
+
req.notified = true;
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
if (countsAsAttempt && req.status !== 'nosend') {
|
|
179
|
+
req.attempts++;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
await req.updateStorageDynamicProperties(task.storage);
|
|
183
|
+
await req.refreshFromStorage(task.storage);
|
|
184
|
+
log += req.historyPretty(since, indent + 2) + '\n';
|
|
185
|
+
if (req.status === 'completed')
|
|
186
|
+
proven.push(req.api);
|
|
187
|
+
if (req.status === 'invalid')
|
|
188
|
+
invalid.push(req.api);
|
|
189
|
+
}
|
|
190
|
+
return { proven, invalid, log };
|
|
191
|
+
}
|
|
191
192
|
//# sourceMappingURL=TaskCheckForProofs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TaskCheckForProofs.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckForProofs.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"TaskCheckForProofs.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckForProofs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Monitor } from '../Monitor';
|
|
2
|
+
import { WalletMonitorTask } from './WalletMonitorTask';
|
|
3
|
+
/**
|
|
4
|
+
* `TaskCheckNoSends` is a WalletMonitor task that retreives merkle proofs for
|
|
5
|
+
* 'nosend' transactions that MAY have been shared externally.
|
|
6
|
+
*
|
|
7
|
+
* Unlike intentionally processed transactions, 'nosend' transactions are fully valid
|
|
8
|
+
* transactions which have not been processed by the wallet.
|
|
9
|
+
*
|
|
10
|
+
* By default, this task runs once a day to check if any 'nosend' transaction has
|
|
11
|
+
* managed to get mined by some external process.
|
|
12
|
+
*
|
|
13
|
+
* If a proof is obtained and validated, a new ProvenTx record is created and
|
|
14
|
+
* the original ProvenTxReq status is advanced to 'notifying'.
|
|
15
|
+
*/
|
|
16
|
+
export declare class TaskCheckNoSends extends WalletMonitorTask {
|
|
17
|
+
triggerMsecs: number;
|
|
18
|
+
static taskName: string;
|
|
19
|
+
/**
|
|
20
|
+
* An external service such as the chaintracks new block header
|
|
21
|
+
* listener can set this true to cause
|
|
22
|
+
*/
|
|
23
|
+
static checkNow: boolean;
|
|
24
|
+
constructor(monitor: Monitor, triggerMsecs?: number);
|
|
25
|
+
/**
|
|
26
|
+
* Normally triggered by checkNow getting set by new block header found event from chaintracks
|
|
27
|
+
*/
|
|
28
|
+
trigger(nowMsecsSinceEpoch: number): {
|
|
29
|
+
run: boolean;
|
|
30
|
+
};
|
|
31
|
+
runTask(): Promise<string>;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=TaskCheckNoSends.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TaskCheckNoSends.d.ts","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckNoSends.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AAEpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD;;;;;;;;;;;;GAYG;AACH,qBAAa,gBAAiB,SAAQ,iBAAiB;IAW5C,YAAY;IAVrB,MAAM,CAAC,QAAQ,SAAiB;IAEhC;;;OAGG;IACH,MAAM,CAAC,QAAQ,UAAQ;gBAGrB,OAAO,EAAE,OAAO,EACT,YAAY,SAAqB;IAK1C;;OAEG;IACH,OAAO,CAAC,kBAAkB,EAAE,MAAM,GAAG;QAAE,GAAG,EAAE,OAAO,CAAA;KAAE;IAQ/C,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;CAuBjC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TaskCheckNoSends = void 0;
|
|
4
|
+
const TaskCheckForProofs_1 = require("./TaskCheckForProofs");
|
|
5
|
+
const WalletMonitorTask_1 = require("./WalletMonitorTask");
|
|
6
|
+
/**
|
|
7
|
+
* `TaskCheckNoSends` is a WalletMonitor task that retreives merkle proofs for
|
|
8
|
+
* 'nosend' transactions that MAY have been shared externally.
|
|
9
|
+
*
|
|
10
|
+
* Unlike intentionally processed transactions, 'nosend' transactions are fully valid
|
|
11
|
+
* transactions which have not been processed by the wallet.
|
|
12
|
+
*
|
|
13
|
+
* By default, this task runs once a day to check if any 'nosend' transaction has
|
|
14
|
+
* managed to get mined by some external process.
|
|
15
|
+
*
|
|
16
|
+
* If a proof is obtained and validated, a new ProvenTx record is created and
|
|
17
|
+
* the original ProvenTxReq status is advanced to 'notifying'.
|
|
18
|
+
*/
|
|
19
|
+
class TaskCheckNoSends extends WalletMonitorTask_1.WalletMonitorTask {
|
|
20
|
+
constructor(monitor, triggerMsecs = monitor.oneDay * 1) {
|
|
21
|
+
super(monitor, TaskCheckNoSends.taskName);
|
|
22
|
+
this.triggerMsecs = triggerMsecs;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Normally triggered by checkNow getting set by new block header found event from chaintracks
|
|
26
|
+
*/
|
|
27
|
+
trigger(nowMsecsSinceEpoch) {
|
|
28
|
+
return {
|
|
29
|
+
run: TaskCheckNoSends.checkNow ||
|
|
30
|
+
(this.triggerMsecs > 0 && nowMsecsSinceEpoch - this.lastRunMsecsSinceEpoch > this.triggerMsecs)
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
async runTask() {
|
|
34
|
+
let log = '';
|
|
35
|
+
const countsAsAttempt = TaskCheckNoSends.checkNow;
|
|
36
|
+
TaskCheckNoSends.checkNow = false;
|
|
37
|
+
const limit = 100;
|
|
38
|
+
let offset = 0;
|
|
39
|
+
for (;;) {
|
|
40
|
+
const reqs = await this.storage.findProvenTxReqs({
|
|
41
|
+
partial: {},
|
|
42
|
+
status: ['nosend'],
|
|
43
|
+
paged: { limit, offset }
|
|
44
|
+
});
|
|
45
|
+
if (reqs.length === 0)
|
|
46
|
+
break;
|
|
47
|
+
log += `${reqs.length} reqs with status 'nosend'\n`;
|
|
48
|
+
const r = await (0, TaskCheckForProofs_1.getProofs)(this, reqs, 2, countsAsAttempt);
|
|
49
|
+
log += `${r.log}\n`;
|
|
50
|
+
//console.log(log);
|
|
51
|
+
if (reqs.length < limit)
|
|
52
|
+
break;
|
|
53
|
+
offset += limit;
|
|
54
|
+
}
|
|
55
|
+
return log;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
exports.TaskCheckNoSends = TaskCheckNoSends;
|
|
59
|
+
TaskCheckNoSends.taskName = 'CheckNoSends';
|
|
60
|
+
/**
|
|
61
|
+
* An external service such as the chaintracks new block header
|
|
62
|
+
* listener can set this true to cause
|
|
63
|
+
*/
|
|
64
|
+
TaskCheckNoSends.checkNow = false;
|
|
65
|
+
//# sourceMappingURL=TaskCheckNoSends.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TaskCheckNoSends.js","sourceRoot":"","sources":["../../../../../src/monitor/tasks/TaskCheckNoSends.ts"],"names":[],"mappings":";;;AAEA,6DAAgD;AAChD,2DAAuD;AAEvD;;;;;;;;;;;;GAYG;AACH,MAAa,gBAAiB,SAAQ,qCAAiB;IASrD,YACE,OAAgB,EACT,eAAe,OAAO,CAAC,MAAM,GAAG,CAAC;QAExC,KAAK,CAAC,OAAO,EAAE,gBAAgB,CAAC,QAAQ,CAAC,CAAA;QAFlC,iBAAY,GAAZ,YAAY,CAAqB;IAG1C,CAAC;IAED;;OAEG;IACH,OAAO,CAAC,kBAA0B;QAChC,OAAO;YACL,GAAG,EACD,gBAAgB,CAAC,QAAQ;gBACzB,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,kBAAkB,GAAG,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,YAAY,CAAC;SAClG,CAAA;IACH,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,GAAG,GAAG,EAAE,CAAA;QACZ,MAAM,eAAe,GAAG,gBAAgB,CAAC,QAAQ,CAAA;QACjD,gBAAgB,CAAC,QAAQ,GAAG,KAAK,CAAA;QAEjC,MAAM,KAAK,GAAG,GAAG,CAAA;QACjB,IAAI,MAAM,GAAG,CAAC,CAAA;QACd,SAAS,CAAC;YACR,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC;gBAC/C,OAAO,EAAE,EAAE;gBACX,MAAM,EAAE,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;aACzB,CAAC,CAAA;YACF,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;gBAAE,MAAK;YAC5B,GAAG,IAAI,GAAG,IAAI,CAAC,MAAM,8BAA8B,CAAA;YACnD,MAAM,CAAC,GAAG,MAAM,IAAA,8BAAS,EAAC,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,eAAe,CAAC,CAAA;YACzD,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAA;YACnB,mBAAmB;YACnB,IAAI,IAAI,CAAC,MAAM,GAAG,KAAK;gBAAE,MAAK;YAC9B,MAAM,IAAI,KAAK,CAAA;QACjB,CAAC;QACD,OAAO,GAAG,CAAA;IACZ,CAAC;;AAjDH,4CAkDC;AAjDQ,yBAAQ,GAAG,cAAc,CAAA;AAEhC;;;GAGG;AACI,yBAAQ,GAAG,KAAK,CAAA"}
|