@rosen-bridge/tx-pot 1.0.3 → 2.0.0
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/CHANGELOG.md +27 -0
- package/README.md +8 -8
- package/dist/db/entities/transactionEntity.d.ts +15 -0
- package/dist/db/entities/{TransactionEntity.d.ts.map → transactionEntity.d.ts.map} +1 -1
- package/dist/db/entities/transactionEntity.js +81 -0
- package/dist/db/migrations/index.d.ts +3 -3
- package/dist/db/migrations/index.js +3 -3
- package/dist/db/migrations/postgres/1706350644686-migration.d.ts +4 -4
- package/dist/db/migrations/postgres/1706350644686-migration.d.ts.map +1 -1
- package/dist/db/migrations/postgres/1706350644686-migration.js +8 -8
- package/dist/db/migrations/sqlite/1706007154531-migration.d.ts +4 -4
- package/dist/db/migrations/sqlite/1706007154531-migration.d.ts.map +1 -1
- package/dist/db/migrations/sqlite/1706007154531-migration.js +8 -8
- package/dist/index.d.ts +4 -4
- package/dist/index.js +4 -4
- package/dist/network/abstractPotChainManager.d.ts +36 -0
- package/dist/network/{AbstractPotChainManager.d.ts.map → abstractPotChainManager.d.ts.map} +1 -1
- package/dist/network/{AbstractPotChainManager.js → abstractPotChainManager.js} +3 -2
- package/dist/transaction/txPot.d.ts +212 -0
- package/dist/transaction/txPot.d.ts.map +1 -0
- package/dist/transaction/{TxPot.js → txPot.js} +2 -2
- package/dist/transaction/types.d.ts +21 -24
- package/dist/transaction/types.d.ts.map +1 -1
- package/dist/transaction/types.js +13 -13
- package/dist/transaction/utils.d.ts +2 -4
- package/dist/transaction/utils.d.ts.map +1 -1
- package/dist/transaction/utils.js +48 -43
- package/package.json +25 -21
- package/.eslintignore +0 -1
- package/dist/db/entities/TransactionEntity.d.ts +0 -15
- package/dist/db/entities/TransactionEntity.js +0 -125
- package/dist/network/AbstractPotChainManager.d.ts +0 -39
- package/dist/transaction/TxPot.d.ts +0 -284
- package/dist/transaction/TxPot.d.ts.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/lib/db/entities/TransactionEntity.ts +0 -44
- package/lib/db/migrations/index.ts +0 -7
- package/lib/db/migrations/postgres/1706350644686-migration.ts +0 -31
- package/lib/db/migrations/sqlite/1706007154531-migration.ts +0 -31
- package/lib/index.ts +0 -5
- package/lib/network/AbstractPotChainManager.ts +0 -44
- package/lib/transaction/TxPot.ts +0 -728
- package/lib/transaction/types.ts +0 -46
- package/lib/transaction/utils.ts +0 -59
- package/tests/.gitkeep +0 -0
- package/tests/db/dataSource.mock.ts +0 -18
- package/tests/network/TestPotChainManager.ts +0 -23
- package/tests/transaction/TestTxPot.ts +0 -32
- package/tests/transaction/TxPot.spec.ts +0 -1881
- package/tests/transaction/testData.ts +0 -84
- package/tsconfig.build.json +0 -8
- package/tsconfig.build.tsbuildinfo +0 -1
- package/tsconfig.json +0 -9
- package/vitest.config.ts +0 -13
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,32 @@
|
|
|
1
1
|
# @rosen-bridge/tx-pot
|
|
2
2
|
|
|
3
|
+
## 2.0.0
|
|
4
|
+
|
|
5
|
+
### Major Changes
|
|
6
|
+
|
|
7
|
+
- Update node version to 22.18
|
|
8
|
+
|
|
9
|
+
### Minor Changes
|
|
10
|
+
|
|
11
|
+
- Update typeorm version to 0.3.26
|
|
12
|
+
|
|
13
|
+
### Patch Changes
|
|
14
|
+
|
|
15
|
+
- Update dependencies
|
|
16
|
+
- @rosen-bridge/abstract-logger@3.0.0
|
|
17
|
+
- @rosen-bridge/extended-typeorm@1.0.0
|
|
18
|
+
|
|
19
|
+
## 1.1.0
|
|
20
|
+
|
|
21
|
+
### Minor Changes
|
|
22
|
+
|
|
23
|
+
- Update versions of nodejs to 20.11 & typescript to 5.8
|
|
24
|
+
|
|
25
|
+
### Patch Changes
|
|
26
|
+
|
|
27
|
+
- Update dependencies
|
|
28
|
+
- @rosen-bridge/abstract-logger@2.1.0
|
|
29
|
+
|
|
3
30
|
## 1.0.3
|
|
4
31
|
|
|
5
32
|
### Patch Changes
|
package/README.md
CHANGED
|
@@ -135,7 +135,7 @@ await txPot.addTx(
|
|
|
135
135
|
'ergo',
|
|
136
136
|
'my-type',
|
|
137
137
|
1,
|
|
138
|
-
'your-serialized-tx'
|
|
138
|
+
'your-serialized-tx',
|
|
139
139
|
);
|
|
140
140
|
```
|
|
141
141
|
|
|
@@ -151,7 +151,7 @@ await txPot.addTx(
|
|
|
151
151
|
1,
|
|
152
152
|
'your-serialized-tx',
|
|
153
153
|
TransactionStatus.SIGNED,
|
|
154
|
-
1000000
|
|
154
|
+
1000000,
|
|
155
155
|
);
|
|
156
156
|
```
|
|
157
157
|
|
|
@@ -169,7 +169,7 @@ await txPot.addTx(
|
|
|
169
169
|
undefined,
|
|
170
170
|
undefined,
|
|
171
171
|
'your-foreign-key',
|
|
172
|
-
'{ yourData: "any-data", secondKey: 100 }'
|
|
172
|
+
'{ yourData: "any-data", secondKey: 100 }',
|
|
173
173
|
);
|
|
174
174
|
```
|
|
175
175
|
|
|
@@ -219,12 +219,12 @@ const txPotJob = async () => {
|
|
|
219
219
|
|
|
220
220
|
const approvedTxs = await TxPot.getTxsByStatus(
|
|
221
221
|
TransactionStatus.APPROVED,
|
|
222
|
-
true // only returns valid txs (also mutate invalid ones)
|
|
222
|
+
true, // only returns valid txs (also mutate invalid ones)
|
|
223
223
|
);
|
|
224
224
|
await processApprovedTxs(approvedTxs);
|
|
225
225
|
|
|
226
226
|
const signFailedTxs = await TxPot.getTxsByStatus(
|
|
227
|
-
TransactionStatus.SIGN_FAILED
|
|
227
|
+
TransactionStatus.SIGN_FAILED,
|
|
228
228
|
);
|
|
229
229
|
await processSignFailedTxs(signFailedTxs);
|
|
230
230
|
|
|
@@ -258,13 +258,13 @@ txPot.registerValidator(
|
|
|
258
258
|
`ergo`,
|
|
259
259
|
`payment`,
|
|
260
260
|
`service-1`,
|
|
261
|
-
s1ErgoPaymentTxValidator
|
|
261
|
+
s1ErgoPaymentTxValidator,
|
|
262
262
|
);
|
|
263
263
|
txPot.registerValidator(
|
|
264
264
|
`ergo`,
|
|
265
265
|
`payment`,
|
|
266
266
|
`service-2`,
|
|
267
|
-
s2ErgoPaymentTxValidator
|
|
267
|
+
s2ErgoPaymentTxValidator,
|
|
268
268
|
);
|
|
269
269
|
```
|
|
270
270
|
|
|
@@ -297,7 +297,7 @@ txPot.registerCallback(
|
|
|
297
297
|
`payment`,
|
|
298
298
|
TransactionStatus.COMPLETED,
|
|
299
299
|
'service-1',
|
|
300
|
-
onPaymentComplete
|
|
300
|
+
onPaymentComplete,
|
|
301
301
|
);
|
|
302
302
|
```
|
|
303
303
|
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare class TransactionEntity {
|
|
2
|
+
txId: string;
|
|
3
|
+
chain: string;
|
|
4
|
+
txType: string;
|
|
5
|
+
status: string;
|
|
6
|
+
requiredSign: number;
|
|
7
|
+
lastCheck: number;
|
|
8
|
+
lastStatusUpdate: string;
|
|
9
|
+
failedInSign: boolean;
|
|
10
|
+
signFailedCount: number;
|
|
11
|
+
serializedTx: string;
|
|
12
|
+
extra?: string | null;
|
|
13
|
+
extra2?: string | null;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=transactionEntity.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"
|
|
1
|
+
{"version":3,"file":"transactionEntity.d.ts","sourceRoot":"","sources":["../../../lib/db/entities/transactionEntity.ts"],"names":[],"mappings":"AAEA,qBACa,iBAAiB;IAE5B,IAAI,EAAE,MAAM,CAAC;IAGb,KAAK,EAAE,MAAM,CAAC;IAGd,MAAM,EAAE,MAAM,CAAC;IAGf,MAAM,EAAE,MAAM,CAAC;IAGf,YAAY,EAAE,MAAM,CAAC;IAGrB,SAAS,EAAE,MAAM,CAAC;IAGlB,gBAAgB,EAAE,MAAM,CAAC;IAGzB,YAAY,EAAE,OAAO,CAAC;IAGtB,eAAe,EAAE,MAAM,CAAC;IAGxB,YAAY,EAAE,MAAM,CAAC;IAKrB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAKtB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACxB"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { Column, Entity, PrimaryColumn } from 'typeorm';
|
|
11
|
+
let TransactionEntity = class TransactionEntity {
|
|
12
|
+
txId;
|
|
13
|
+
chain;
|
|
14
|
+
txType;
|
|
15
|
+
status;
|
|
16
|
+
requiredSign;
|
|
17
|
+
lastCheck;
|
|
18
|
+
lastStatusUpdate;
|
|
19
|
+
failedInSign;
|
|
20
|
+
signFailedCount;
|
|
21
|
+
serializedTx;
|
|
22
|
+
extra;
|
|
23
|
+
extra2;
|
|
24
|
+
};
|
|
25
|
+
__decorate([
|
|
26
|
+
PrimaryColumn('varchar'),
|
|
27
|
+
__metadata("design:type", String)
|
|
28
|
+
], TransactionEntity.prototype, "txId", void 0);
|
|
29
|
+
__decorate([
|
|
30
|
+
PrimaryColumn('varchar'),
|
|
31
|
+
__metadata("design:type", String)
|
|
32
|
+
], TransactionEntity.prototype, "chain", void 0);
|
|
33
|
+
__decorate([
|
|
34
|
+
Column('varchar'),
|
|
35
|
+
__metadata("design:type", String)
|
|
36
|
+
], TransactionEntity.prototype, "txType", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
Column('varchar'),
|
|
39
|
+
__metadata("design:type", String)
|
|
40
|
+
], TransactionEntity.prototype, "status", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
Column('integer'),
|
|
43
|
+
__metadata("design:type", Number)
|
|
44
|
+
], TransactionEntity.prototype, "requiredSign", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
Column('integer'),
|
|
47
|
+
__metadata("design:type", Number)
|
|
48
|
+
], TransactionEntity.prototype, "lastCheck", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
Column('varchar'),
|
|
51
|
+
__metadata("design:type", String)
|
|
52
|
+
], TransactionEntity.prototype, "lastStatusUpdate", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
Column('boolean'),
|
|
55
|
+
__metadata("design:type", Boolean)
|
|
56
|
+
], TransactionEntity.prototype, "failedInSign", void 0);
|
|
57
|
+
__decorate([
|
|
58
|
+
Column('integer'),
|
|
59
|
+
__metadata("design:type", Number)
|
|
60
|
+
], TransactionEntity.prototype, "signFailedCount", void 0);
|
|
61
|
+
__decorate([
|
|
62
|
+
Column('varchar'),
|
|
63
|
+
__metadata("design:type", String)
|
|
64
|
+
], TransactionEntity.prototype, "serializedTx", void 0);
|
|
65
|
+
__decorate([
|
|
66
|
+
Column('varchar', {
|
|
67
|
+
nullable: true,
|
|
68
|
+
}),
|
|
69
|
+
__metadata("design:type", Object)
|
|
70
|
+
], TransactionEntity.prototype, "extra", void 0);
|
|
71
|
+
__decorate([
|
|
72
|
+
Column('varchar', {
|
|
73
|
+
nullable: true,
|
|
74
|
+
}),
|
|
75
|
+
__metadata("design:type", Object)
|
|
76
|
+
], TransactionEntity.prototype, "extra2", void 0);
|
|
77
|
+
TransactionEntity = __decorate([
|
|
78
|
+
Entity()
|
|
79
|
+
], TransactionEntity);
|
|
80
|
+
export { TransactionEntity };
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25FbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvZGIvZW50aXRpZXMvdHJhbnNhY3Rpb25FbnRpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsYUFBYSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBR2pELElBQU0saUJBQWlCLEdBQXZCLE1BQU0saUJBQWlCO0lBRTVCLElBQUksQ0FBUztJQUdiLEtBQUssQ0FBUztJQUdkLE1BQU0sQ0FBUztJQUdmLE1BQU0sQ0FBUztJQUdmLFlBQVksQ0FBUztJQUdyQixTQUFTLENBQVM7SUFHbEIsZ0JBQWdCLENBQVM7SUFHekIsWUFBWSxDQUFVO0lBR3RCLGVBQWUsQ0FBUztJQUd4QixZQUFZLENBQVM7SUFLckIsS0FBSyxDQUFpQjtJQUt0QixNQUFNLENBQWlCO0NBQ3hCLENBQUE7QUF0Q0M7SUFEQyxhQUFhLENBQUMsU0FBUyxDQUFDOzsrQ0FDWjtBQUdiO0lBREMsYUFBYSxDQUFDLFNBQVMsQ0FBQzs7Z0RBQ1g7QUFHZDtJQURDLE1BQU0sQ0FBQyxTQUFTLENBQUM7O2lEQUNIO0FBR2Y7SUFEQyxNQUFNLENBQUMsU0FBUyxDQUFDOztpREFDSDtBQUdmO0lBREMsTUFBTSxDQUFDLFNBQVMsQ0FBQzs7dURBQ0c7QUFHckI7SUFEQyxNQUFNLENBQUMsU0FBUyxDQUFDOztvREFDQTtBQUdsQjtJQURDLE1BQU0sQ0FBQyxTQUFTLENBQUM7OzJEQUNPO0FBR3pCO0lBREMsTUFBTSxDQUFDLFNBQVMsQ0FBQzs7dURBQ0k7QUFHdEI7SUFEQyxNQUFNLENBQUMsU0FBUyxDQUFDOzswREFDTTtBQUd4QjtJQURDLE1BQU0sQ0FBQyxTQUFTLENBQUM7O3VEQUNHO0FBS3JCO0lBSEMsTUFBTSxDQUFDLFNBQVMsRUFBRTtRQUNqQixRQUFRLEVBQUUsSUFBSTtLQUNmLENBQUM7O2dEQUNvQjtBQUt0QjtJQUhDLE1BQU0sQ0FBQyxTQUFTLEVBQUU7UUFDakIsUUFBUSxFQUFFLElBQUk7S0FDZixDQUFDOztpREFDcUI7QUF2Q1osaUJBQWlCO0lBRDdCLE1BQU0sRUFBRTtHQUNJLGlCQUFpQixDQXdDN0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2x1bW4sIEVudGl0eSwgUHJpbWFyeUNvbHVtbiB9IGZyb20gJ3R5cGVvcm0nO1xuXG5ARW50aXR5KClcbmV4cG9ydCBjbGFzcyBUcmFuc2FjdGlvbkVudGl0eSB7XG4gIEBQcmltYXJ5Q29sdW1uKCd2YXJjaGFyJylcbiAgdHhJZDogc3RyaW5nO1xuXG4gIEBQcmltYXJ5Q29sdW1uKCd2YXJjaGFyJylcbiAgY2hhaW46IHN0cmluZztcblxuICBAQ29sdW1uKCd2YXJjaGFyJylcbiAgdHhUeXBlOiBzdHJpbmc7XG5cbiAgQENvbHVtbigndmFyY2hhcicpXG4gIHN0YXR1czogc3RyaW5nO1xuXG4gIEBDb2x1bW4oJ2ludGVnZXInKVxuICByZXF1aXJlZFNpZ246IG51bWJlcjtcblxuICBAQ29sdW1uKCdpbnRlZ2VyJylcbiAgbGFzdENoZWNrOiBudW1iZXI7XG5cbiAgQENvbHVtbigndmFyY2hhcicpXG4gIGxhc3RTdGF0dXNVcGRhdGU6IHN0cmluZztcblxuICBAQ29sdW1uKCdib29sZWFuJylcbiAgZmFpbGVkSW5TaWduOiBib29sZWFuO1xuXG4gIEBDb2x1bW4oJ2ludGVnZXInKVxuICBzaWduRmFpbGVkQ291bnQ6IG51bWJlcjtcblxuICBAQ29sdW1uKCd2YXJjaGFyJylcbiAgc2VyaWFsaXplZFR4OiBzdHJpbmc7XG5cbiAgQENvbHVtbigndmFyY2hhcicsIHtcbiAgICBudWxsYWJsZTogdHJ1ZSxcbiAgfSlcbiAgZXh0cmE/OiBzdHJpbmcgfCBudWxsO1xuXG4gIEBDb2x1bW4oJ3ZhcmNoYXInLCB7XG4gICAgbnVsbGFibGU6IHRydWUsXG4gIH0pXG4gIGV4dHJhMj86IHN0cmluZyB8IG51bGw7XG59XG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Migration1706350644686 } from './postgres/1706350644686-migration';
|
|
2
2
|
import { Migration1706007154531 } from './sqlite/1706007154531-migration';
|
|
3
3
|
export declare const migrations: {
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
sqlite: (typeof Migration1706007154531)[];
|
|
5
|
+
postgres: (typeof Migration1706350644686)[];
|
|
6
6
|
};
|
|
7
|
-
//# sourceMappingURL=index.d.ts.map
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Migration1706350644686 } from './postgres/1706350644686-migration';
|
|
2
2
|
import { Migration1706007154531 } from './sqlite/1706007154531-migration';
|
|
3
3
|
export const migrations = {
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
sqlite: [Migration1706007154531],
|
|
5
|
+
postgres: [Migration1706350644686],
|
|
6
6
|
};
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvZGIvbWlncmF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsTUFBTSxFQUFFLENBQUMsc0JBQXNCLENBQUM7SUFDaEMsUUFBUSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Q0FDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pZ3JhdGlvbjE3MDYzNTA2NDQ2ODYgfSBmcm9tICcuL3Bvc3RncmVzLzE3MDYzNTA2NDQ2ODYtbWlncmF0aW9uJztcbmltcG9ydCB7IE1pZ3JhdGlvbjE3MDYwMDcxNTQ1MzEgfSBmcm9tICcuL3NxbGl0ZS8xNzA2MDA3MTU0NTMxLW1pZ3JhdGlvbic7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRpb25zID0ge1xuICBzcWxpdGU6IFtNaWdyYXRpb24xNzA2MDA3MTU0NTMxXSxcbiAgcG9zdGdyZXM6IFtNaWdyYXRpb24xNzA2MzUwNjQ0Njg2XSxcbn07XG4iXX0=
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvZGIvbWlncmF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsTUFBTSxFQUFFLENBQUMsc0JBQXNCLENBQUM7SUFDaEMsUUFBUSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Q0FDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pZ3JhdGlvbjE3MDYzNTA2NDQ2ODYgfSBmcm9tICcuL3Bvc3RncmVzLzE3MDYzNTA2NDQ2ODYtbWlncmF0aW9uJztcbmltcG9ydCB7IE1pZ3JhdGlvbjE3MDYwMDcxNTQ1MzEgfSBmcm9tICcuL3NxbGl0ZS8xNzA2MDA3MTU0NTMxLW1pZ3JhdGlvbic7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRpb25zID0ge1xuICBzcWxpdGU6IFtNaWdyYXRpb24xNzA2MDA3MTU0NTMxXSxcbiAgcG9zdGdyZXM6IFtNaWdyYXRpb24xNzA2MzUwNjQ0Njg2XSxcbn07XG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
2
|
export declare class Migration1706350644686 implements MigrationInterface {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
6
|
}
|
|
7
|
-
//# sourceMappingURL=1706350644686-migration.d.ts.map
|
|
7
|
+
//# sourceMappingURL=1706350644686-migration.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"1706350644686-migration.d.ts","sourceRoot":"","sources":["../../../../lib/db/migrations/postgres/1706350644686-migration.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"1706350644686-migration.d.ts","sourceRoot":"","sources":["../../../../lib/db/migrations/postgres/1706350644686-migration.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAoB3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAK3D"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export class Migration1706350644686 {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
name = 'Migration1706350644686';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
5
|
CREATE TABLE "transaction_entity" (
|
|
6
6
|
"txId" character varying NOT NULL,
|
|
7
7
|
"chain" character varying NOT NULL,
|
|
@@ -18,11 +18,11 @@ export class Migration1706350644686 {
|
|
|
18
18
|
CONSTRAINT "PK_cafcc9d8e76fef57bc0cf385caa" PRIMARY KEY ("txId", "chain")
|
|
19
19
|
)
|
|
20
20
|
`);
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
}
|
|
22
|
+
async down(queryRunner) {
|
|
23
|
+
await queryRunner.query(`
|
|
24
24
|
DROP TABLE "transaction_entity"
|
|
25
25
|
`);
|
|
26
|
-
|
|
26
|
+
}
|
|
27
27
|
}
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcwNjM1MDY0NDY4Ni1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWIvZGIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzA2MzUwNjQ0Njg2LW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLElBQUksR0FBRyx3QkFBd0IsQ0FBQztJQUV6QixLQUFLLENBQUMsRUFBRSxDQUFDLFdBQXdCO1FBQ3RDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7Ozs7Ozs7Ozs7Ozs7OztTQWdCbkIsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLENBQUMsV0FBd0I7UUFDeEMsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOztTQUVuQixDQUFDLENBQUM7SUFDVCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBjaGVjay1maWxlL2ZpbGVuYW1lLW5hbWluZy1jb252ZW50aW9uICovXG5pbXBvcnQgeyBNaWdyYXRpb25JbnRlcmZhY2UsIFF1ZXJ5UnVubmVyIH0gZnJvbSAndHlwZW9ybSc7XG5cbmV4cG9ydCBjbGFzcyBNaWdyYXRpb24xNzA2MzUwNjQ0Njg2IGltcGxlbWVudHMgTWlncmF0aW9uSW50ZXJmYWNlIHtcbiAgbmFtZSA9ICdNaWdyYXRpb24xNzA2MzUwNjQ0Njg2JztcblxuICBwdWJsaWMgYXN5bmMgdXAocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQ1JFQVRFIFRBQkxFIFwidHJhbnNhY3Rpb25fZW50aXR5XCIgKFxuICAgICAgICAgICAgICAgIFwidHhJZFwiIGNoYXJhY3RlciB2YXJ5aW5nIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwiY2hhaW5cIiBjaGFyYWN0ZXIgdmFyeWluZyBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcInR4VHlwZVwiIGNoYXJhY3RlciB2YXJ5aW5nIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwic3RhdHVzXCIgY2hhcmFjdGVyIHZhcnlpbmcgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJyZXF1aXJlZFNpZ25cIiBpbnRlZ2VyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwibGFzdENoZWNrXCIgaW50ZWdlciBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcImxhc3RTdGF0dXNVcGRhdGVcIiBjaGFyYWN0ZXIgdmFyeWluZyBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcImZhaWxlZEluU2lnblwiIGJvb2xlYW4gTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJzaWduRmFpbGVkQ291bnRcIiBpbnRlZ2VyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwic2VyaWFsaXplZFR4XCIgY2hhcmFjdGVyIHZhcnlpbmcgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJleHRyYVwiIGNoYXJhY3RlciB2YXJ5aW5nLFxuICAgICAgICAgICAgICAgIFwiZXh0cmEyXCIgY2hhcmFjdGVyIHZhcnlpbmcsXG4gICAgICAgICAgICAgICAgQ09OU1RSQUlOVCBcIlBLX2NhZmNjOWQ4ZTc2ZmVmNTdiYzBjZjM4NWNhYVwiIFBSSU1BUlkgS0VZIChcInR4SWRcIiwgXCJjaGFpblwiKVxuICAgICAgICAgICAgKVxuICAgICAgICBgKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBkb3duKHF1ZXJ5UnVubmVyOiBRdWVyeVJ1bm5lcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIERST1AgVEFCTEUgXCJ0cmFuc2FjdGlvbl9lbnRpdHlcIlxuICAgICAgICBgKTtcbiAgfVxufVxuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
2
|
export declare class Migration1706007154531 implements MigrationInterface {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
6
|
}
|
|
7
|
-
//# sourceMappingURL=1706007154531-migration.d.ts.map
|
|
7
|
+
//# sourceMappingURL=1706007154531-migration.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"1706007154531-migration.d.ts","sourceRoot":"","sources":["../../../../lib/db/migrations/sqlite/1706007154531-migration.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"1706007154531-migration.d.ts","sourceRoot":"","sources":["../../../../lib/db/migrations/sqlite/1706007154531-migration.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAoB3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAK3D"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export class Migration1706007154531 {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
name = 'Migration1706007154531';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
5
|
CREATE TABLE "transaction_entity" (
|
|
6
6
|
"txId" varchar NOT NULL,
|
|
7
7
|
"chain" varchar NOT NULL,
|
|
@@ -18,11 +18,11 @@ export class Migration1706007154531 {
|
|
|
18
18
|
PRIMARY KEY ("txId", "chain")
|
|
19
19
|
)
|
|
20
20
|
`);
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
}
|
|
22
|
+
async down(queryRunner) {
|
|
23
|
+
await queryRunner.query(`
|
|
24
24
|
DROP TABLE "transaction_entity"
|
|
25
25
|
`);
|
|
26
|
-
|
|
26
|
+
}
|
|
27
27
|
}
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcwNjAwNzE1NDUzMS1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWIvZGIvbWlncmF0aW9ucy9zcWxpdGUvMTcwNjAwNzE1NDUzMS1taWdyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxJQUFJLEdBQUcsd0JBQXdCLENBQUM7SUFFekIsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUF3QjtRQUN0QyxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7U0FnQm5CLENBQUMsQ0FBQztJQUNULENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQXdCO1FBQ3hDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgY2hlY2stZmlsZS9maWxlbmFtZS1uYW1pbmctY29udmVudGlvbiAqL1xuaW1wb3J0IHsgTWlncmF0aW9uSW50ZXJmYWNlLCBRdWVyeVJ1bm5lciB9IGZyb20gJ3R5cGVvcm0nO1xuXG5leHBvcnQgY2xhc3MgTWlncmF0aW9uMTcwNjAwNzE1NDUzMSBpbXBsZW1lbnRzIE1pZ3JhdGlvbkludGVyZmFjZSB7XG4gIG5hbWUgPSAnTWlncmF0aW9uMTcwNjAwNzE1NDUzMSc7XG5cbiAgcHVibGljIGFzeW5jIHVwKHF1ZXJ5UnVubmVyOiBRdWVyeVJ1bm5lcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIENSRUFURSBUQUJMRSBcInRyYW5zYWN0aW9uX2VudGl0eVwiIChcbiAgICAgICAgICAgICAgICBcInR4SWRcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwiY2hhaW5cIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwidHhUeXBlXCIgdmFyY2hhciBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcInN0YXR1c1wiIHZhcmNoYXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJyZXF1aXJlZFNpZ25cIiBpbnRlZ2VyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwibGFzdENoZWNrXCIgaW50ZWdlciBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcImxhc3RTdGF0dXNVcGRhdGVcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwiZmFpbGVkSW5TaWduXCIgYm9vbGVhbiBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcInNpZ25GYWlsZWRDb3VudFwiIGludGVnZXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJzZXJpYWxpemVkVHhcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwiZXh0cmFcIiB2YXJjaGFyLFxuICAgICAgICAgICAgICAgIFwiZXh0cmEyXCIgdmFyY2hhcixcbiAgICAgICAgICAgICAgICBQUklNQVJZIEtFWSAoXCJ0eElkXCIsIFwiY2hhaW5cIilcbiAgICAgICAgICAgIClcbiAgICAgICAgYCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZG93bihxdWVyeVJ1bm5lcjogUXVlcnlSdW5uZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBEUk9QIFRBQkxFIFwidHJhbnNhY3Rpb25fZW50aXR5XCJcbiAgICAgICAgYCk7XG4gIH1cbn1cbiJdfQ==
|
package/dist/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { AbstractPotChainManager } from './network/
|
|
2
|
-
export { TxPot } from './transaction/
|
|
1
|
+
export { AbstractPotChainManager } from './network/abstractPotChainManager';
|
|
2
|
+
export { TxPot } from './transaction/txPot';
|
|
3
3
|
export * from './transaction/types';
|
|
4
|
-
export { TransactionEntity } from './db/entities/
|
|
4
|
+
export { TransactionEntity } from './db/entities/transactionEntity';
|
|
5
5
|
export { migrations } from './db/migrations/index';
|
|
6
|
-
//# sourceMappingURL=index.d.ts.map
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { AbstractPotChainManager } from './network/
|
|
2
|
-
export { TxPot } from './transaction/
|
|
1
|
+
export { AbstractPotChainManager } from './network/abstractPotChainManager';
|
|
2
|
+
export { TxPot } from './transaction/txPot';
|
|
3
3
|
export * from './transaction/types';
|
|
4
|
-
export { TransactionEntity } from './db/entities/
|
|
4
|
+
export { TransactionEntity } from './db/entities/transactionEntity';
|
|
5
5
|
export { migrations } from './db/migrations/index';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDNUUsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzVDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQWJzdHJhY3RQb3RDaGFpbk1hbmFnZXIgfSBmcm9tICcuL25ldHdvcmsvYWJzdHJhY3RQb3RDaGFpbk1hbmFnZXInO1xuZXhwb3J0IHsgVHhQb3QgfSBmcm9tICcuL3RyYW5zYWN0aW9uL3R4UG90JztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb24vdHlwZXMnO1xuZXhwb3J0IHsgVHJhbnNhY3Rpb25FbnRpdHkgfSBmcm9tICcuL2RiL2VudGl0aWVzL3RyYW5zYWN0aW9uRW50aXR5JztcbmV4cG9ydCB7IG1pZ3JhdGlvbnMgfSBmcm9tICcuL2RiL21pZ3JhdGlvbnMvaW5kZXgnO1xuIl19
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { SigningStatus } from '../transaction/types';
|
|
2
|
+
export declare abstract class AbstractPotChainManager {
|
|
3
|
+
/**
|
|
4
|
+
* gets the blockchain current height
|
|
5
|
+
*/
|
|
6
|
+
abstract getHeight: () => Promise<number>;
|
|
7
|
+
/**
|
|
8
|
+
* returns required number of confirmation
|
|
9
|
+
* @param txType
|
|
10
|
+
*/
|
|
11
|
+
abstract getTxRequiredConfirmation: (txType: string) => number;
|
|
12
|
+
/**
|
|
13
|
+
* gets number of confirmation for a tx
|
|
14
|
+
* returns -1 if tx is not in the blockchain
|
|
15
|
+
* @param txId
|
|
16
|
+
*/
|
|
17
|
+
abstract getTxConfirmation: (txId: string) => Promise<number>;
|
|
18
|
+
/**
|
|
19
|
+
* checks if a tx is still valid and can be sent to the network
|
|
20
|
+
* @param serializedTx
|
|
21
|
+
* @param signingStatus
|
|
22
|
+
*/
|
|
23
|
+
abstract isTxValid: (serializedTx: string, signingStatus: SigningStatus) => Promise<boolean>;
|
|
24
|
+
/**
|
|
25
|
+
* submits a tx to the blockchain
|
|
26
|
+
* @param serializedTx
|
|
27
|
+
*/
|
|
28
|
+
abstract submitTransaction: (serializedTx: string) => Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* checks if a tx is in mempool
|
|
31
|
+
* returns false if the chain has no mempool
|
|
32
|
+
* @param txId
|
|
33
|
+
*/
|
|
34
|
+
abstract isTxInMempool: (txId: string) => Promise<boolean>;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=abstractPotChainManager.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"
|
|
1
|
+
{"version":3,"file":"abstractPotChainManager.d.ts","sourceRoot":"","sources":["../../lib/network/abstractPotChainManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,8BAAsB,uBAAuB;IAC3C;;OAEG;IACH,QAAQ,CAAC,SAAS,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAE1C;;;OAGG;IACH,QAAQ,CAAC,yBAAyB,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,CAAC;IAE/D;;;;OAIG;IACH,QAAQ,CAAC,iBAAiB,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IAE9D;;;;OAIG;IACH,QAAQ,CAAC,SAAS,EAAE,CAClB,YAAY,EAAE,MAAM,EACpB,aAAa,EAAE,aAAa,KACzB,OAAO,CAAC,OAAO,CAAC,CAAC;IAEtB;;;OAGG;IACH,QAAQ,CAAC,iBAAiB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpE;;;;OAIG;IACH,QAAQ,CAAC,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;CAC5D"}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
export class AbstractPotChainManager {
|
|
2
|
-
|
|
1
|
+
export class AbstractPotChainManager {
|
|
2
|
+
}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3RQb3RDaGFpbk1hbmFnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvbmV0d29yay9hYnN0cmFjdFBvdENoYWluTWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQWdCLHVCQUF1QjtDQXlDNUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaWduaW5nU3RhdHVzIH0gZnJvbSAnLi4vdHJhbnNhY3Rpb24vdHlwZXMnO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RQb3RDaGFpbk1hbmFnZXIge1xuICAvKipcbiAgICogZ2V0cyB0aGUgYmxvY2tjaGFpbiBjdXJyZW50IGhlaWdodFxuICAgKi9cbiAgYWJzdHJhY3QgZ2V0SGVpZ2h0OiAoKSA9PiBQcm9taXNlPG51bWJlcj47XG5cbiAgLyoqXG4gICAqIHJldHVybnMgcmVxdWlyZWQgbnVtYmVyIG9mIGNvbmZpcm1hdGlvblxuICAgKiBAcGFyYW0gdHhUeXBlXG4gICAqL1xuICBhYnN0cmFjdCBnZXRUeFJlcXVpcmVkQ29uZmlybWF0aW9uOiAodHhUeXBlOiBzdHJpbmcpID0+IG51bWJlcjtcblxuICAvKipcbiAgICogZ2V0cyBudW1iZXIgb2YgY29uZmlybWF0aW9uIGZvciBhIHR4XG4gICAqICByZXR1cm5zIC0xIGlmIHR4IGlzIG5vdCBpbiB0aGUgYmxvY2tjaGFpblxuICAgKiBAcGFyYW0gdHhJZFxuICAgKi9cbiAgYWJzdHJhY3QgZ2V0VHhDb25maXJtYXRpb246ICh0eElkOiBzdHJpbmcpID0+IFByb21pc2U8bnVtYmVyPjtcblxuICAvKipcbiAgICogY2hlY2tzIGlmIGEgdHggaXMgc3RpbGwgdmFsaWQgYW5kIGNhbiBiZSBzZW50IHRvIHRoZSBuZXR3b3JrXG4gICAqIEBwYXJhbSBzZXJpYWxpemVkVHhcbiAgICogQHBhcmFtIHNpZ25pbmdTdGF0dXNcbiAgICovXG4gIGFic3RyYWN0IGlzVHhWYWxpZDogKFxuICAgIHNlcmlhbGl6ZWRUeDogc3RyaW5nLFxuICAgIHNpZ25pbmdTdGF0dXM6IFNpZ25pbmdTdGF0dXMsXG4gICkgPT4gUHJvbWlzZTxib29sZWFuPjtcblxuICAvKipcbiAgICogc3VibWl0cyBhIHR4IHRvIHRoZSBibG9ja2NoYWluXG4gICAqIEBwYXJhbSBzZXJpYWxpemVkVHhcbiAgICovXG4gIGFic3RyYWN0IHN1Ym1pdFRyYW5zYWN0aW9uOiAoc2VyaWFsaXplZFR4OiBzdHJpbmcpID0+IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIGNoZWNrcyBpZiBhIHR4IGlzIGluIG1lbXBvb2xcbiAgICogIHJldHVybnMgZmFsc2UgaWYgdGhlIGNoYWluIGhhcyBubyBtZW1wb29sXG4gICAqIEBwYXJhbSB0eElkXG4gICAqL1xuICBhYnN0cmFjdCBpc1R4SW5NZW1wb29sOiAodHhJZDogc3RyaW5nKSA9PiBQcm9taXNlPGJvb2xlYW4+O1xufVxuIl19
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { DataSource, Repository } from 'typeorm';
|
|
2
|
+
import { TransactionEntity } from '../db/entities/transactionEntity';
|
|
3
|
+
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
4
|
+
import { CallbackFunction, TransactionStatus, TxOptions, ValidatorFunction } from './types';
|
|
5
|
+
import { AbstractPotChainManager } from '../network/abstractPotChainManager';
|
|
6
|
+
export declare class TxPot {
|
|
7
|
+
protected static instance: TxPot;
|
|
8
|
+
protected readonly txRepository: Repository<TransactionEntity>;
|
|
9
|
+
protected chains: Map<string, AbstractPotChainManager>;
|
|
10
|
+
protected validators: Map<string, Map<string, Map<string, ValidatorFunction>>>;
|
|
11
|
+
protected txTypeCallbacks: Map<string, Map<TransactionStatus, Map<string, CallbackFunction>>>;
|
|
12
|
+
protected submissionAllowance: Map<string, Map<string, ValidatorFunction>>;
|
|
13
|
+
protected logger: AbstractLogger;
|
|
14
|
+
protected constructor(dataSource: DataSource, logger?: AbstractLogger);
|
|
15
|
+
/**
|
|
16
|
+
* initiates TxPot
|
|
17
|
+
* @param dataSource typeorm data source
|
|
18
|
+
* @param logger
|
|
19
|
+
* @returns
|
|
20
|
+
*/
|
|
21
|
+
static setup: (dataSource: DataSource, logger?: AbstractLogger) => TxPot;
|
|
22
|
+
/**
|
|
23
|
+
* returns TxPot instance (throws error if none exists)
|
|
24
|
+
* @returns TxPot instance
|
|
25
|
+
*/
|
|
26
|
+
static getInstance: () => TxPot;
|
|
27
|
+
/**
|
|
28
|
+
* registers a chain to TxPot
|
|
29
|
+
* @param chain
|
|
30
|
+
* @param chainManager
|
|
31
|
+
*/
|
|
32
|
+
registerChain: (chain: string, chainManager: AbstractPotChainManager) => void;
|
|
33
|
+
/**
|
|
34
|
+
* registers a validator function
|
|
35
|
+
* @param chain
|
|
36
|
+
* @param txType
|
|
37
|
+
* @param id
|
|
38
|
+
* @param validator
|
|
39
|
+
*/
|
|
40
|
+
registerValidator: (chain: string, txType: string, id: string, validator: ValidatorFunction) => void;
|
|
41
|
+
/**
|
|
42
|
+
* removes a validator function
|
|
43
|
+
* @param chain
|
|
44
|
+
* @param txType
|
|
45
|
+
* @param id
|
|
46
|
+
*/
|
|
47
|
+
unregisterValidator: (chain: string, txType: string, id: string) => void;
|
|
48
|
+
/**
|
|
49
|
+
* registers a submit validator function
|
|
50
|
+
* @param chain
|
|
51
|
+
* @param id
|
|
52
|
+
* @param validator
|
|
53
|
+
*/
|
|
54
|
+
registerSubmitValidator: (chain: string, id: string, validator: ValidatorFunction) => void;
|
|
55
|
+
/**
|
|
56
|
+
* removes a submit validator function
|
|
57
|
+
* @param chain
|
|
58
|
+
* @param id
|
|
59
|
+
*/
|
|
60
|
+
unregisterSubmitValidator: (chain: string, id: string) => void;
|
|
61
|
+
/**
|
|
62
|
+
* registers a callback function
|
|
63
|
+
* the callback will be called when status of any transactions
|
|
64
|
+
* of given type changes to given status
|
|
65
|
+
* @param txType
|
|
66
|
+
* @param status
|
|
67
|
+
* @param id
|
|
68
|
+
* @param callback
|
|
69
|
+
*/
|
|
70
|
+
registerCallback: (txType: string, status: TransactionStatus, id: string, callback: CallbackFunction) => void;
|
|
71
|
+
/**
|
|
72
|
+
* removes a callback function
|
|
73
|
+
* @param txType
|
|
74
|
+
* @param status
|
|
75
|
+
* @param id
|
|
76
|
+
*/
|
|
77
|
+
unregisterCallback: (txType: string, status: TransactionStatus, id: string) => void;
|
|
78
|
+
/**
|
|
79
|
+
* returns chain manager for given chain
|
|
80
|
+
* throws error if no manager is registered for it
|
|
81
|
+
* @param chain
|
|
82
|
+
*/
|
|
83
|
+
protected getChainManager: (chain: string) => AbstractPotChainManager;
|
|
84
|
+
/**
|
|
85
|
+
* sets the tx as invalid if enough blocks is passed from last check
|
|
86
|
+
* @param tx
|
|
87
|
+
*/
|
|
88
|
+
protected setTransactionAsInvalid: (tx: TransactionEntity) => Promise<void>;
|
|
89
|
+
/**
|
|
90
|
+
* validates a transaction
|
|
91
|
+
* returns true if no validator functions is set or tx is valid
|
|
92
|
+
* otherwise handle the tx as invalid and returns false
|
|
93
|
+
* @param tx
|
|
94
|
+
*/
|
|
95
|
+
protected validateTx: (tx: TransactionEntity) => Promise<boolean>;
|
|
96
|
+
/**
|
|
97
|
+
* checks a transaction for submission
|
|
98
|
+
* returns true if no validator functions is set or all validators allow tx to submit
|
|
99
|
+
* otherwise returns false
|
|
100
|
+
* @param tx
|
|
101
|
+
*/
|
|
102
|
+
protected isSubmitAllowed: (tx: TransactionEntity) => Promise<boolean>;
|
|
103
|
+
/**
|
|
104
|
+
* updates the status of a tx
|
|
105
|
+
* @param txKey tx id and chain
|
|
106
|
+
* @param status new status
|
|
107
|
+
*/
|
|
108
|
+
protected setTxStatus: (tx: TransactionEntity, status: TransactionStatus) => Promise<void>;
|
|
109
|
+
/**
|
|
110
|
+
* @returns current timestamp in seconds and string format
|
|
111
|
+
*/
|
|
112
|
+
protected currentTime: () => string;
|
|
113
|
+
/**
|
|
114
|
+
* submits the signed transaction to the blockchain
|
|
115
|
+
* @param tx
|
|
116
|
+
*/
|
|
117
|
+
protected processSignedTx: (tx: TransactionEntity) => Promise<void>;
|
|
118
|
+
/**
|
|
119
|
+
* processes the sent transaction
|
|
120
|
+
* @param tx
|
|
121
|
+
*/
|
|
122
|
+
protected processesSentTx: (tx: TransactionEntity) => Promise<void>;
|
|
123
|
+
/**
|
|
124
|
+
* runs all jobs of TxPot
|
|
125
|
+
* - process signed txs
|
|
126
|
+
* - process sent txs
|
|
127
|
+
*/
|
|
128
|
+
update: () => Promise<void>;
|
|
129
|
+
/**
|
|
130
|
+
* gets transactions by status
|
|
131
|
+
* @param status
|
|
132
|
+
* @param validate
|
|
133
|
+
* @returns
|
|
134
|
+
*/
|
|
135
|
+
getTxsByStatus: (status: TransactionStatus, validate?: boolean) => Promise<Array<TransactionEntity>>;
|
|
136
|
+
/**
|
|
137
|
+
* inserts a new transaction into db
|
|
138
|
+
* Note: make sure to set `lastCheck` field if initialStatus is `signed` or `sent`
|
|
139
|
+
* @param txId
|
|
140
|
+
* @param chain
|
|
141
|
+
* @param txType
|
|
142
|
+
* @param requiredSign
|
|
143
|
+
* @param serializedTx
|
|
144
|
+
* @param initialStatus
|
|
145
|
+
* @param lastCheck last blockchain height that tx was valid
|
|
146
|
+
* @param extra
|
|
147
|
+
* @param extra2
|
|
148
|
+
*/
|
|
149
|
+
addTx: (txId: string, chain: string, txType: string, requiredSign: number, serializedTx: string, initialStatus?: TransactionStatus, lastCheck?: number, extra?: string | null, extra2?: string | null) => Promise<void>;
|
|
150
|
+
/**
|
|
151
|
+
* updates the status of a tx
|
|
152
|
+
* @param txId
|
|
153
|
+
* @param chain
|
|
154
|
+
* @param status new status
|
|
155
|
+
*/
|
|
156
|
+
setTxStatusById: (txId: string, chain: string, status: TransactionStatus) => Promise<void>;
|
|
157
|
+
/**
|
|
158
|
+
* updates tx info when failed in sign process
|
|
159
|
+
* @param txId
|
|
160
|
+
* @param chain
|
|
161
|
+
*/
|
|
162
|
+
setTxAsSignFailed: (txId: string, chain: string) => Promise<void>;
|
|
163
|
+
/**
|
|
164
|
+
* updates the tx and set status as signed
|
|
165
|
+
* @param txId
|
|
166
|
+
* @param chain
|
|
167
|
+
* @param serializedTx
|
|
168
|
+
* @param currentHeight current height of the blockchain
|
|
169
|
+
* @param extra
|
|
170
|
+
* @param extra2
|
|
171
|
+
*/
|
|
172
|
+
setTxAsSigned: (txId: string, chain: string, serializedTx: string, currentHeight: number, extra?: string, extra2?: string) => Promise<void>;
|
|
173
|
+
/**
|
|
174
|
+
* updates last check value of a tx
|
|
175
|
+
* @param txId
|
|
176
|
+
* @param chain
|
|
177
|
+
* @param currentHeight current height of the blockchain
|
|
178
|
+
*/
|
|
179
|
+
updateTxLastCheck: (txId: string, chain: string, currentHeight: number) => Promise<void>;
|
|
180
|
+
/**
|
|
181
|
+
* updates failedInSign field of a transaction to false
|
|
182
|
+
* @param txId
|
|
183
|
+
* @param chain
|
|
184
|
+
*/
|
|
185
|
+
resetFailedInSign: (txId: string, chain: string) => Promise<void>;
|
|
186
|
+
/**
|
|
187
|
+
* updates requiredSign field of a transaction
|
|
188
|
+
* @param txId
|
|
189
|
+
* @param chain
|
|
190
|
+
* @param requiredSign
|
|
191
|
+
*/
|
|
192
|
+
updateRequiredSign: (txId: string, chain: string, requiredSign: number) => Promise<void>;
|
|
193
|
+
/**
|
|
194
|
+
* gets the transaction by its id and chain
|
|
195
|
+
* @param txId
|
|
196
|
+
* @param chain
|
|
197
|
+
*/
|
|
198
|
+
getTxByKey: (txId: string, chain: string) => Promise<TransactionEntity | null>;
|
|
199
|
+
/**
|
|
200
|
+
* @returns the transactions with valid status
|
|
201
|
+
*/
|
|
202
|
+
getTxsQuery: (options?: Array<TxOptions>) => Promise<TransactionEntity[]>;
|
|
203
|
+
/**
|
|
204
|
+
* updates extra fields of a transaction
|
|
205
|
+
* @param txId
|
|
206
|
+
* @param chain
|
|
207
|
+
* @param extra
|
|
208
|
+
* @param extra2
|
|
209
|
+
*/
|
|
210
|
+
updateExtra: (txId: string, chain: string, extra?: string | null, extra2?: string | null) => Promise<void>;
|
|
211
|
+
}
|
|
212
|
+
//# sourceMappingURL=txPot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"txPot.d.ts","sourceRoot":"","sources":["../../lib/transaction/txPot.ts"],"names":[],"mappings":"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"}
|