@mainsail/processor 0.0.1-rc.6 → 0.0.1-rc.8
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/distribution/actions/process-block.d.ts +6 -3
- package/distribution/actions/process-block.d.ts.map +1 -1
- package/distribution/actions/process-block.js.map +1 -1
- package/distribution/block-processor.d.ts +1 -2
- package/distribution/block-processor.d.ts.map +1 -1
- package/distribution/block-processor.js +8 -15
- package/distribution/block-processor.js.map +1 -1
- package/distribution/block-verifier.d.ts +1 -1
- package/distribution/block-verifier.d.ts.map +1 -1
- package/distribution/block-verifier.js +1 -1
- package/distribution/block-verifier.js.map +1 -1
- package/distribution/index.js +1 -1
- package/distribution/index.js.map +1 -1
- package/distribution/transaction-processor.d.ts +2 -2
- package/distribution/transaction-processor.d.ts.map +1 -1
- package/distribution/transaction-processor.js +9 -9
- package/distribution/transaction-processor.js.map +1 -1
- package/distribution/verifiers/chained-verifier.d.ts +1 -1
- package/distribution/verifiers/chained-verifier.d.ts.map +1 -1
- package/distribution/verifiers/chained-verifier.js +4 -3
- package/distribution/verifiers/chained-verifier.js.map +1 -1
- package/distribution/verifiers/gas-limit-verifier.d.ts +1 -1
- package/distribution/verifiers/gas-limit-verifier.d.ts.map +1 -1
- package/distribution/verifiers/gas-limit-verifier.js +3 -2
- package/distribution/verifiers/gas-limit-verifier.js.map +1 -1
- package/distribution/verifiers/generator-verifier.d.ts +1 -1
- package/distribution/verifiers/generator-verifier.d.ts.map +1 -1
- package/distribution/verifiers/generator-verifier.js +3 -2
- package/distribution/verifiers/generator-verifier.js.map +1 -1
- package/distribution/verifiers/legacy-attribute-verifier.d.ts +1 -1
- package/distribution/verifiers/legacy-attribute-verifier.d.ts.map +1 -1
- package/distribution/verifiers/legacy-attribute-verifier.js +3 -2
- package/distribution/verifiers/legacy-attribute-verifier.js.map +1 -1
- package/distribution/verifiers/reward-verifier.d.ts +1 -1
- package/distribution/verifiers/reward-verifier.d.ts.map +1 -1
- package/distribution/verifiers/reward-verifier.js +3 -2
- package/distribution/verifiers/reward-verifier.js.map +1 -1
- package/distribution/verifiers/size-verifier.d.ts +1 -1
- package/distribution/verifiers/size-verifier.d.ts.map +1 -1
- package/distribution/verifiers/size-verifier.js +5 -4
- package/distribution/verifiers/size-verifier.js.map +1 -1
- package/distribution/verifiers/timestamp-verifier.d.ts +1 -1
- package/distribution/verifiers/timestamp-verifier.d.ts.map +1 -1
- package/distribution/verifiers/timestamp-verifier.js +4 -3
- package/distribution/verifiers/timestamp-verifier.js.map +1 -1
- package/distribution/verifiers/transaction-duplicates-verifier.d.ts +1 -1
- package/distribution/verifiers/transaction-duplicates-verifier.d.ts.map +1 -1
- package/distribution/verifiers/transaction-duplicates-verifier.js +3 -2
- package/distribution/verifiers/transaction-duplicates-verifier.js.map +1 -1
- package/distribution/verifiers/transaction-length-verifier.d.ts +1 -1
- package/distribution/verifiers/transaction-length-verifier.d.ts.map +1 -1
- package/distribution/verifiers/transaction-length-verifier.js +3 -2
- package/distribution/verifiers/transaction-length-verifier.js.map +1 -1
- package/distribution/verifiers/transaction-root-verifier.d.ts +1 -1
- package/distribution/verifiers/transaction-root-verifier.d.ts.map +1 -1
- package/distribution/verifiers/transaction-root-verifier.js +3 -2
- package/distribution/verifiers/transaction-root-verifier.js.map +1 -1
- package/distribution/verifiers/version-verifier.d.ts +1 -1
- package/distribution/verifiers/version-verifier.d.ts.map +1 -1
- package/distribution/verifiers/version-verifier.js +3 -2
- package/distribution/verifiers/version-verifier.js.map +1 -1
- package/package.json +9 -8
|
@@ -1,6 +1,9 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
2
|
-
import { Services
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
|
+
import { Services } from "@mainsail/kernel";
|
|
3
3
|
export declare class ProcessBlockAction extends Services.Triggers.Action {
|
|
4
|
-
execute(arguments_:
|
|
4
|
+
execute(arguments_: Contracts.Kernel.ActionArguments<{
|
|
5
|
+
blockProcessor: Contracts.Processor.BlockProcessor;
|
|
6
|
+
roundState: Contracts.Consensus.RoundState;
|
|
7
|
+
}>): Promise<Contracts.Processor.BlockProcessorResult>;
|
|
5
8
|
}
|
|
6
9
|
//# sourceMappingURL=process-block.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"process-block.d.ts","sourceRoot":"","sources":["../../source/actions/process-block.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"process-block.d.ts","sourceRoot":"","sources":["../../source/actions/process-block.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAE5C,qBACa,kBAAmB,SAAQ,QAAQ,CAAC,QAAQ,CAAC,MAAM;IAClD,OAAO,CACnB,UAAU,EAAE,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC;QAC5C,cAAc,EAAE,SAAS,CAAC,SAAS,CAAC,cAAc,CAAC;QACnD,UAAU,EAAE,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC;KAC3C,CAAC,GACA,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,oBAAoB,CAAC;CAMpD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"process-block.js","sourceRoot":"","sources":["../../source/actions/process-block.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,EAAE,QAAQ,
|
|
1
|
+
{"version":3,"file":"process-block.js","sourceRoot":"","sources":["../../source/actions/process-block.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAGrC,IAAM,kBAAkB,GAAxB,MAAM,kBAAmB,SAAQ,QAAQ,CAAC,QAAQ,CAAC,MAAM;IACxD,KAAK,CAAC,OAAO,CACnB,UAGE;QAEF,MAAM,cAAc,GAAG,UAAU,CAAC,cAAc,CAAC;QACjD,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;QAEzC,OAAO,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,CAAC;CACD,CAAA;AAZY,kBAAkB;IAD9B,UAAU,EAAE;GACA,kBAAkB,CAY9B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class BlockProcessor implements Contracts.Processor.BlockProcessor {
|
|
3
3
|
#private;
|
|
4
4
|
private readonly stateStore;
|
|
@@ -8,7 +8,6 @@ export declare class BlockProcessor implements Contracts.Processor.BlockProcesso
|
|
|
8
8
|
private readonly databaseService;
|
|
9
9
|
private readonly evm;
|
|
10
10
|
private readonly transactionProcessor;
|
|
11
|
-
private handlerRegistry;
|
|
12
11
|
private readonly events;
|
|
13
12
|
private readonly logger;
|
|
14
13
|
private readonly validatorSet;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block-processor.d.ts","sourceRoot":"","sources":["../source/block-processor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"block-processor.d.ts","sourceRoot":"","sources":["../source/block-processor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,cAAe,YAAW,SAAS,CAAC,SAAS,CAAC,cAAc;;IAExE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAyB;IAGpD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAyB;IAG/C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAGhE,OAAO,CAAC,QAAQ,CAAC,eAAe,CAA6C;IAG7E,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAsC;IAItE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAA0B;IAG9C,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAA4C;IAGjF,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoC;IAG3D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2B;IAGlD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;IAG/D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAgC;IAGzD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAoC;IAGjE,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAwB;IAIlD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAA4B;IAIrD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAoC;IAGtE,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAG,SAAS,CAAC,eAAe,CAAC,aAAa,CAAC;IAE9D,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,oBAAoB,CAAC;IA4CrG,MAAM,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAsM7E"}
|
|
@@ -7,8 +7,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Events, Identifiers, Locale } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable, optional, tagged } from "@mainsail/container";
|
|
11
|
-
import { Constants, Contracts, Events, Identifiers } from "@mainsail/contracts";
|
|
12
12
|
import { assert, BigNumber, sleep } from "@mainsail/utils";
|
|
13
13
|
let BlockProcessor = class BlockProcessor {
|
|
14
14
|
stateStore;
|
|
@@ -18,7 +18,6 @@ let BlockProcessor = class BlockProcessor {
|
|
|
18
18
|
databaseService;
|
|
19
19
|
evm;
|
|
20
20
|
transactionProcessor;
|
|
21
|
-
handlerRegistry;
|
|
22
21
|
events;
|
|
23
22
|
logger;
|
|
24
23
|
validatorSet;
|
|
@@ -59,7 +58,7 @@ let BlockProcessor = class BlockProcessor {
|
|
|
59
58
|
}
|
|
60
59
|
catch (error) {
|
|
61
60
|
void this.#emit(Events.BlockEvent.Invalid, { block: unit.getBlock().data, error });
|
|
62
|
-
this.logger.error(`Cannot process block because: ${error.message}
|
|
61
|
+
this.logger.error(`Cannot process block because: ${error.message}`, "consensus");
|
|
63
62
|
}
|
|
64
63
|
return processResult;
|
|
65
64
|
}
|
|
@@ -87,16 +86,16 @@ let BlockProcessor = class BlockProcessor {
|
|
|
87
86
|
#logBlockCommitted(unit) {
|
|
88
87
|
if (!this.state.isBootstrap()) {
|
|
89
88
|
const block = unit.getBlock();
|
|
90
|
-
const blockNumber = unit.blockNumber.toLocaleString(
|
|
91
|
-
const round = unit.round.toLocaleString(
|
|
92
|
-
const blockRound = block.data.round.toLocaleString(
|
|
93
|
-
const transactionsCount = block.data.transactionsCount.toLocaleString(
|
|
94
|
-
const gasUsed = block.data.gasUsed.toLocaleString(
|
|
89
|
+
const blockNumber = unit.blockNumber.toLocaleString(Locale);
|
|
90
|
+
const round = unit.round.toLocaleString(Locale);
|
|
91
|
+
const blockRound = block.data.round.toLocaleString(Locale);
|
|
92
|
+
const transactionsCount = block.data.transactionsCount.toLocaleString(Locale);
|
|
93
|
+
const gasUsed = block.data.gasUsed.toLocaleString(Locale);
|
|
95
94
|
let blockString = `${blockNumber}/${round}/${block.data.hash}`;
|
|
96
95
|
if (block.data.round !== unit.round) {
|
|
97
96
|
blockString = `${blockNumber}/${round}(${blockRound})/${block.data.hash}`;
|
|
98
97
|
}
|
|
99
|
-
this.logger.info(`Committed block ${blockString} with ${transactionsCount} tx(s) (gasUsed=${gasUsed})
|
|
98
|
+
this.logger.info(`Committed block ${blockString} with ${transactionsCount} tx(s) (gasUsed=${gasUsed})`, "consensus");
|
|
100
99
|
}
|
|
101
100
|
}
|
|
102
101
|
#logNewRound(unit) {
|
|
@@ -172,8 +171,6 @@ let BlockProcessor = class BlockProcessor {
|
|
|
172
171
|
return;
|
|
173
172
|
}
|
|
174
173
|
void this.#emit(Events.TransactionEvent.Applied, transaction.data);
|
|
175
|
-
const handler = await this.handlerRegistry.getActivatedHandlerForData(transaction.data);
|
|
176
|
-
handler.emitEvents(transaction);
|
|
177
174
|
}
|
|
178
175
|
async #updateRewardsAndVotes(unit) {
|
|
179
176
|
const milestone = this.configuration.getMilestone();
|
|
@@ -244,10 +241,6 @@ __decorate([
|
|
|
244
241
|
inject(Identifiers.Processor.TransactionProcessor),
|
|
245
242
|
__metadata("design:type", Object)
|
|
246
243
|
], BlockProcessor.prototype, "transactionProcessor", void 0);
|
|
247
|
-
__decorate([
|
|
248
|
-
inject(Identifiers.Transaction.Handler.Registry),
|
|
249
|
-
__metadata("design:type", Object)
|
|
250
|
-
], BlockProcessor.prototype, "handlerRegistry", void 0);
|
|
251
244
|
__decorate([
|
|
252
245
|
inject(Identifiers.Services.EventDispatcher.Service),
|
|
253
246
|
__metadata("design:type", Object)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block-processor.js","sourceRoot":"","sources":["../source/block-processor.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"block-processor.js","sourceRoot":"","sources":["../source/block-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class BlockVerifier implements Contracts.Processor.Verifier {
|
|
3
3
|
private readonly handlers;
|
|
4
4
|
verify(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block-verifier.d.ts","sourceRoot":"","sources":["../source/block-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"block-verifier.d.ts","sourceRoot":"","sources":["../source/block-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAErD,qBACa,aAAc,YAAW,SAAS,CAAC,SAAS,CAAC,QAAQ;IAEjE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAiC;IAE7C,MAAM,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAK7E"}
|
|
@@ -7,8 +7,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { injectable, multiInject } from "@mainsail/container";
|
|
11
|
-
import { Identifiers } from "@mainsail/contracts";
|
|
12
12
|
let BlockVerifier = class BlockVerifier {
|
|
13
13
|
handlers;
|
|
14
14
|
async verify(unit) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block-verifier.js","sourceRoot":"","sources":["../source/block-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"block-verifier.js","sourceRoot":"","sources":["../source/block-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAIvD,IAAM,aAAa,GAAnB,MAAM,aAAa;IAER,QAAQ,CAAiC;IAEnD,KAAK,CAAC,MAAM,CAAC,IAAyC;QAC5D,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrC,MAAM,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;IACF,CAAC;CACD,CAAA;AAPiB;IADhB,WAAW,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC;;+CACC;AAF9C,aAAa;IADzB,UAAU,EAAE;GACA,aAAa,CASzB"}
|
package/distribution/index.js
CHANGED
|
@@ -4,8 +4,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
4
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
5
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
6
|
};
|
|
7
|
+
import { Identifiers } from "@mainsail/constants";
|
|
7
8
|
import { injectable } from "@mainsail/container";
|
|
8
|
-
import { Identifiers } from "@mainsail/contracts";
|
|
9
9
|
import { Providers } from "@mainsail/kernel";
|
|
10
10
|
import { ProcessBlockAction } from "./actions/process-block.js";
|
|
11
11
|
import { BlockProcessor } from "./block-processor.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAY,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,EACN,eAAe,EACf,gBAAgB,EAChB,iBAAiB,EACjB,uBAAuB,EACvB,cAAc,EACd,YAAY,EACZ,iBAAiB,EACjB,6BAA6B,EAC7B,yBAAyB,EACzB,wBAAwB,EACxB,eAAe,GACf,MAAM,sBAAsB,CAAC;AAGvB,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,SAAS,CAAC,eAAe;IACtD,KAAK,CAAC,QAAQ;QACpB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAExF,KAAK,MAAM,OAAO,IAAI;YACrB,eAAe;YACf,YAAY;YACZ,iBAAiB;YACjB,iBAAiB;YACjB,eAAe;YACf,cAAc;YACd,yBAAyB;YACzB,6BAA6B;YAC7B,wBAAwB;YACxB,gBAAgB;YAChB,uBAAuB;SACvB,EAAE,CAAC;YACH,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;QACxE,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAC1F,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAEtG,IAAI,CAAC,gBAAgB,EAAE,CAAC;IACzB,CAAC;IAEM,KAAK,CAAC,QAAQ;QACpB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,gBAAgB;QACf,IAAI,CAAC,GAAG;aACN,GAAG,CAA6B,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC;aACrE,IAAI,CAAC,cAAc,EAAE,IAAI,kBAAkB,EAAE,CAAC,CAAC;IAClD,CAAC;CACD,CAAA;AAnCY,eAAe;IAD3B,UAAU,EAAE;GACA,eAAe,CAmC3B"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class TransactionProcessor implements Contracts.Processor.TransactionProcessor {
|
|
3
3
|
private readonly evm;
|
|
4
4
|
protected readonly logger: Contracts.Kernel.Logger;
|
|
5
5
|
readonly app: Contracts.Kernel.Application;
|
|
6
6
|
private readonly configuration;
|
|
7
7
|
private readonly feeCalculator;
|
|
8
|
-
private readonly
|
|
8
|
+
private readonly transactionHandler;
|
|
9
9
|
process(unit: Contracts.Processor.ProcessableUnit, transaction: Contracts.Crypto.Transaction): Promise<Contracts.Evm.TransactionReceipt>;
|
|
10
10
|
}
|
|
11
11
|
//# sourceMappingURL=transaction-processor.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-processor.d.ts","sourceRoot":"","sources":["../source/transaction-processor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"transaction-processor.d.ts","sourceRoot":"","sources":["../source/transaction-processor.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,oBAAqB,YAAW,SAAS,CAAC,SAAS,CAAC,oBAAoB;IAGpF,OAAO,CAAC,QAAQ,CAAC,GAAG,CAA0B;IAG9C,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAG,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC;IAEpD,SACgB,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGnD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAGhE,OAAO,CAAC,QAAQ,CAAC,aAAa,CAA2C;IAGzE,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAA6C;IAE1E,OAAO,CACZ,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,EACzC,WAAW,EAAE,SAAS,CAAC,MAAM,CAAC,WAAW,GACvC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC;CAqC5C"}
|
|
@@ -8,19 +8,19 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
10
|
import { formatCurrency } from "@mainsail/blockchain-utils";
|
|
11
|
+
import { Identifiers } from "@mainsail/constants";
|
|
11
12
|
import { inject, injectable, tagged } from "@mainsail/container";
|
|
12
|
-
import {
|
|
13
|
+
import { InvalidSignatureError } from "@mainsail/exceptions";
|
|
13
14
|
let TransactionProcessor = class TransactionProcessor {
|
|
14
15
|
evm;
|
|
15
16
|
logger;
|
|
16
17
|
app;
|
|
17
18
|
configuration;
|
|
18
19
|
feeCalculator;
|
|
19
|
-
|
|
20
|
+
transactionHandler;
|
|
20
21
|
async process(unit, transaction) {
|
|
21
22
|
const block = unit.getBlock();
|
|
22
23
|
const milestone = this.configuration.getMilestone(block.header.number);
|
|
23
|
-
const transactionHandler = await this.handlerRegistry.getActivatedHandlerForData(transaction.data);
|
|
24
24
|
const commitKey = {
|
|
25
25
|
blockHash: block.header.hash,
|
|
26
26
|
blockNumber: BigInt(block.header.number),
|
|
@@ -37,12 +37,12 @@ let TransactionProcessor = class TransactionProcessor {
|
|
|
37
37
|
instance: this.evm,
|
|
38
38
|
},
|
|
39
39
|
};
|
|
40
|
-
if (!(await transactionHandler.verify(transaction))) {
|
|
41
|
-
throw new
|
|
40
|
+
if (!(await this.transactionHandler.verify(transaction))) {
|
|
41
|
+
throw new InvalidSignatureError();
|
|
42
42
|
}
|
|
43
|
-
const receipt = await transactionHandler.apply(transactionHandlerContext, transaction);
|
|
43
|
+
const receipt = await this.transactionHandler.apply(transactionHandlerContext, transaction);
|
|
44
44
|
const feeConsumed = this.feeCalculator.calculateConsumed(transaction.data.gasPrice, Number(receipt.gasUsed));
|
|
45
|
-
this.logger.debug(`executed EVM call (status=${receipt.status}, from=${transaction.data.from} to=${transaction.data.to} gasUsed=${receipt.gasUsed} paidNativeFee=${formatCurrency(this.configuration, feeConsumed)} deployed=${receipt.contractAddress})
|
|
45
|
+
this.logger.debug(`executed EVM call (status=${receipt.status}, from=${transaction.data.from} to=${transaction.data.to} gasUsed=${receipt.gasUsed} paidNativeFee=${formatCurrency(this.configuration, feeConsumed)} deployed=${receipt.contractAddress ?? ""})`, "consensus");
|
|
46
46
|
return receipt;
|
|
47
47
|
}
|
|
48
48
|
};
|
|
@@ -68,9 +68,9 @@ __decorate([
|
|
|
68
68
|
__metadata("design:type", Object)
|
|
69
69
|
], TransactionProcessor.prototype, "feeCalculator", void 0);
|
|
70
70
|
__decorate([
|
|
71
|
-
inject(Identifiers.Transaction.Handler
|
|
71
|
+
inject(Identifiers.Transaction.Handler),
|
|
72
72
|
__metadata("design:type", Object)
|
|
73
|
-
], TransactionProcessor.prototype, "
|
|
73
|
+
], TransactionProcessor.prototype, "transactionHandler", void 0);
|
|
74
74
|
TransactionProcessor = __decorate([
|
|
75
75
|
injectable()
|
|
76
76
|
], TransactionProcessor);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-processor.js","sourceRoot":"","sources":["../source/transaction-processor.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"transaction-processor.js","sourceRoot":"","sources":["../source/transaction-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class ChainedVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
private readonly configuration;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chained-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/chained-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"chained-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/chained-verifier.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIrD,qBACa,eAAgB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAElE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAGhE,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAyB;IAElC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAsB9E"}
|
|
@@ -8,8 +8,9 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
10
|
import { isBlockChained } from "@mainsail/blockchain-utils";
|
|
11
|
+
import { Identifiers } from "@mainsail/constants";
|
|
11
12
|
import { inject, injectable } from "@mainsail/container";
|
|
12
|
-
import {
|
|
13
|
+
import { BlockNotChained } from "@mainsail/exceptions";
|
|
13
14
|
import { assert } from "@mainsail/utils";
|
|
14
15
|
let ChainedVerifier = class ChainedVerifier {
|
|
15
16
|
app;
|
|
@@ -29,11 +30,11 @@ let ChainedVerifier = class ChainedVerifier {
|
|
|
29
30
|
blockData.parentHash === "0000000000000000000000000000000000000000000000000000000000000000";
|
|
30
31
|
}
|
|
31
32
|
if (!validPreviousBlock) {
|
|
32
|
-
throw new
|
|
33
|
+
throw new BlockNotChained(unit.getBlock());
|
|
33
34
|
}
|
|
34
35
|
}
|
|
35
36
|
else if (!isBlockChained(this.store.getLastBlock().data, blockData)) {
|
|
36
|
-
throw new
|
|
37
|
+
throw new BlockNotChained(unit.getBlock());
|
|
37
38
|
}
|
|
38
39
|
}
|
|
39
40
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chained-verifier.js","sourceRoot":"","sources":["../../source/verifiers/chained-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"chained-verifier.js","sourceRoot":"","sources":["../../source/verifiers/chained-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAGlC,IAAM,eAAe,GAArB,MAAM,eAAe;IAER,GAAG,CAAgC;IAGrC,aAAa,CAAkC;IAG/C,KAAK,CAAyB;IAExC,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC;QAEvC,IAAI,SAAS,CAAC,MAAM,KAAK,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAChE,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;YAEpD,IAAI,kBAAkB,GAAG,KAAK,CAAC;YAC/B,IAAI,SAAS,CAAC,QAAQ,EAAE,CAAC;gBACxB,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBACnC,kBAAkB,GAAG,SAAS,CAAC,UAAU,KAAK,SAAS,CAAC,QAAQ,CAAC,wBAAwB,CAAC;YAC3F,CAAC;iBAAM,CAAC;gBACP,kBAAkB;oBACjB,SAAS,CAAC,UAAU,KAAK,kEAAkE,CAAC;YAC9F,CAAC;YAED,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBACzB,MAAM,IAAI,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC5C,CAAC;QACF,CAAC;aAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE,CAAC;YACvE,MAAM,IAAI,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5C,CAAC;IACF,CAAC;CACD,CAAA;AA9BmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;4CACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;sDACiB;AAG/C;IADhB,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC;;8CACe;AARnC,eAAe;IAD3B,UAAU,EAAE;GACA,eAAe,CAgC3B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class GasLimitVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
private readonly configuration;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gas-limit-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/gas-limit-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"gas-limit-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/gas-limit-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,gBAAiB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAEnE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAEnD,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAW9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { ExceededGasLimit } from "@mainsail/exceptions";
|
|
12
13
|
let GasLimitVerifier = class GasLimitVerifier {
|
|
13
14
|
app;
|
|
14
15
|
configuration;
|
|
@@ -18,7 +19,7 @@ let GasLimitVerifier = class GasLimitVerifier {
|
|
|
18
19
|
}
|
|
19
20
|
const maxGasLimit = this.configuration.getMilestone().block.maxGasLimit;
|
|
20
21
|
if (unit.getBlock().data.gasUsed > maxGasLimit) {
|
|
21
|
-
throw new
|
|
22
|
+
throw new ExceededGasLimit(unit.getBlock(), maxGasLimit);
|
|
22
23
|
}
|
|
23
24
|
}
|
|
24
25
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gas-limit-verifier.js","sourceRoot":"","sources":["../../source/verifiers/gas-limit-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"gas-limit-verifier.js","sourceRoot":"","sources":["../../source/verifiers/gas-limit-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGjD,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAET,GAAG,CAAgC;IAGrC,aAAa,CAAkC;IAEzD,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAC3E,OAAO;QACR,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC;QAExE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,WAAW,EAAE,CAAC;YAChD,MAAM,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,WAAW,CAAC,CAAC;QAC1D,CAAC;IACF,CAAC;CACD,CAAA;AAhBmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;6CACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;uDACiB;AALpD,gBAAgB;IAD5B,UAAU,EAAE;GACA,gBAAgB,CAkB5B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class GeneratorVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
private readonly configuration;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"generator-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,iBAAkB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAEpE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAGhE,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAgD;IAGnF,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;IAElD,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAY9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { InvalidGenerator } from "@mainsail/exceptions";
|
|
12
13
|
let GeneratorVerifier = class GeneratorVerifier {
|
|
13
14
|
app;
|
|
14
15
|
configuration;
|
|
@@ -21,7 +22,7 @@ let GeneratorVerifier = class GeneratorVerifier {
|
|
|
21
22
|
const validatorIndex = this.proposerCalculator.getValidatorIndex(unit.getBlock().data.round);
|
|
22
23
|
const validator = this.validatorSet.getValidator(validatorIndex);
|
|
23
24
|
if (unit.getBlock().data.proposer !== validator.address) {
|
|
24
|
-
throw new
|
|
25
|
+
throw new InvalidGenerator(unit.getBlock(), validator.address);
|
|
25
26
|
}
|
|
26
27
|
}
|
|
27
28
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator-verifier.js","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"generator-verifier.js","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGjD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAEV,GAAG,CAAgC;IAGrC,aAAa,CAAkC;IAG/C,kBAAkB,CAAgD;IAGlE,YAAY,CAAkC;IAExD,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAC3E,OAAO;QACR,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7F,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;QAEjE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,SAAS,CAAC,OAAO,EAAE,CAAC;YACzD,MAAM,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;QAChE,CAAC;IACF,CAAC;CACD,CAAA;AAvBmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;8CACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;wDACiB;AAG/C;IADhB,MAAM,CAAC,WAAW,CAAC,eAAe,CAAC,kBAAkB,CAAC;;6DAC4B;AAGlE;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC;;uDACsB;AAXnD,iBAAiB;IAD7B,UAAU,EAAE;GACA,iBAAiB,CAyB7B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"legacy-attribute-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/legacy-attribute-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"legacy-attribute-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/legacy-attribute-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,uBAAwB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAG1E,OAAO,CAAC,QAAQ,CAAC,GAAG,CAA0B;IAG9C,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAwC;IAE/D,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAyB9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable, tagged } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { UnexpectedLegacySecondSignatureError } from "@mainsail/exceptions";
|
|
12
13
|
let LegacyAttributeVerifier = class LegacyAttributeVerifier {
|
|
13
14
|
evm;
|
|
14
15
|
transactionVerifier;
|
|
@@ -22,7 +23,7 @@ let LegacyAttributeVerifier = class LegacyAttributeVerifier {
|
|
|
22
23
|
const legacyAttributes = senders.get(from);
|
|
23
24
|
if (!legacyAttributes?.secondPublicKey) {
|
|
24
25
|
if (legacySecondSignature) {
|
|
25
|
-
throw new
|
|
26
|
+
throw new UnexpectedLegacySecondSignatureError();
|
|
26
27
|
}
|
|
27
28
|
continue;
|
|
28
29
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"legacy-attribute-verifier.js","sourceRoot":"","sources":["../../source/verifiers/legacy-attribute-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"legacy-attribute-verifier.js","sourceRoot":"","sources":["../../source/verifiers/legacy-attribute-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAEjE,OAAO,EAAE,oCAAoC,EAAE,MAAM,sBAAsB,CAAC;AAGrE,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAGlB,GAAG,CAA0B;IAG7B,mBAAmB,CAAwC;IAErE,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,OAAO,GAAG,IAAI,GAAG,EAA6D,CAAC;QAErF,KAAK,MAAM,WAAW,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,YAAY,EAAE,CAAC;YACxD,MAAM,EAAE,IAAI,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,GAAG,WAAW,CAAC,IAAI,CAAC;YAC9E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC,CAAC;YAClF,CAAC;YAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAE3C,IAAI,CAAC,gBAAgB,EAAE,eAAe,EAAE,CAAC;gBACxC,IAAI,qBAAqB,EAAE,CAAC;oBAC3B,MAAM,IAAI,oCAAoC,EAAE,CAAC;gBAClD,CAAC;gBAED,SAAS;YACV,CAAC;YAED,MAAM,IAAI,CAAC,mBAAmB,CAAC,2BAA2B,CACzD,WAAW,CAAC,IAAI,EAChB,gBAAgB,CAAC,eAAe,CAChC,CAAC;QACH,CAAC;IACF,CAAC;CACD,CAAA;AA9BiB;IAFhB,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC;IAChC,MAAM,CAAC,UAAU,EAAE,KAAK,CAAC;;oDACoB;AAG7B;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,WAAW,CAAC,QAAQ,CAAC;;oEACsB;AANhE,uBAAuB;IADnC,UAAU,EAAE;GACA,uBAAuB,CAiCnC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class RewardVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
private readonly configuration;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reward-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/reward-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"reward-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/reward-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,cAAe,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAEjE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAEnD,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAO9E"}
|
|
@@ -7,15 +7,16 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { InvalidReward } from "@mainsail/exceptions";
|
|
12
13
|
let RewardVerifier = class RewardVerifier {
|
|
13
14
|
app;
|
|
14
15
|
configuration;
|
|
15
16
|
async execute(unit) {
|
|
16
17
|
const reward = this.configuration.getMilestone().reward;
|
|
17
18
|
if (!unit.getBlock().data.reward.isEqualTo(reward)) {
|
|
18
|
-
throw new
|
|
19
|
+
throw new InvalidReward(unit.getBlock(), reward);
|
|
19
20
|
}
|
|
20
21
|
}
|
|
21
22
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reward-verifier.js","sourceRoot":"","sources":["../../source/verifiers/reward-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"reward-verifier.js","sourceRoot":"","sources":["../../source/verifiers/reward-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG9C,IAAM,cAAc,GAApB,MAAM,cAAc;IAEP,GAAG,CAAgC;IAGrC,aAAa,CAAkC;IAEzD,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC;QAExD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;YACpD,MAAM,IAAI,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,CAAC;QAClD,CAAC;IACF,CAAC;CACD,CAAA;AAZmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;2CACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;qDACiB;AALpD,cAAc;IAD1B,UAAU,EAAE;GACA,cAAc,CAc1B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"size-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/size-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"size-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/size-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,YAAa,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAE/D,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAGhE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAgB;IAE9B,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAuB9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { InvalidPayloadSize, MaxPayloadExceeded } from "@mainsail/exceptions";
|
|
12
13
|
let SizeVerifier = class SizeVerifier {
|
|
13
14
|
app;
|
|
14
15
|
configuration;
|
|
@@ -18,18 +19,18 @@ let SizeVerifier = class SizeVerifier {
|
|
|
18
19
|
const block = unit.getBlock();
|
|
19
20
|
const totalSize = this.headerSize() + block.header.payloadSize;
|
|
20
21
|
if (totalSize > maxPayload) {
|
|
21
|
-
throw new
|
|
22
|
+
throw new MaxPayloadExceeded(block, totalSize, maxPayload);
|
|
22
23
|
}
|
|
23
24
|
const actualSize = Buffer.byteLength(block.serialized, "hex");
|
|
24
25
|
if (totalSize !== actualSize) {
|
|
25
|
-
throw new
|
|
26
|
+
throw new InvalidPayloadSize(block, totalSize, actualSize);
|
|
26
27
|
}
|
|
27
28
|
let totalPayloadLength = block.transactions.length * 4;
|
|
28
29
|
for (const transaction of block.transactions) {
|
|
29
30
|
totalPayloadLength += transaction.serialized.byteLength;
|
|
30
31
|
}
|
|
31
32
|
if (totalPayloadLength !== block.data.payloadSize) {
|
|
32
|
-
throw new
|
|
33
|
+
throw new InvalidPayloadSize(block, totalSize, totalPayloadLength);
|
|
33
34
|
}
|
|
34
35
|
}
|
|
35
36
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"size-verifier.js","sourceRoot":"","sources":["../../source/verifiers/size-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"size-verifier.js","sourceRoot":"","sources":["../../source/verifiers/size-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAGvE,IAAM,YAAY,GAAlB,MAAM,YAAY;IAEL,GAAG,CAAgC;IAGrC,aAAa,CAAkC;IAG/C,UAAU,CAAgB;IAEpC,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,KAAK,CAAC;QAC/D,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE9B,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC;QAC/D,IAAI,SAAS,GAAG,UAAU,EAAE,CAAC;YAC5B,MAAM,IAAI,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAC9D,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;YAC9B,MAAM,IAAI,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QAC5D,CAAC;QAED,IAAI,kBAAkB,GAAG,KAAK,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;QACvD,KAAK,MAAM,WAAW,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YAC9C,kBAAkB,IAAI,WAAW,CAAC,UAAU,CAAC,UAAU,CAAC;QACzD,CAAC;QAED,IAAI,kBAAkB,KAAK,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACnD,MAAM,IAAI,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,kBAAkB,CAAC,CAAC;QACpE,CAAC;IACF,CAAC;CACD,CAAA;AA/BmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;yCACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;mDACiB;AAG/C;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC;;gDACP;AAR/B,YAAY;IADxB,UAAU,EAAE;GACA,YAAY,CAiCxB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timestamp-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/timestamp-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"timestamp-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/timestamp-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIrD,qBACa,iBAAkB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAEpE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAyB;IAG/C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAGhE,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAiD;IAExE,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAgB9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { FutureBlock, InvalidTimestamp } from "@mainsail/exceptions";
|
|
12
13
|
import dayjs from "dayjs";
|
|
13
14
|
let TimestampVerifier = class TimestampVerifier {
|
|
14
15
|
app;
|
|
@@ -20,11 +21,11 @@ let TimestampVerifier = class TimestampVerifier {
|
|
|
20
21
|
return;
|
|
21
22
|
}
|
|
22
23
|
if (unit.getBlock().data.timestamp > dayjs().valueOf() + this.configuration.getMilestone().timeouts.tolerance) {
|
|
23
|
-
throw new
|
|
24
|
+
throw new FutureBlock(unit.getBlock());
|
|
24
25
|
}
|
|
25
26
|
if (unit.getBlock().data.timestamp <
|
|
26
27
|
this.timestampCalculator.calculateMinimalTimestamp(this.store.getLastBlock(), unit.getBlock().data.round)) {
|
|
27
|
-
throw new
|
|
28
|
+
throw new InvalidTimestamp(unit.getBlock());
|
|
28
29
|
}
|
|
29
30
|
}
|
|
30
31
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timestamp-verifier.js","sourceRoot":"","sources":["../../source/verifiers/timestamp-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"timestamp-verifier.js","sourceRoot":"","sources":["../../source/verifiers/timestamp-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACrE,OAAO,KAAK,MAAM,OAAO,CAAC;AAGnB,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAEV,GAAG,CAAgC;IAGrC,KAAK,CAAyB;IAG9B,aAAa,CAAkC;IAG/C,mBAAmB,CAAiD;IAE9E,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAC3E,OAAO;QACR,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;YAC/G,MAAM,IAAI,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACxC,CAAC;QAED,IACC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,SAAS;YAC9B,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EACxG,CAAC;YACF,MAAM,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC7C,CAAC;IACF,CAAC;CACD,CAAA;AA3BmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;8CACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC;;gDACe;AAG9B;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;wDACiB;AAG/C;IADhB,MAAM,CAAC,WAAW,CAAC,eAAe,CAAC,mBAAmB,CAAC;;8DAC6B;AAXzE,iBAAiB;IAD7B,UAAU,EAAE;GACA,iBAAiB,CA6B7B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class TransactionDuplicatesVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-duplicates-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-duplicates-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"transaction-duplicates-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-duplicates-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,6BAA8B,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAEhF,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAEzC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAY9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { DuplicatedTransaction } from "@mainsail/exceptions";
|
|
12
13
|
let TransactionDuplicatesVerifier = class TransactionDuplicatesVerifier {
|
|
13
14
|
app;
|
|
14
15
|
async execute(unit) {
|
|
@@ -16,7 +17,7 @@ let TransactionDuplicatesVerifier = class TransactionDuplicatesVerifier {
|
|
|
16
17
|
const appliedTransactions = new Set();
|
|
17
18
|
for (const transaction of block.transactions) {
|
|
18
19
|
if (appliedTransactions.has(transaction.hash)) {
|
|
19
|
-
throw new
|
|
20
|
+
throw new DuplicatedTransaction(unit.getBlock(), transaction.hash);
|
|
20
21
|
}
|
|
21
22
|
appliedTransactions.add(transaction.hash);
|
|
22
23
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-duplicates-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-duplicates-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"transaction-duplicates-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-duplicates-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAGtD,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IAEtB,GAAG,CAAgC;IAE/C,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE9B,MAAM,mBAAmB,GAAgB,IAAI,GAAG,EAAE,CAAC;QACnD,KAAK,MAAM,WAAW,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YAC9C,IAAI,mBAAmB,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC/C,MAAM,IAAI,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;YACpE,CAAC;YAED,mBAAmB,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC3C,CAAC;IACF,CAAC;CACD,CAAA;AAdmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;0DACa;AAF1C,6BAA6B;IADzC,UAAU,EAAE;GACA,6BAA6B,CAgBzC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class TransactionLengthVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-length-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-length-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"transaction-length-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-length-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,yBAA0B,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAE5E,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAEzC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAO9E"}
|
|
@@ -7,14 +7,15 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { InvalidTransactionsLength } from "@mainsail/exceptions";
|
|
12
13
|
let TransactionLengthVerifier = class TransactionLengthVerifier {
|
|
13
14
|
app;
|
|
14
15
|
async execute(unit) {
|
|
15
16
|
const block = unit.getBlock();
|
|
16
17
|
if (block.transactions.length !== block.data.transactionsCount) {
|
|
17
|
-
throw new
|
|
18
|
+
throw new InvalidTransactionsLength(block);
|
|
18
19
|
}
|
|
19
20
|
}
|
|
20
21
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-length-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-length-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"transaction-length-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-length-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAElB,GAAG,CAAgC;IAE/C,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE9B,IAAI,KAAK,CAAC,YAAY,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAChE,MAAM,IAAI,yBAAyB,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;IACF,CAAC;CACD,CAAA;AATmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;sDACa;AAF1C,yBAAyB;IADrC,UAAU,EAAE;GACA,yBAAyB,CAWrC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class TransactionsRootVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
private readonly hashFactory;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-root-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-root-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"transaction-root-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-root-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,wBAAyB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAE3E,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAgC;IAE/C,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAc9E"}
|
|
@@ -7,8 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { InvalidTransactionsRoot } from "@mainsail/exceptions";
|
|
12
13
|
let TransactionsRootVerifier = class TransactionsRootVerifier {
|
|
13
14
|
app;
|
|
14
15
|
hashFactory;
|
|
@@ -20,7 +21,7 @@ let TransactionsRootVerifier = class TransactionsRootVerifier {
|
|
|
20
21
|
}
|
|
21
22
|
const transactionsRoot = await this.hashFactory.sha256(payloadBuffers);
|
|
22
23
|
if (transactionsRoot.toString("hex") !== block.data.transactionsRoot) {
|
|
23
|
-
throw new
|
|
24
|
+
throw new InvalidTransactionsRoot(block, transactionsRoot.toString("hex"));
|
|
24
25
|
}
|
|
25
26
|
}
|
|
26
27
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-root-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-root-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"transaction-root-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-root-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAGxD,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAEjB,GAAG,CAAgC;IAGrC,WAAW,CAAgC;IAErD,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE9B,MAAM,cAAc,GAAa,EAAE,CAAC;QAEpC,KAAK,MAAM,WAAW,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YAC9C,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;QAC3D,CAAC;QAED,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACtE,MAAM,IAAI,uBAAuB,CAAC,KAAK,EAAE,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5E,CAAC;IACF,CAAC;CACD,CAAA;AAnBmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;qDACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC;;6DACc;AALhD,wBAAwB;IADpC,UAAU,EAAE;GACA,wBAAwB,CAqBpC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Contracts } from "@mainsail/contracts";
|
|
1
|
+
import type { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class VersionVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
4
|
private readonly configuration;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"version-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/version-verifier.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"version-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/version-verifier.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,qBACa,eAAgB,YAAW,SAAS,CAAC,SAAS,CAAC,OAAO;IAElE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAEnD,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAO9E"}
|
|
@@ -7,15 +7,16 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
+
import { Identifiers } from "@mainsail/constants";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
|
-
import {
|
|
12
|
+
import { InvalidBlockVersion } from "@mainsail/exceptions";
|
|
12
13
|
let VersionVerifier = class VersionVerifier {
|
|
13
14
|
app;
|
|
14
15
|
configuration;
|
|
15
16
|
async execute(unit) {
|
|
16
17
|
const version = this.configuration.getMilestone().block.version;
|
|
17
18
|
if (unit.getBlock().data.version !== version) {
|
|
18
|
-
throw new
|
|
19
|
+
throw new InvalidBlockVersion(unit.getBlock());
|
|
19
20
|
}
|
|
20
21
|
}
|
|
21
22
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"version-verifier.js","sourceRoot":"","sources":["../../source/verifiers/version-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"version-verifier.js","sourceRoot":"","sources":["../../source/verifiers/version-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAGpD,IAAM,eAAe,GAArB,MAAM,eAAe;IAER,GAAG,CAAgC;IAGrC,aAAa,CAAkC;IAEzD,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;QAEhE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;YAC9C,MAAM,IAAI,mBAAmB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAChD,CAAC;IACF,CAAC;CACD,CAAA;AAZmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;4CACa;AAGrC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;sDACiB;AALpD,eAAe;IAD3B,UAAU,EAAE;GACA,eAAe,CAc3B"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mainsail/processor",
|
|
3
|
-
"version": "0.0.1-rc.
|
|
3
|
+
"version": "0.0.1-rc.8",
|
|
4
4
|
"description": "Block processor for the Mainsail blockchain",
|
|
5
5
|
"license": "GPL-3.0-only",
|
|
6
6
|
"contributors": [],
|
|
@@ -12,14 +12,16 @@
|
|
|
12
12
|
],
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"dayjs": "1.11.13",
|
|
15
|
-
"@mainsail/blockchain-utils": "0.0.1-rc.
|
|
16
|
-
"@mainsail/
|
|
17
|
-
"@mainsail/
|
|
18
|
-
"@mainsail/
|
|
19
|
-
"@mainsail/
|
|
15
|
+
"@mainsail/blockchain-utils": "0.0.1-rc.8",
|
|
16
|
+
"@mainsail/constants": "0.0.1-rc.8",
|
|
17
|
+
"@mainsail/container": "0.0.1-rc.8",
|
|
18
|
+
"@mainsail/exceptions": "0.0.1-rc.8",
|
|
19
|
+
"@mainsail/kernel": "0.0.1-rc.8",
|
|
20
|
+
"@mainsail/utils": "0.0.1-rc.8"
|
|
20
21
|
},
|
|
21
22
|
"devDependencies": {
|
|
22
|
-
"uvu": "0.5.6"
|
|
23
|
+
"uvu": "0.5.6",
|
|
24
|
+
"@mainsail/contracts": "0.0.1-rc.8"
|
|
23
25
|
},
|
|
24
26
|
"engines": {
|
|
25
27
|
"node": ">=20.x"
|
|
@@ -27,7 +29,6 @@
|
|
|
27
29
|
"scripts": {
|
|
28
30
|
"build": "tsc -b",
|
|
29
31
|
"build:watch": "pnpm run clean && tsc -w",
|
|
30
|
-
"clean": "del distribution && del tsconfig.tsbuildinfo",
|
|
31
32
|
"release": "pnpm publish --access public",
|
|
32
33
|
"test": "pnpm run uvu source .test.ts",
|
|
33
34
|
"test:coverage": "c8 --check-coverage --lines 100 pnpm run test",
|