@mainsail/consensus 0.0.1-alpha.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.
Files changed (62) hide show
  1. package/LICENSE +623 -0
  2. package/distribution/aggregator.d.ts +11 -0
  3. package/distribution/aggregator.d.ts.map +1 -0
  4. package/distribution/aggregator.js +58 -0
  5. package/distribution/aggregator.js.map +1 -0
  6. package/distribution/bootstrapper.d.ts +8 -0
  7. package/distribution/bootstrapper.d.ts.map +1 -0
  8. package/distribution/bootstrapper.js +68 -0
  9. package/distribution/bootstrapper.js.map +1 -0
  10. package/distribution/commit-state.d.ts +19 -0
  11. package/distribution/commit-state.d.ts.map +1 -0
  12. package/distribution/commit-state.js +102 -0
  13. package/distribution/commit-state.js.map +1 -0
  14. package/distribution/consensus.d.ts +45 -0
  15. package/distribution/consensus.d.ts.map +1 -0
  16. package/distribution/consensus.js +445 -0
  17. package/distribution/consensus.js.map +1 -0
  18. package/distribution/index.d.ts +6 -0
  19. package/distribution/index.d.ts.map +1 -0
  20. package/distribution/index.js +59 -0
  21. package/distribution/index.js.map +1 -0
  22. package/distribution/processors/abstract-processor.d.ts +16 -0
  23. package/distribution/processors/abstract-processor.d.ts.map +1 -0
  24. package/distribution/processors/abstract-processor.js +52 -0
  25. package/distribution/processors/abstract-processor.js.map +1 -0
  26. package/distribution/processors/commit-processor.d.ts +14 -0
  27. package/distribution/processors/commit-processor.d.ts.map +1 -0
  28. package/distribution/processors/commit-processor.js +103 -0
  29. package/distribution/processors/commit-processor.js.map +1 -0
  30. package/distribution/processors/index.d.ts +5 -0
  31. package/distribution/processors/index.d.ts.map +1 -0
  32. package/distribution/processors/index.js +21 -0
  33. package/distribution/processors/index.js.map +1 -0
  34. package/distribution/processors/precommit-processor.d.ts +12 -0
  35. package/distribution/processors/precommit-processor.d.ts.map +1 -0
  36. package/distribution/processors/precommit-processor.js +81 -0
  37. package/distribution/processors/precommit-processor.js.map +1 -0
  38. package/distribution/processors/prevote-processor.d.ts +12 -0
  39. package/distribution/processors/prevote-processor.d.ts.map +1 -0
  40. package/distribution/processors/prevote-processor.js +81 -0
  41. package/distribution/processors/prevote-processor.js.map +1 -0
  42. package/distribution/processors/proposal-processor.d.ts +16 -0
  43. package/distribution/processors/proposal-processor.d.ts.map +1 -0
  44. package/distribution/processors/proposal-processor.js +148 -0
  45. package/distribution/processors/proposal-processor.js.map +1 -0
  46. package/distribution/round-state-repository.d.ts +9 -0
  47. package/distribution/round-state-repository.d.ts.map +1 -0
  48. package/distribution/round-state-repository.js +54 -0
  49. package/distribution/round-state-repository.js.map +1 -0
  50. package/distribution/round-state.d.ts +49 -0
  51. package/distribution/round-state.d.ts.map +1 -0
  52. package/distribution/round-state.js +315 -0
  53. package/distribution/round-state.js.map +1 -0
  54. package/distribution/scheduler.d.ts +13 -0
  55. package/distribution/scheduler.d.ts.map +1 -0
  56. package/distribution/scheduler.js +125 -0
  57. package/distribution/scheduler.js.map +1 -0
  58. package/distribution/storage.d.ts +19 -0
  59. package/distribution/storage.d.ts.map +1 -0
  60. package/distribution/storage.js +114 -0
  61. package/distribution/storage.js.map +1 -0
  62. package/package.json +41 -0
@@ -0,0 +1,445 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
12
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
13
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
14
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
+ };
16
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
17
+ if (kind === "m") throw new TypeError("Private method is not writable");
18
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
19
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
20
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
21
+ };
22
+ var _Consensus_instances, _Consensus_height, _Consensus_round, _Consensus_step, _Consensus_lockedValue, _Consensus_validValue, _Consensus_didMajorityPrevote, _Consensus_didMajorityPrecommit, _Consensus_isDisposed, _Consensus_handlerLock, _Consensus_isInvalidRoundState, _Consensus_propose, _Consensus_makeProposal, _Consensus_prevote, _Consensus_precommit, _Consensus_bootstrap;
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.Consensus = void 0;
25
+ const container_1 = require("@mainsail/container");
26
+ const contracts_1 = require("@mainsail/contracts");
27
+ const kernel_1 = require("@mainsail/kernel");
28
+ let Consensus = class Consensus {
29
+ constructor() {
30
+ _Consensus_instances.add(this);
31
+ _Consensus_height.set(this, 1);
32
+ _Consensus_round.set(this, 0);
33
+ _Consensus_step.set(this, contracts_1.Contracts.Consensus.Step.Propose);
34
+ _Consensus_lockedValue.set(this, void 0);
35
+ _Consensus_validValue.set(this, void 0);
36
+ _Consensus_didMajorityPrevote.set(this, false);
37
+ _Consensus_didMajorityPrecommit.set(this, false);
38
+ _Consensus_isDisposed.set(this, false);
39
+ // Handler lock is different than commit lock. It is used to prevent parallel processing and it is similar to queue.
40
+ _Consensus_handlerLock.set(this, new kernel_1.Utils.Lock());
41
+ }
42
+ getHeight() {
43
+ return __classPrivateFieldGet(this, _Consensus_height, "f");
44
+ }
45
+ getRound() {
46
+ return __classPrivateFieldGet(this, _Consensus_round, "f");
47
+ }
48
+ // TODO: Only for testing
49
+ setRound(round) {
50
+ __classPrivateFieldSet(this, _Consensus_round, round, "f");
51
+ }
52
+ getStep() {
53
+ return __classPrivateFieldGet(this, _Consensus_step, "f");
54
+ }
55
+ // TODO: Only for testing
56
+ setStep(step) {
57
+ __classPrivateFieldSet(this, _Consensus_step, step, "f");
58
+ }
59
+ getLockedRound() {
60
+ return __classPrivateFieldGet(this, _Consensus_lockedValue, "f") ? __classPrivateFieldGet(this, _Consensus_lockedValue, "f").round : undefined;
61
+ }
62
+ getValidRound() {
63
+ return __classPrivateFieldGet(this, _Consensus_validValue, "f") ? __classPrivateFieldGet(this, _Consensus_validValue, "f").round : undefined;
64
+ }
65
+ // TODO: Only for testing
66
+ setValidRound(round) {
67
+ __classPrivateFieldSet(this, _Consensus_validValue, round, "f");
68
+ }
69
+ getState() {
70
+ return {
71
+ height: __classPrivateFieldGet(this, _Consensus_height, "f"),
72
+ lockedRound: this.getLockedRound(),
73
+ round: __classPrivateFieldGet(this, _Consensus_round, "f"),
74
+ step: __classPrivateFieldGet(this, _Consensus_step, "f"),
75
+ validRound: this.getValidRound(),
76
+ };
77
+ }
78
+ async run() {
79
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_bootstrap).call(this);
80
+ await this.startRound(__classPrivateFieldGet(this, _Consensus_round, "f"));
81
+ await this.handle(this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f")));
82
+ // Rerun previous rounds, in case proposal & +2/3 precommits were received
83
+ for (let index = 0; index < __classPrivateFieldGet(this, _Consensus_round, "f"); index++) {
84
+ await this.handle(this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), index));
85
+ }
86
+ }
87
+ async dispose() {
88
+ this.scheduler.clear();
89
+ __classPrivateFieldSet(this, _Consensus_isDisposed, true, "f");
90
+ await __classPrivateFieldGet(this, _Consensus_handlerLock, "f").runExclusive(async () => { });
91
+ }
92
+ async handle(roundState) {
93
+ await __classPrivateFieldGet(this, _Consensus_handlerLock, "f").runExclusive(async () => {
94
+ if (__classPrivateFieldGet(this, _Consensus_isDisposed, "f")) {
95
+ return;
96
+ }
97
+ if (!roundState.hasProcessorResult() && roundState.hasProposal()) {
98
+ const result = await this.processor.process(roundState);
99
+ roundState.setProcessorResult(result);
100
+ }
101
+ await this.onProposal(roundState);
102
+ await this.onProposalLocked(roundState);
103
+ if (roundState.hasMajorityPrevotes()) {
104
+ await this.onMajorityPrevote(roundState);
105
+ }
106
+ if (roundState.hasMajorityPrevotesAny()) {
107
+ await this.onMajorityPrevoteAny(roundState);
108
+ }
109
+ if (roundState.hasMajorityPrevotesNull()) {
110
+ await this.onMajorityPrevoteNull(roundState);
111
+ }
112
+ if (roundState.hasMajorityPrecommitsAny()) {
113
+ await this.onMajorityPrecommitAny(roundState);
114
+ }
115
+ if (roundState.hasMajorityPrecommits()) {
116
+ await this.onMajorityPrecommit(roundState);
117
+ }
118
+ if (roundState.hasMinorityPrevotesOrPrecommits()) {
119
+ await this.onMinorityWithHigherRound(roundState);
120
+ }
121
+ });
122
+ }
123
+ async handleCommitState(commitState) {
124
+ await __classPrivateFieldGet(this, _Consensus_handlerLock, "f").runExclusive(async () => {
125
+ if (__classPrivateFieldGet(this, _Consensus_isDisposed, "f")) {
126
+ return;
127
+ }
128
+ await this.onMajorityPrecommit(commitState);
129
+ });
130
+ }
131
+ async startRound(round) {
132
+ __classPrivateFieldSet(this, _Consensus_round, round, "f");
133
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Propose, "f");
134
+ __classPrivateFieldSet(this, _Consensus_didMajorityPrevote, false, "f");
135
+ __classPrivateFieldSet(this, _Consensus_didMajorityPrecommit, false, "f");
136
+ this.scheduler.clear();
137
+ if (__classPrivateFieldGet(this, _Consensus_isDisposed, "f")) {
138
+ return;
139
+ }
140
+ this.scheduler.scheduleTimeoutStartRound();
141
+ }
142
+ async onTimeoutStartRound() {
143
+ const roundState = this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"));
144
+ this.logger.info(`>> Starting new round: ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} with proposer: ${roundState.proposer}`);
145
+ this.scheduler.scheduleTimeoutPropose(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"));
146
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_propose).call(this, roundState);
147
+ }
148
+ async onProposal(roundState) {
149
+ const proposal = roundState.getProposal();
150
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") !== contracts_1.Contracts.Consensus.Step.Propose ||
151
+ __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_isInvalidRoundState).call(this, roundState) ||
152
+ !proposal ||
153
+ proposal.validRound !== undefined) {
154
+ return;
155
+ }
156
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Prevote, "f");
157
+ const { block } = proposal.block;
158
+ this.logger.info(`Received proposal ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} blockId: ${block.data.id}`);
159
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_prevote).call(this, roundState.getProcessorResult() ? block.data.id : undefined);
160
+ }
161
+ async onProposalLocked(roundState) {
162
+ const proposal = roundState.getProposal();
163
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") !== contracts_1.Contracts.Consensus.Step.Propose ||
164
+ __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_isInvalidRoundState).call(this, roundState) ||
165
+ !proposal ||
166
+ !proposal.block.lockProof ||
167
+ proposal.validRound === undefined ||
168
+ proposal.validRound >= __classPrivateFieldGet(this, _Consensus_round, "f")) {
169
+ return;
170
+ }
171
+ const { block } = proposal.block;
172
+ this.logger.info(`Received proposal ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} with locked blockId: ${block.data.id}`);
173
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Prevote, "f");
174
+ const lockedRound = this.getLockedRound();
175
+ if ((!lockedRound || lockedRound <= proposal.validRound) && roundState.getProcessorResult()) {
176
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_prevote).call(this, block.data.id);
177
+ }
178
+ else {
179
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_prevote).call(this);
180
+ }
181
+ }
182
+ async onMajorityPrevote(roundState) {
183
+ const proposal = roundState.getProposal();
184
+ if (__classPrivateFieldGet(this, _Consensus_didMajorityPrevote, "f") ||
185
+ __classPrivateFieldGet(this, _Consensus_step, "f") === contracts_1.Contracts.Consensus.Step.Propose ||
186
+ __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_isInvalidRoundState).call(this, roundState) ||
187
+ !proposal ||
188
+ !roundState.getProcessorResult()) {
189
+ return;
190
+ }
191
+ const { block } = proposal.block;
192
+ this.logger.info(`Received +2/3 prevotes for ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} blockId: ${block.data.id}`);
193
+ __classPrivateFieldSet(this, _Consensus_didMajorityPrevote, true, "f");
194
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") === contracts_1.Contracts.Consensus.Step.Prevote) {
195
+ __classPrivateFieldSet(this, _Consensus_lockedValue, roundState, "f");
196
+ __classPrivateFieldSet(this, _Consensus_validValue, roundState, "f");
197
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Precommit, "f");
198
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_precommit).call(this, block.data.id);
199
+ }
200
+ else {
201
+ __classPrivateFieldSet(this, _Consensus_validValue, roundState, "f");
202
+ }
203
+ }
204
+ async onMajorityPrevoteAny(roundState) {
205
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") !== contracts_1.Contracts.Consensus.Step.Prevote || __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_isInvalidRoundState).call(this, roundState)) {
206
+ return;
207
+ }
208
+ this.scheduler.scheduleTimeoutPrevote(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"));
209
+ }
210
+ async onMajorityPrevoteNull(roundState) {
211
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") !== contracts_1.Contracts.Consensus.Step.Prevote || __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_isInvalidRoundState).call(this, roundState)) {
212
+ return;
213
+ }
214
+ this.logger.info(`Received +2/3 prevotes for ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} blockId: null`);
215
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Precommit, "f");
216
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_precommit).call(this);
217
+ }
218
+ async onMajorityPrecommitAny(roundState) {
219
+ if (__classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_isInvalidRoundState).call(this, roundState)) {
220
+ return;
221
+ }
222
+ this.scheduler.scheduleTimeoutPrecommit(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"));
223
+ }
224
+ async onMajorityPrecommit(roundState) {
225
+ // TODO: Only height must match. Round can be any. Add tests
226
+ if (__classPrivateFieldGet(this, _Consensus_didMajorityPrecommit, "f") || roundState.height !== __classPrivateFieldGet(this, _Consensus_height, "f")) {
227
+ return;
228
+ }
229
+ __classPrivateFieldSet(this, _Consensus_didMajorityPrecommit, true, "f");
230
+ const block = roundState.getBlock();
231
+ if (!roundState.getProcessorResult()) {
232
+ this.logger.info(`Block ${block.data.id} on height ${__classPrivateFieldGet(this, _Consensus_height, "f")} received +2/3 precommits but is invalid`);
233
+ return;
234
+ }
235
+ this.logger.info(`Received +2/3 precommits for ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${roundState.round} blockId: ${block.data.id}`);
236
+ await this.commitLock.runExclusive(async () => {
237
+ var _a;
238
+ try {
239
+ await this.processor.commit(roundState);
240
+ }
241
+ catch (error) {
242
+ await this.app.terminate("Failed to commit block", error);
243
+ }
244
+ this.roundStateRepository.clear();
245
+ __classPrivateFieldSet(this, _Consensus_height, (_a = __classPrivateFieldGet(this, _Consensus_height, "f"), _a++, _a), "f");
246
+ __classPrivateFieldSet(this, _Consensus_lockedValue, undefined, "f");
247
+ __classPrivateFieldSet(this, _Consensus_validValue, undefined, "f");
248
+ await this.startRound(0);
249
+ });
250
+ }
251
+ async onMinorityWithHigherRound(roundState) {
252
+ if (roundState.height !== __classPrivateFieldGet(this, _Consensus_height, "f") || roundState.round <= __classPrivateFieldGet(this, _Consensus_round, "f")) {
253
+ return;
254
+ }
255
+ await this.startRound(roundState.round);
256
+ }
257
+ async onTimeoutPropose(height, round) {
258
+ await __classPrivateFieldGet(this, _Consensus_handlerLock, "f").runExclusive(async () => {
259
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") !== contracts_1.Contracts.Consensus.Step.Propose || __classPrivateFieldGet(this, _Consensus_height, "f") !== height || __classPrivateFieldGet(this, _Consensus_round, "f") !== round) {
260
+ return;
261
+ }
262
+ this.logger.info(`Timeout to propose ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} expired`);
263
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Prevote, "f");
264
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_prevote).call(this);
265
+ });
266
+ }
267
+ async onTimeoutPrevote(height, round) {
268
+ await __classPrivateFieldGet(this, _Consensus_handlerLock, "f").runExclusive(async () => {
269
+ if (__classPrivateFieldGet(this, _Consensus_step, "f") !== contracts_1.Contracts.Consensus.Step.Prevote || __classPrivateFieldGet(this, _Consensus_height, "f") !== height || __classPrivateFieldGet(this, _Consensus_round, "f") !== round) {
270
+ return;
271
+ }
272
+ this.logger.info(`Timeout to prevote ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} expired`);
273
+ this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f")).logPrevotes();
274
+ __classPrivateFieldSet(this, _Consensus_step, contracts_1.Contracts.Consensus.Step.Precommit, "f");
275
+ await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_precommit).call(this);
276
+ });
277
+ }
278
+ async onTimeoutPrecommit(height, round) {
279
+ await __classPrivateFieldGet(this, _Consensus_handlerLock, "f").runExclusive(async () => {
280
+ if (__classPrivateFieldGet(this, _Consensus_height, "f") !== height || __classPrivateFieldGet(this, _Consensus_round, "f") !== round) {
281
+ return;
282
+ }
283
+ this.logger.info(`Timeout to precommit ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} expired`);
284
+ this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f")).logPrevotes();
285
+ this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f")).logPrecommits();
286
+ await this.startRound(__classPrivateFieldGet(this, _Consensus_round, "f") + 1);
287
+ });
288
+ }
289
+ };
290
+ exports.Consensus = Consensus;
291
+ _Consensus_height = new WeakMap();
292
+ _Consensus_round = new WeakMap();
293
+ _Consensus_step = new WeakMap();
294
+ _Consensus_lockedValue = new WeakMap();
295
+ _Consensus_validValue = new WeakMap();
296
+ _Consensus_didMajorityPrevote = new WeakMap();
297
+ _Consensus_didMajorityPrecommit = new WeakMap();
298
+ _Consensus_isDisposed = new WeakMap();
299
+ _Consensus_handlerLock = new WeakMap();
300
+ _Consensus_instances = new WeakSet();
301
+ _Consensus_isInvalidRoundState = function _Consensus_isInvalidRoundState(roundState) {
302
+ if (roundState.height !== __classPrivateFieldGet(this, _Consensus_height, "f")) {
303
+ return true;
304
+ }
305
+ if (roundState.round !== __classPrivateFieldGet(this, _Consensus_round, "f")) {
306
+ return true;
307
+ }
308
+ return false;
309
+ };
310
+ _Consensus_propose = async function _Consensus_propose(roundState) {
311
+ if (roundState.hasProposal()) {
312
+ return;
313
+ }
314
+ const registeredProposer = this.validatorsRepository.getValidator(roundState.proposer.getConsensusPublicKey());
315
+ if (registeredProposer === undefined) {
316
+ return;
317
+ }
318
+ this.logger.info(`Found registered proposer: ${roundState.proposer}`);
319
+ const proposal = await __classPrivateFieldGet(this, _Consensus_instances, "m", _Consensus_makeProposal).call(this, roundState, registeredProposer);
320
+ void this.proposalProcessor.process(proposal);
321
+ };
322
+ _Consensus_makeProposal = async function _Consensus_makeProposal(roundState, registeredProposer) {
323
+ if (__classPrivateFieldGet(this, _Consensus_validValue, "f")) {
324
+ const block = __classPrivateFieldGet(this, _Consensus_validValue, "f").getBlock();
325
+ const lockProof = await __classPrivateFieldGet(this, _Consensus_validValue, "f").aggregatePrevotes();
326
+ this.logger.info(`Proposing valid block ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} from round ${this.getValidRound()} with blockId: ${block.data.id}`);
327
+ return await registeredProposer.propose(this.validatorSet.getValidatorIndexByWalletPublicKey(roundState.proposer.getWalletPublicKey()), __classPrivateFieldGet(this, _Consensus_round, "f"), __classPrivateFieldGet(this, _Consensus_validValue, "f").round, block, lockProof);
328
+ }
329
+ const block = await registeredProposer.prepareBlock(roundState.proposer.getWalletPublicKey(), __classPrivateFieldGet(this, _Consensus_round, "f"));
330
+ this.logger.info(`Proposing new block ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")} with blockId: ${block.data.id}`);
331
+ return registeredProposer.propose(this.validatorSet.getValidatorIndexByWalletPublicKey(roundState.proposer.getWalletPublicKey()), __classPrivateFieldGet(this, _Consensus_round, "f"), undefined, block);
332
+ };
333
+ _Consensus_prevote = async function _Consensus_prevote(value) {
334
+ const roundState = this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"));
335
+ for (const validator of this.validatorSet.getActiveValidators()) {
336
+ const localValidator = this.validatorsRepository.getValidator(validator.getConsensusPublicKey());
337
+ if (localValidator === undefined) {
338
+ continue;
339
+ }
340
+ const validatorIndex = this.validatorSet.getValidatorIndexByWalletPublicKey(validator.getWalletPublicKey());
341
+ if (roundState.hasPrevote(validatorIndex)) {
342
+ continue;
343
+ }
344
+ const prevote = await localValidator.prevote(validatorIndex, __classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"), value);
345
+ void this.prevoteProcessor.process(prevote);
346
+ }
347
+ };
348
+ _Consensus_precommit = async function _Consensus_precommit(value) {
349
+ const roundState = this.roundStateRepository.getRoundState(__classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"));
350
+ for (const validator of this.validatorSet.getActiveValidators()) {
351
+ const localValidator = this.validatorsRepository.getValidator(validator.getConsensusPublicKey());
352
+ if (localValidator === undefined) {
353
+ continue;
354
+ }
355
+ const validatorIndex = this.validatorSet.getValidatorIndexByWalletPublicKey(validator.getWalletPublicKey());
356
+ if (roundState.hasPrecommit(validatorIndex)) {
357
+ continue;
358
+ }
359
+ const precommit = await localValidator.precommit(validatorIndex, __classPrivateFieldGet(this, _Consensus_height, "f"), __classPrivateFieldGet(this, _Consensus_round, "f"), value);
360
+ void this.precommitProcessor.process(precommit);
361
+ }
362
+ };
363
+ _Consensus_bootstrap = async function _Consensus_bootstrap() {
364
+ const state = await this.bootstrapper.run();
365
+ const store = this.stateService.getStore();
366
+ if (state && state.height === store.getLastBlock().data.height + 1) {
367
+ __classPrivateFieldSet(this, _Consensus_step, state.step, "f");
368
+ __classPrivateFieldSet(this, _Consensus_height, state.height, "f");
369
+ __classPrivateFieldSet(this, _Consensus_round, state.round, "f");
370
+ __classPrivateFieldSet(this, _Consensus_lockedValue, state.lockedValue, "f");
371
+ __classPrivateFieldSet(this, _Consensus_validValue, state.validValue, "f");
372
+ }
373
+ else {
374
+ if (state) {
375
+ this.logger.warning(`Skipping state restore, because stored height is ${state.height}, but should be ${store.getLastBlock().data.height + 1}`);
376
+ this.roundStateRepository.clear();
377
+ }
378
+ const lastBlock = store.getLastBlock();
379
+ __classPrivateFieldSet(this, _Consensus_height, lastBlock.data.height + 1, "f");
380
+ }
381
+ if (__classPrivateFieldGet(this, _Consensus_height, "f") !== this.configuration.getHeight()) {
382
+ throw new Error(`bootstrapped height ${__classPrivateFieldGet(this, _Consensus_height, "f")} does not match configuration height ${this.configuration.getHeight()}`);
383
+ }
384
+ this.logger.info(`Completed consensus bootstrap for ${__classPrivateFieldGet(this, _Consensus_height, "f")}/${__classPrivateFieldGet(this, _Consensus_round, "f")}/${store.getTotalRound()}`);
385
+ };
386
+ __decorate([
387
+ (0, container_1.inject)(contracts_1.Identifiers.Application.Instance),
388
+ __metadata("design:type", Object)
389
+ ], Consensus.prototype, "app", void 0);
390
+ __decorate([
391
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.Bootstrapper),
392
+ __metadata("design:type", Object)
393
+ ], Consensus.prototype, "bootstrapper", void 0);
394
+ __decorate([
395
+ (0, container_1.inject)(contracts_1.Identifiers.Cryptography.Configuration),
396
+ __metadata("design:type", Object)
397
+ ], Consensus.prototype, "configuration", void 0);
398
+ __decorate([
399
+ (0, container_1.inject)(contracts_1.Identifiers.Processor.BlockProcessor),
400
+ __metadata("design:type", Object)
401
+ ], Consensus.prototype, "processor", void 0);
402
+ __decorate([
403
+ (0, container_1.inject)(contracts_1.Identifiers.State.Service),
404
+ __metadata("design:type", Object)
405
+ ], Consensus.prototype, "stateService", void 0);
406
+ __decorate([
407
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.Processor.Proposal),
408
+ __metadata("design:type", Object)
409
+ ], Consensus.prototype, "proposalProcessor", void 0);
410
+ __decorate([
411
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.Processor.PreVote),
412
+ __metadata("design:type", Object)
413
+ ], Consensus.prototype, "prevoteProcessor", void 0);
414
+ __decorate([
415
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.Processor.PreCommit),
416
+ __metadata("design:type", Object)
417
+ ], Consensus.prototype, "precommitProcessor", void 0);
418
+ __decorate([
419
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.Scheduler),
420
+ __metadata("design:type", Object)
421
+ ], Consensus.prototype, "scheduler", void 0);
422
+ __decorate([
423
+ (0, container_1.inject)(contracts_1.Identifiers.Validator.Repository),
424
+ __metadata("design:type", Object)
425
+ ], Consensus.prototype, "validatorsRepository", void 0);
426
+ __decorate([
427
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.RoundStateRepository),
428
+ __metadata("design:type", Object)
429
+ ], Consensus.prototype, "roundStateRepository", void 0);
430
+ __decorate([
431
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.CommitLock),
432
+ __metadata("design:type", Object)
433
+ ], Consensus.prototype, "commitLock", void 0);
434
+ __decorate([
435
+ (0, container_1.inject)(contracts_1.Identifiers.ValidatorSet.Service),
436
+ __metadata("design:type", Object)
437
+ ], Consensus.prototype, "validatorSet", void 0);
438
+ __decorate([
439
+ (0, container_1.inject)(contracts_1.Identifiers.Services.Log.Service),
440
+ __metadata("design:type", Object)
441
+ ], Consensus.prototype, "logger", void 0);
442
+ exports.Consensus = Consensus = __decorate([
443
+ (0, container_1.injectable)()
444
+ ], Consensus);
445
+ //# sourceMappingURL=consensus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consensus.js","sourceRoot":"","sources":["../source/consensus.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { Providers } from "@mainsail/kernel";
2
+ export declare class ServiceProvider extends Providers.ServiceProvider {
3
+ register(): Promise<void>;
4
+ dispose(): Promise<void>;
5
+ }
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAS,MAAM,kBAAkB,CAAC;AAYpD,qBAAa,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IA+BzB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;CAuBrC"}
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ServiceProvider = void 0;
4
+ const contracts_1 = require("@mainsail/contracts");
5
+ const kernel_1 = require("@mainsail/kernel");
6
+ const aggregator_1 = require("./aggregator");
7
+ const bootstrapper_1 = require("./bootstrapper");
8
+ const commit_state_1 = require("./commit-state");
9
+ const consensus_1 = require("./consensus");
10
+ const processors_1 = require("./processors");
11
+ const round_state_repository_1 = require("./round-state-repository");
12
+ const scheduler_1 = require("./scheduler");
13
+ const storage_1 = require("./storage");
14
+ class ServiceProvider extends kernel_1.Providers.ServiceProvider {
15
+ async register() {
16
+ this.app.bind(contracts_1.Identifiers.Consensus.Aggregator).to(aggregator_1.Aggregator).inSingletonScope();
17
+ this.app.bind(contracts_1.Identifiers.Consensus.RoundStateRepository).to(round_state_repository_1.RoundStateRepository).inSingletonScope();
18
+ this.app.bind(contracts_1.Identifiers.Consensus.Scheduler).to(scheduler_1.Scheduler).inSingletonScope();
19
+ this.app.bind(contracts_1.Identifiers.Consensus.Processor.Proposal).to(processors_1.ProposalProcessor).inSingletonScope();
20
+ this.app.bind(contracts_1.Identifiers.Consensus.Processor.PreVote).to(processors_1.PrevoteProcessor).inSingletonScope();
21
+ this.app.bind(contracts_1.Identifiers.Consensus.Processor.PreCommit).to(processors_1.PrecommitProcessor).inSingletonScope();
22
+ this.app.bind(contracts_1.Identifiers.Consensus.Processor.Commit).to(processors_1.CommitProcessor).inSingletonScope();
23
+ this.app.bind(contracts_1.Identifiers.Consensus.CommitLock).toConstantValue(new kernel_1.Utils.Lock());
24
+ this.app
25
+ .bind(contracts_1.Identifiers.Consensus.CommitState.Factory)
26
+ .toFactory((context) => (commit) => context.container.resolve(commit_state_1.CommitState).configure(commit));
27
+ // Storage for prevotes, precommits and proposals
28
+ const storage = this.app.get(contracts_1.Identifiers.Database.Instance.Consensus);
29
+ this.app.bind(contracts_1.Identifiers.Database.Storage.Proposal).toConstantValue(storage.openDB({ name: "proposals" }));
30
+ this.app.bind(contracts_1.Identifiers.Database.Storage.PreVote).toConstantValue(storage.openDB({ name: "prevotes" }));
31
+ this.app.bind(contracts_1.Identifiers.Database.Storage.PreCommit).toConstantValue(storage.openDB({ name: "precommits" }));
32
+ this.app
33
+ .bind(contracts_1.Identifiers.Database.Storage.ConsensusState)
34
+ .toConstantValue(storage.openDB({ name: "consensus" }));
35
+ this.app.bind(contracts_1.Identifiers.Consensus.Storage).to(storage_1.Storage).inSingletonScope();
36
+ this.app.bind(contracts_1.Identifiers.Consensus.Bootstrapper).to(bootstrapper_1.Bootstrapper).inSingletonScope();
37
+ this.app.bind(contracts_1.Identifiers.Consensus.Service).toConstantValue(this.app.resolve(consensus_1.Consensus));
38
+ }
39
+ async dispose() {
40
+ const consensus = this.app.get(contracts_1.Identifiers.Consensus.Service);
41
+ await consensus.dispose();
42
+ const storage = this.app.get(contracts_1.Identifiers.Consensus.Storage);
43
+ await storage.clear();
44
+ await storage.saveState(consensus.getState());
45
+ const roundStates = this.app
46
+ .get(contracts_1.Identifiers.Consensus.RoundStateRepository)
47
+ .getRoundStates();
48
+ const proposals = roundStates
49
+ .map((roundState) => roundState.getProposal())
50
+ .filter((proposal) => !!proposal);
51
+ await storage.saveProposals(proposals);
52
+ const prevotes = roundStates.flatMap((roundState) => roundState.getPrevotes());
53
+ await storage.savePrevotes(prevotes);
54
+ const precommits = roundStates.flatMap((roundState) => roundState.getPrecommits());
55
+ await storage.savePrecommits(precommits);
56
+ }
57
+ }
58
+ exports.ServiceProvider = ServiceProvider;
59
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { Contracts } from "@mainsail/contracts";
2
+ export declare class AbstractProcessor {
3
+ protected readonly app: Contracts.Kernel.Application;
4
+ protected readonly commitLock: Contracts.Kernel.Lock;
5
+ private readonly stateService;
6
+ private readonly cryptoConfiguration;
7
+ protected hasValidHeightOrRound(message: {
8
+ height: number;
9
+ round: number;
10
+ }): boolean;
11
+ protected isRoundInBounds(message: {
12
+ round: number;
13
+ }): boolean;
14
+ protected getConsensus(): Contracts.Consensus.ConsensusService;
15
+ }
16
+ //# sourceMappingURL=abstract-processor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstract-processor.d.ts","sourceRoot":"","sources":["../../source/processors/abstract-processor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAI7D,qBACa,iBAAiB;IAE7B,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAG,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC;IAGtD,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC;IAGtD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA2B;IAGxD,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAkC;IAEtE,SAAS,CAAC,qBAAqB,CAAC,OAAO,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO;IAIpF,SAAS,CAAC,eAAe,CAAC,OAAO,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO;IAW9D,SAAS,CAAC,YAAY,IAAI,SAAS,CAAC,SAAS,CAAC,gBAAgB;CAG9D"}
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.AbstractProcessor = void 0;
16
+ const container_1 = require("@mainsail/container");
17
+ const contracts_1 = require("@mainsail/contracts");
18
+ const kernel_1 = require("@mainsail/kernel");
19
+ const dayjs_1 = __importDefault(require("dayjs"));
20
+ let AbstractProcessor = class AbstractProcessor {
21
+ hasValidHeightOrRound(message) {
22
+ return message.height === this.getConsensus().getHeight() && message.round >= this.getConsensus().getRound();
23
+ }
24
+ isRoundInBounds(message) {
25
+ const earliestTime = kernel_1.Utils.timestampCalculator.calculateMinimalTimestamp(this.stateService.getStore().getLastBlock(), message.round, this.cryptoConfiguration) - 500; // Allow time drift between nodes
26
+ return (0, dayjs_1.default)().isAfter((0, dayjs_1.default)(earliestTime));
27
+ }
28
+ getConsensus() {
29
+ return this.app.get(contracts_1.Identifiers.Consensus.Service);
30
+ }
31
+ };
32
+ exports.AbstractProcessor = AbstractProcessor;
33
+ __decorate([
34
+ (0, container_1.inject)(contracts_1.Identifiers.Application.Instance),
35
+ __metadata("design:type", Object)
36
+ ], AbstractProcessor.prototype, "app", void 0);
37
+ __decorate([
38
+ (0, container_1.inject)(contracts_1.Identifiers.Consensus.CommitLock),
39
+ __metadata("design:type", Object)
40
+ ], AbstractProcessor.prototype, "commitLock", void 0);
41
+ __decorate([
42
+ (0, container_1.inject)(contracts_1.Identifiers.State.Service),
43
+ __metadata("design:type", Object)
44
+ ], AbstractProcessor.prototype, "stateService", void 0);
45
+ __decorate([
46
+ (0, container_1.inject)(contracts_1.Identifiers.Cryptography.Configuration),
47
+ __metadata("design:type", Object)
48
+ ], AbstractProcessor.prototype, "cryptoConfiguration", void 0);
49
+ exports.AbstractProcessor = AbstractProcessor = __decorate([
50
+ (0, container_1.injectable)()
51
+ ], AbstractProcessor);
52
+ //# sourceMappingURL=abstract-processor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstract-processor.js","sourceRoot":"","sources":["../../source/processors/abstract-processor.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,mDAAyD;AACzD,mDAA6D;AAC7D,6CAAyC;AACzC,kDAA0B;AAGnB,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAanB,qBAAqB,CAAC,OAA0C;QACzE,OAAO,OAAO,CAAC,MAAM,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC,SAAS,EAAE,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC,QAAQ,EAAE,CAAC;IAC9G,CAAC;IAES,eAAe,CAAC,OAA0B;QACnD,MAAM,YAAY,GACjB,cAAK,CAAC,mBAAmB,CAAC,yBAAyB,CAClD,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,YAAY,EAAE,EAC3C,OAAO,CAAC,KAAK,EACb,IAAI,CAAC,mBAAmB,CACxB,GAAG,GAAG,CAAC,CAAC,iCAAiC;QAE3C,OAAO,IAAA,eAAK,GAAE,CAAC,OAAO,CAAC,IAAA,eAAK,EAAC,YAAY,CAAC,CAAC,CAAC;IAC7C,CAAC;IAES,YAAY;QACrB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAuC,uBAAW,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IAC1F,CAAC;CACD,CAAA;AA/BY,8CAAiB;AAEV;IADlB,IAAA,kBAAM,EAAC,uBAAW,CAAC,WAAW,CAAC,QAAQ,CAAC;;8CACa;AAGnC;IADlB,IAAA,kBAAM,EAAC,uBAAW,CAAC,SAAS,CAAC,UAAU,CAAC;;qDACa;AAGrC;IADhB,IAAA,kBAAM,EAAC,uBAAW,CAAC,KAAK,CAAC,OAAO,CAAC;;uDACsB;AAGvC;IADhB,IAAA,kBAAM,EAAC,uBAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;8DACuB;4BAX1D,iBAAiB;IAD7B,IAAA,sBAAU,GAAE;GACA,iBAAiB,CA+B7B"}