@mainsail/processor 0.0.1-evm.9 → 0.0.1-rc.1
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.map +1 -1
- package/distribution/actions/process-block.js +13 -2
- package/distribution/actions/process-block.js.map +1 -1
- package/distribution/block-processor.d.ts +3 -1
- package/distribution/block-processor.d.ts.map +1 -1
- package/distribution/block-processor.js +100 -47
- 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 +8 -12
- package/distribution/block-verifier.js.map +1 -1
- package/distribution/index.d.ts.map +1 -1
- package/distribution/index.js +31 -3
- package/distribution/index.js.map +1 -1
- package/distribution/transaction-processor.d.ts +1 -1
- package/distribution/transaction-processor.d.ts.map +1 -1
- package/distribution/transaction-processor.js +14 -12
- package/distribution/transaction-processor.js.map +1 -1
- package/distribution/verifiers/chained-verifier.d.ts +2 -1
- package/distribution/verifiers/chained-verifier.d.ts.map +1 -1
- package/distribution/verifiers/chained-verifier.js +23 -5
- package/distribution/verifiers/chained-verifier.js.map +1 -1
- package/distribution/verifiers/gas-limit-verifier.d.ts +7 -0
- package/distribution/verifiers/gas-limit-verifier.d.ts.map +1 -0
- package/distribution/verifiers/gas-limit-verifier.js +35 -0
- package/distribution/verifiers/gas-limit-verifier.js.map +1 -0
- package/distribution/verifiers/generator-verifier.d.ts +2 -1
- package/distribution/verifiers/generator-verifier.d.ts.map +1 -1
- package/distribution/verifiers/generator-verifier.js +9 -5
- package/distribution/verifiers/generator-verifier.js.map +1 -1
- package/distribution/verifiers/index.d.ts +8 -1
- package/distribution/verifiers/index.d.ts.map +1 -1
- package/distribution/verifiers/index.js +8 -1
- package/distribution/verifiers/index.js.map +1 -1
- package/distribution/verifiers/legacy-attribute-verifier.d.ts +7 -0
- package/distribution/verifiers/legacy-attribute-verifier.d.ts.map +1 -0
- package/distribution/verifiers/legacy-attribute-verifier.js +44 -0
- package/distribution/verifiers/legacy-attribute-verifier.js.map +1 -0
- package/distribution/verifiers/reward-verifier.d.ts +7 -0
- package/distribution/verifiers/reward-verifier.d.ts.map +1 -0
- package/distribution/verifiers/reward-verifier.js +32 -0
- package/distribution/verifiers/reward-verifier.js.map +1 -0
- package/distribution/verifiers/size-verifier.d.ts +8 -0
- package/distribution/verifiers/size-verifier.d.ts.map +1 -0
- package/distribution/verifiers/size-verifier.js +49 -0
- package/distribution/verifiers/size-verifier.js.map +1 -0
- package/distribution/verifiers/timestamp-verifier.d.ts +2 -1
- package/distribution/verifiers/timestamp-verifier.d.ts.map +1 -1
- package/distribution/verifiers/timestamp-verifier.js +7 -4
- package/distribution/verifiers/timestamp-verifier.js.map +1 -1
- package/distribution/verifiers/transaction-duplicates-verifier.d.ts +6 -0
- package/distribution/verifiers/transaction-duplicates-verifier.d.ts.map +1 -0
- package/distribution/verifiers/transaction-duplicates-verifier.js +32 -0
- package/distribution/verifiers/transaction-duplicates-verifier.js.map +1 -0
- package/distribution/verifiers/{nonce-verifier.d.ts → transaction-length-verifier.d.ts} +2 -2
- package/distribution/verifiers/transaction-length-verifier.d.ts.map +1 -0
- package/distribution/verifiers/transaction-length-verifier.js +28 -0
- package/distribution/verifiers/transaction-length-verifier.js.map +1 -0
- package/distribution/verifiers/transaction-root-verifier.d.ts +7 -0
- package/distribution/verifiers/transaction-root-verifier.d.ts.map +1 -0
- package/distribution/verifiers/transaction-root-verifier.js +37 -0
- package/distribution/verifiers/transaction-root-verifier.js.map +1 -0
- package/distribution/verifiers/version-verifier.d.ts +7 -0
- package/distribution/verifiers/version-verifier.d.ts.map +1 -0
- package/distribution/verifiers/version-verifier.js +32 -0
- package/distribution/verifiers/version-verifier.js.map +1 -0
- package/package.json +9 -7
- package/distribution/verifiers/nonce-verifier.d.ts.map +0 -1
- package/distribution/verifiers/nonce-verifier.js +0 -41
- package/distribution/verifiers/nonce-verifier.js.map +0 -1
|
@@ -7,15 +7,29 @@ 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 { isBlockChained } from "@mainsail/blockchain-utils";
|
|
10
11
|
import { inject, injectable } from "@mainsail/container";
|
|
11
12
|
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
-
import {
|
|
13
|
+
import { assert } from "@mainsail/utils";
|
|
13
14
|
let ChainedVerifier = class ChainedVerifier {
|
|
14
15
|
async execute(unit) {
|
|
15
|
-
|
|
16
|
-
|
|
16
|
+
const blockData = unit.getBlock().data;
|
|
17
|
+
if (blockData.number === this.configuration.getGenesisHeight()) {
|
|
18
|
+
const milestone = this.configuration.getMilestone();
|
|
19
|
+
let validPreviousBlock = false;
|
|
20
|
+
if (milestone.snapshot) {
|
|
21
|
+
assert.defined(milestone.snapshot);
|
|
22
|
+
validPreviousBlock = blockData.parentHash === milestone.snapshot.previousGenesisBlockHash;
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
validPreviousBlock =
|
|
26
|
+
blockData.parentHash === "0000000000000000000000000000000000000000000000000000000000000000";
|
|
27
|
+
}
|
|
28
|
+
if (!validPreviousBlock) {
|
|
29
|
+
throw new Exceptions.BlockNotChained(unit.getBlock());
|
|
30
|
+
}
|
|
17
31
|
}
|
|
18
|
-
if (!
|
|
32
|
+
else if (!isBlockChained(this.store.getLastBlock().data, blockData)) {
|
|
19
33
|
throw new Exceptions.BlockNotChained(unit.getBlock());
|
|
20
34
|
}
|
|
21
35
|
}
|
|
@@ -24,10 +38,14 @@ __decorate([
|
|
|
24
38
|
inject(Identifiers.Application.Instance),
|
|
25
39
|
__metadata("design:type", Object)
|
|
26
40
|
], ChainedVerifier.prototype, "app", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
inject(Identifiers.Cryptography.Configuration),
|
|
43
|
+
__metadata("design:type", Object)
|
|
44
|
+
], ChainedVerifier.prototype, "configuration", void 0);
|
|
27
45
|
__decorate([
|
|
28
46
|
inject(Identifiers.State.Store),
|
|
29
47
|
__metadata("design:type", Object)
|
|
30
|
-
], ChainedVerifier.prototype, "
|
|
48
|
+
], ChainedVerifier.prototype, "store", void 0);
|
|
31
49
|
ChainedVerifier = __decorate([
|
|
32
50
|
injectable()
|
|
33
51
|
], ChainedVerifier);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chained-verifier.js","sourceRoot":"","sources":["../../source/verifiers/chained-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACzE,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,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAGlC,IAAM,eAAe,GAArB,MAAM,eAAe;IAUpB,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,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YACvD,CAAC;QACF,CAAC;aAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE,CAAC;YACvE,MAAM,IAAI,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvD,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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class GasLimitVerifier implements Contracts.Processor.Handler {
|
|
3
|
+
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
+
private readonly configuration;
|
|
5
|
+
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=gas-limit-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gas-limit-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/gas-limit-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
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 { inject, injectable } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let GasLimitVerifier = class GasLimitVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
if (unit.getBlock().data.number === this.configuration.getGenesisHeight()) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const maxGasLimit = this.configuration.getMilestone().block.maxGasLimit;
|
|
18
|
+
if (unit.getBlock().data.gasUsed > maxGasLimit) {
|
|
19
|
+
throw new Exceptions.ExceededGasLimit(unit.getBlock(), maxGasLimit);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
__decorate([
|
|
24
|
+
inject(Identifiers.Application.Instance),
|
|
25
|
+
__metadata("design:type", Object)
|
|
26
|
+
], GasLimitVerifier.prototype, "app", void 0);
|
|
27
|
+
__decorate([
|
|
28
|
+
inject(Identifiers.Cryptography.Configuration),
|
|
29
|
+
__metadata("design:type", Object)
|
|
30
|
+
], GasLimitVerifier.prototype, "configuration", void 0);
|
|
31
|
+
GasLimitVerifier = __decorate([
|
|
32
|
+
injectable()
|
|
33
|
+
], GasLimitVerifier);
|
|
34
|
+
export { GasLimitVerifier };
|
|
35
|
+
//# sourceMappingURL=gas-limit-verifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gas-limit-verifier.js","sourceRoot":"","sources":["../../source/verifiers/gas-limit-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAOrB,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,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,WAAW,CAAC,CAAC;QACrE,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,7 +1,8 @@
|
|
|
1
1
|
import { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class GeneratorVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
-
private readonly
|
|
4
|
+
private readonly configuration;
|
|
5
|
+
private readonly proposerCalculator;
|
|
5
6
|
private readonly validatorSet;
|
|
6
7
|
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
7
8
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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,
|
|
1
|
+
{"version":3,"file":"generator-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -11,12 +11,12 @@ import { inject, injectable } from "@mainsail/container";
|
|
|
11
11
|
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
12
|
let GeneratorVerifier = class GeneratorVerifier {
|
|
13
13
|
async execute(unit) {
|
|
14
|
-
if (unit.getBlock().data.
|
|
14
|
+
if (unit.getBlock().data.number === this.configuration.getGenesisHeight()) {
|
|
15
15
|
return;
|
|
16
16
|
}
|
|
17
|
-
const validatorIndex = this.
|
|
17
|
+
const validatorIndex = this.proposerCalculator.getValidatorIndex(unit.getBlock().data.round);
|
|
18
18
|
const validator = this.validatorSet.getValidator(validatorIndex);
|
|
19
|
-
if (unit.getBlock().data.
|
|
19
|
+
if (unit.getBlock().data.proposer !== validator.address) {
|
|
20
20
|
throw new Exceptions.InvalidGenerator(unit.getBlock(), validator.address);
|
|
21
21
|
}
|
|
22
22
|
}
|
|
@@ -26,9 +26,13 @@ __decorate([
|
|
|
26
26
|
__metadata("design:type", Object)
|
|
27
27
|
], GeneratorVerifier.prototype, "app", void 0);
|
|
28
28
|
__decorate([
|
|
29
|
-
inject(Identifiers.
|
|
29
|
+
inject(Identifiers.Cryptography.Configuration),
|
|
30
30
|
__metadata("design:type", Object)
|
|
31
|
-
], GeneratorVerifier.prototype, "
|
|
31
|
+
], GeneratorVerifier.prototype, "configuration", void 0);
|
|
32
|
+
__decorate([
|
|
33
|
+
inject(Identifiers.BlockchainUtils.ProposerCalculator),
|
|
34
|
+
__metadata("design:type", Object)
|
|
35
|
+
], GeneratorVerifier.prototype, "proposerCalculator", void 0);
|
|
32
36
|
__decorate([
|
|
33
37
|
inject(Identifiers.ValidatorSet.Service),
|
|
34
38
|
__metadata("design:type", Object)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generator-verifier.js","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;
|
|
1
|
+
{"version":3,"file":"generator-verifier.js","sourceRoot":"","sources":["../../source/verifiers/generator-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAatB,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,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;QAC3E,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,5 +1,12 @@
|
|
|
1
1
|
export * from "./chained-verifier.js";
|
|
2
|
+
export * from "./gas-limit-verifier.js";
|
|
2
3
|
export * from "./generator-verifier.js";
|
|
3
|
-
export * from "./
|
|
4
|
+
export * from "./legacy-attribute-verifier.js";
|
|
5
|
+
export * from "./reward-verifier.js";
|
|
6
|
+
export * from "./size-verifier.js";
|
|
4
7
|
export * from "./timestamp-verifier.js";
|
|
8
|
+
export * from "./transaction-duplicates-verifier.js";
|
|
9
|
+
export * from "./transaction-length-verifier.js";
|
|
10
|
+
export * from "./transaction-root-verifier.js";
|
|
11
|
+
export * from "./version-verifier.js";
|
|
5
12
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../source/verifiers/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../source/verifiers/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,yBAAyB,CAAC;AACxC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,sCAAsC,CAAC;AACrD,cAAc,kCAAkC,CAAC;AACjD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,uBAAuB,CAAC"}
|
|
@@ -1,5 +1,12 @@
|
|
|
1
1
|
export * from "./chained-verifier.js";
|
|
2
|
+
export * from "./gas-limit-verifier.js";
|
|
2
3
|
export * from "./generator-verifier.js";
|
|
3
|
-
export * from "./
|
|
4
|
+
export * from "./legacy-attribute-verifier.js";
|
|
5
|
+
export * from "./reward-verifier.js";
|
|
6
|
+
export * from "./size-verifier.js";
|
|
4
7
|
export * from "./timestamp-verifier.js";
|
|
8
|
+
export * from "./transaction-duplicates-verifier.js";
|
|
9
|
+
export * from "./transaction-length-verifier.js";
|
|
10
|
+
export * from "./transaction-root-verifier.js";
|
|
11
|
+
export * from "./version-verifier.js";
|
|
5
12
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../source/verifiers/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../source/verifiers/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,yBAAyB,CAAC;AACxC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,sCAAsC,CAAC;AACrD,cAAc,kCAAkC,CAAC;AACjD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class LegacyAttributeVerifier implements Contracts.Processor.Handler {
|
|
3
|
+
private readonly evm;
|
|
4
|
+
private readonly transactionVerifier;
|
|
5
|
+
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=legacy-attribute-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-attribute-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/legacy-attribute-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
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 { inject, injectable, tagged } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let LegacyAttributeVerifier = class LegacyAttributeVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
const senders = new Map();
|
|
15
|
+
for (const transaction of unit.getBlock().transactions) {
|
|
16
|
+
const { from, legacySecondSignature, senderLegacyAddress } = transaction.data;
|
|
17
|
+
if (!senders.has(from)) {
|
|
18
|
+
senders.set(from, await this.evm.getLegacyAttributes(from, senderLegacyAddress));
|
|
19
|
+
}
|
|
20
|
+
const legacyAttributes = senders.get(from);
|
|
21
|
+
if (!legacyAttributes?.secondPublicKey) {
|
|
22
|
+
if (legacySecondSignature) {
|
|
23
|
+
throw new Exceptions.UnexpectedLegacySecondSignatureError();
|
|
24
|
+
}
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
await this.transactionVerifier.verifyLegacySecondSignature(transaction.data, legacyAttributes.secondPublicKey);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
__decorate([
|
|
32
|
+
inject(Identifiers.Evm.Instance),
|
|
33
|
+
tagged("instance", "evm"),
|
|
34
|
+
__metadata("design:type", Object)
|
|
35
|
+
], LegacyAttributeVerifier.prototype, "evm", void 0);
|
|
36
|
+
__decorate([
|
|
37
|
+
inject(Identifiers.Cryptography.Transaction.Verifier),
|
|
38
|
+
__metadata("design:type", Object)
|
|
39
|
+
], LegacyAttributeVerifier.prototype, "transactionVerifier", void 0);
|
|
40
|
+
LegacyAttributeVerifier = __decorate([
|
|
41
|
+
injectable()
|
|
42
|
+
], LegacyAttributeVerifier);
|
|
43
|
+
export { LegacyAttributeVerifier };
|
|
44
|
+
//# sourceMappingURL=legacy-attribute-verifier.js.map
|
|
@@ -0,0 +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;AACjE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAQ5B,KAAK,CAAC,OAAO,CAAC,IAAyC;QAC7D,MAAM,OAAO,GAAG,IAAI,GAAG,EAAiD,CAAC;QAEzE,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,UAAU,CAAC,oCAAoC,EAAE,CAAC;gBAC7D,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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class RewardVerifier implements Contracts.Processor.Handler {
|
|
3
|
+
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
+
private readonly configuration;
|
|
5
|
+
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=reward-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reward-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/reward-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
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 { inject, injectable } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let RewardVerifier = class RewardVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
const reward = this.configuration.getMilestone().reward;
|
|
15
|
+
if (!unit.getBlock().data.reward.isEqualTo(reward)) {
|
|
16
|
+
throw new Exceptions.InvalidReward(unit.getBlock(), reward);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
__decorate([
|
|
21
|
+
inject(Identifiers.Application.Instance),
|
|
22
|
+
__metadata("design:type", Object)
|
|
23
|
+
], RewardVerifier.prototype, "app", void 0);
|
|
24
|
+
__decorate([
|
|
25
|
+
inject(Identifiers.Cryptography.Configuration),
|
|
26
|
+
__metadata("design:type", Object)
|
|
27
|
+
], RewardVerifier.prototype, "configuration", void 0);
|
|
28
|
+
RewardVerifier = __decorate([
|
|
29
|
+
injectable()
|
|
30
|
+
], RewardVerifier);
|
|
31
|
+
export { RewardVerifier };
|
|
32
|
+
//# sourceMappingURL=reward-verifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reward-verifier.js","sourceRoot":"","sources":["../../source/verifiers/reward-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,cAAc,GAApB,MAAM,cAAc;IAOnB,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,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,CAAC;QAC7D,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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class SizeVerifier implements Contracts.Processor.Handler {
|
|
3
|
+
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
+
private readonly configuration;
|
|
5
|
+
private readonly headerSize;
|
|
6
|
+
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=size-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"size-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/size-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
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 { inject, injectable } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let SizeVerifier = class SizeVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
const { maxPayload } = this.configuration.getMilestone().block;
|
|
15
|
+
const block = unit.getBlock();
|
|
16
|
+
const totalSize = this.headerSize() + block.header.payloadSize;
|
|
17
|
+
if (totalSize > maxPayload) {
|
|
18
|
+
throw new Exceptions.MaxPayloadExceeded(block, totalSize, maxPayload);
|
|
19
|
+
}
|
|
20
|
+
const actualSize = Buffer.byteLength(block.serialized, "hex");
|
|
21
|
+
if (totalSize !== actualSize) {
|
|
22
|
+
throw new Exceptions.InvalidPayloadSize(block, totalSize, actualSize);
|
|
23
|
+
}
|
|
24
|
+
let totalPayloadLength = block.transactions.length * 4;
|
|
25
|
+
for (const transaction of block.transactions) {
|
|
26
|
+
totalPayloadLength += transaction.serialized.byteLength;
|
|
27
|
+
}
|
|
28
|
+
if (totalPayloadLength !== block.data.payloadSize) {
|
|
29
|
+
throw new Exceptions.InvalidPayloadSize(block, totalSize, totalPayloadLength);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
__decorate([
|
|
34
|
+
inject(Identifiers.Application.Instance),
|
|
35
|
+
__metadata("design:type", Object)
|
|
36
|
+
], SizeVerifier.prototype, "app", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
inject(Identifiers.Cryptography.Configuration),
|
|
39
|
+
__metadata("design:type", Object)
|
|
40
|
+
], SizeVerifier.prototype, "configuration", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
inject(Identifiers.Cryptography.Block.HeaderSize),
|
|
43
|
+
__metadata("design:type", Function)
|
|
44
|
+
], SizeVerifier.prototype, "headerSize", void 0);
|
|
45
|
+
SizeVerifier = __decorate([
|
|
46
|
+
injectable()
|
|
47
|
+
], SizeVerifier);
|
|
48
|
+
export { SizeVerifier };
|
|
49
|
+
//# sourceMappingURL=size-verifier.js.map
|
|
@@ -0,0 +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;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,YAAY,GAAlB,MAAM,YAAY;IAUjB,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,UAAU,CAAC,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QACvE,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,UAAU,CAAC,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QACvE,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,UAAU,CAAC,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,kBAAkB,CAAC,CAAC;QAC/E,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,8 +1,9 @@
|
|
|
1
1
|
import { Contracts } from "@mainsail/contracts";
|
|
2
2
|
export declare class TimestampVerifier implements Contracts.Processor.Handler {
|
|
3
3
|
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
-
private readonly
|
|
4
|
+
private readonly store;
|
|
5
5
|
private readonly configuration;
|
|
6
|
+
private readonly timestampCalculator;
|
|
6
7
|
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
7
8
|
}
|
|
8
9
|
//# sourceMappingURL=timestamp-verifier.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timestamp-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/timestamp-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"timestamp-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/timestamp-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAGzE,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"}
|
|
@@ -9,18 +9,17 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
9
9
|
};
|
|
10
10
|
import { inject, injectable } from "@mainsail/container";
|
|
11
11
|
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
-
import { Utils } from "@mainsail/kernel";
|
|
13
12
|
import dayjs from "dayjs";
|
|
14
13
|
let TimestampVerifier = class TimestampVerifier {
|
|
15
14
|
async execute(unit) {
|
|
16
|
-
if (unit.getBlock().data.
|
|
15
|
+
if (unit.getBlock().data.number === this.configuration.getGenesisHeight()) {
|
|
17
16
|
return;
|
|
18
17
|
}
|
|
19
18
|
if (unit.getBlock().data.timestamp > dayjs().valueOf() + this.configuration.getMilestone().timeouts.tolerance) {
|
|
20
19
|
throw new Exceptions.FutureBlock(unit.getBlock());
|
|
21
20
|
}
|
|
22
21
|
if (unit.getBlock().data.timestamp <
|
|
23
|
-
|
|
22
|
+
this.timestampCalculator.calculateMinimalTimestamp(this.store.getLastBlock(), unit.getBlock().data.round)) {
|
|
24
23
|
throw new Exceptions.InvalidTimestamp(unit.getBlock());
|
|
25
24
|
}
|
|
26
25
|
}
|
|
@@ -32,11 +31,15 @@ __decorate([
|
|
|
32
31
|
__decorate([
|
|
33
32
|
inject(Identifiers.State.Store),
|
|
34
33
|
__metadata("design:type", Object)
|
|
35
|
-
], TimestampVerifier.prototype, "
|
|
34
|
+
], TimestampVerifier.prototype, "store", void 0);
|
|
36
35
|
__decorate([
|
|
37
36
|
inject(Identifiers.Cryptography.Configuration),
|
|
38
37
|
__metadata("design:type", Object)
|
|
39
38
|
], TimestampVerifier.prototype, "configuration", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
inject(Identifiers.BlockchainUtils.TimestampCalculator),
|
|
41
|
+
__metadata("design:type", Object)
|
|
42
|
+
], TimestampVerifier.prototype, "timestampCalculator", void 0);
|
|
40
43
|
TimestampVerifier = __decorate([
|
|
41
44
|
injectable()
|
|
42
45
|
], TimestampVerifier);
|
|
@@ -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;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,
|
|
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;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,KAAK,MAAM,OAAO,CAAC;AAGnB,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAatB,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,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACnD,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,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACxD,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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class TransactionDuplicatesVerifier implements Contracts.Processor.Handler {
|
|
3
|
+
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
+
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=transaction-duplicates-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-duplicates-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-duplicates-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
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 { inject, injectable } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let TransactionDuplicatesVerifier = class TransactionDuplicatesVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
const block = unit.getBlock();
|
|
15
|
+
const appliedTransactions = new Set();
|
|
16
|
+
for (const transaction of block.transactions) {
|
|
17
|
+
if (appliedTransactions.has(transaction.hash)) {
|
|
18
|
+
throw new Exceptions.DuplicatedTransaction(unit.getBlock(), transaction.hash);
|
|
19
|
+
}
|
|
20
|
+
appliedTransactions.add(transaction.hash);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
__decorate([
|
|
25
|
+
inject(Identifiers.Application.Instance),
|
|
26
|
+
__metadata("design:type", Object)
|
|
27
|
+
], TransactionDuplicatesVerifier.prototype, "app", void 0);
|
|
28
|
+
TransactionDuplicatesVerifier = __decorate([
|
|
29
|
+
injectable()
|
|
30
|
+
], TransactionDuplicatesVerifier);
|
|
31
|
+
export { TransactionDuplicatesVerifier };
|
|
32
|
+
//# sourceMappingURL=transaction-duplicates-verifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-duplicates-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-duplicates-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IAIlC,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,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;YAC/E,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,6 +1,6 @@
|
|
|
1
1
|
import { Contracts } from "@mainsail/contracts";
|
|
2
|
-
export declare class
|
|
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>;
|
|
5
5
|
}
|
|
6
|
-
//# sourceMappingURL=
|
|
6
|
+
//# sourceMappingURL=transaction-length-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-length-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-length-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
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 { inject, injectable } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let TransactionLengthVerifier = class TransactionLengthVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
const block = unit.getBlock();
|
|
15
|
+
if (block.transactions.length !== block.data.transactionsCount) {
|
|
16
|
+
throw new Exceptions.InvalidTransactionsLength(block);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
__decorate([
|
|
21
|
+
inject(Identifiers.Application.Instance),
|
|
22
|
+
__metadata("design:type", Object)
|
|
23
|
+
], TransactionLengthVerifier.prototype, "app", void 0);
|
|
24
|
+
TransactionLengthVerifier = __decorate([
|
|
25
|
+
injectable()
|
|
26
|
+
], TransactionLengthVerifier);
|
|
27
|
+
export { TransactionLengthVerifier };
|
|
28
|
+
//# sourceMappingURL=transaction-length-verifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-length-verifier.js","sourceRoot":"","sources":["../../source/verifiers/transaction-length-verifier.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlE,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAI9B,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,UAAU,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC;QACvD,CAAC;IACF,CAAC;CACD,CAAA;AATmB;IADlB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;sDACa;AAF1C,yBAAyB;IADrC,UAAU,EAAE;GACA,yBAAyB,CAWrC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class TransactionsRootVerifier implements Contracts.Processor.Handler {
|
|
3
|
+
protected readonly app: Contracts.Kernel.Application;
|
|
4
|
+
private readonly hashFactory;
|
|
5
|
+
execute(unit: Contracts.Processor.ProcessableUnit): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=transaction-root-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-root-verifier.d.ts","sourceRoot":"","sources":["../../source/verifiers/transaction-root-verifier.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAEzE,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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
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 { inject, injectable } from "@mainsail/container";
|
|
11
|
+
import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
|
|
12
|
+
let TransactionsRootVerifier = class TransactionsRootVerifier {
|
|
13
|
+
async execute(unit) {
|
|
14
|
+
const block = unit.getBlock();
|
|
15
|
+
const payloadBuffers = [];
|
|
16
|
+
for (const transaction of block.transactions) {
|
|
17
|
+
payloadBuffers.push(Buffer.from(transaction.hash, "hex"));
|
|
18
|
+
}
|
|
19
|
+
const transactionsRoot = await this.hashFactory.sha256(payloadBuffers);
|
|
20
|
+
if (transactionsRoot.toString("hex") !== block.data.transactionsRoot) {
|
|
21
|
+
throw new Exceptions.InvalidTransactionsRoot(block, transactionsRoot.toString("hex"));
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
__decorate([
|
|
26
|
+
inject(Identifiers.Application.Instance),
|
|
27
|
+
__metadata("design:type", Object)
|
|
28
|
+
], TransactionsRootVerifier.prototype, "app", void 0);
|
|
29
|
+
__decorate([
|
|
30
|
+
inject(Identifiers.Cryptography.Hash.Factory),
|
|
31
|
+
__metadata("design:type", Object)
|
|
32
|
+
], TransactionsRootVerifier.prototype, "hashFactory", void 0);
|
|
33
|
+
TransactionsRootVerifier = __decorate([
|
|
34
|
+
injectable()
|
|
35
|
+
], TransactionsRootVerifier);
|
|
36
|
+
export { TransactionsRootVerifier };
|
|
37
|
+
//# sourceMappingURL=transaction-root-verifier.js.map
|