@digitaldefiance/node-ecies-lib 4.8.1 → 4.10.6
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/package.json +10 -5
- package/src/builders/member-builder.d.ts +1 -1
- package/src/builders/member-builder.d.ts.map +1 -1
- package/src/builders/member-builder.js +3 -1
- package/src/builders/member-builder.js.map +1 -1
- package/src/constants.d.ts.map +1 -1
- package/src/constants.js +31 -25
- package/src/constants.js.map +1 -1
- package/src/interfaces/index.d.ts +1 -2
- package/src/interfaces/index.d.ts.map +1 -1
- package/src/interfaces/index.js +6 -3
- package/src/interfaces/index.js.map +1 -1
- package/src/interfaces/member-with-mnemonic.d.ts +3 -2
- package/src/interfaces/member-with-mnemonic.d.ts.map +1 -1
- package/src/interfaces/member.d.ts +30 -12
- package/src/interfaces/member.d.ts.map +1 -1
- package/src/interfaces/multi-encrypted-message.d.ts +2 -1
- package/src/interfaces/multi-encrypted-message.d.ts.map +1 -1
- package/src/interfaces/multi-encrypted-parsed-header.d.ts +3 -2
- package/src/interfaces/multi-encrypted-parsed-header.d.ts.map +1 -1
- package/src/interfaces/platform-buffer.d.ts +9 -0
- package/src/interfaces/platform-buffer.d.ts.map +1 -0
- package/src/interfaces/platform-buffer.js +3 -0
- package/src/interfaces/platform-buffer.js.map +1 -0
- package/src/interfaces/platform-id.d.ts +2 -2
- package/src/interfaces/platform-id.d.ts.map +1 -1
- package/src/interfaces/voting-poll.d.ts +32 -31
- package/src/interfaces/voting-poll.d.ts.map +1 -1
- package/src/interfaces/voting-poll.js.map +1 -1
- package/src/lib/id-providers/buffer-provider.d.ts +54 -0
- package/src/lib/id-providers/buffer-provider.d.ts.map +1 -0
- package/src/lib/id-providers/buffer-provider.js +93 -0
- package/src/lib/id-providers/buffer-provider.js.map +1 -0
- package/src/lib/index.d.ts +1 -0
- package/src/lib/index.d.ts.map +1 -1
- package/src/lib/index.js +1 -0
- package/src/lib/index.js.map +1 -1
- package/src/lib/voting/audit.d.ts +39 -48
- package/src/lib/voting/audit.d.ts.map +1 -1
- package/src/lib/voting/audit.js +103 -111
- package/src/lib/voting/audit.js.map +1 -1
- package/src/lib/voting/bulletin-board.d.ts +47 -80
- package/src/lib/voting/bulletin-board.d.ts.map +1 -1
- package/src/lib/voting/bulletin-board.js +95 -226
- package/src/lib/voting/bulletin-board.js.map +1 -1
- package/src/lib/voting/encoder.d.ts +7 -15
- package/src/lib/voting/encoder.d.ts.map +1 -1
- package/src/lib/voting/encoder.js +11 -107
- package/src/lib/voting/encoder.js.map +1 -1
- package/src/lib/voting/enumerations/index.d.ts +6 -0
- package/src/lib/voting/enumerations/index.d.ts.map +1 -0
- package/src/lib/voting/enumerations/index.js +14 -0
- package/src/lib/voting/enumerations/index.js.map +1 -0
- package/src/lib/voting/event-logger.d.ts +13 -74
- package/src/lib/voting/event-logger.d.ts.map +1 -1
- package/src/lib/voting/event-logger.js +19 -140
- package/src/lib/voting/event-logger.js.map +1 -1
- package/src/lib/voting/examples.d.ts +112 -0
- package/src/lib/voting/examples.d.ts.map +1 -0
- package/src/lib/voting/examples.js +386 -0
- package/src/lib/voting/examples.js.map +1 -0
- package/src/lib/voting/factory.d.ts +38 -9
- package/src/lib/voting/factory.d.ts.map +1 -1
- package/src/lib/voting/factory.js +42 -8
- package/src/lib/voting/factory.js.map +1 -1
- package/src/lib/voting/hierarchical-aggregator.d.ts +44 -0
- package/src/lib/voting/hierarchical-aggregator.d.ts.map +1 -0
- package/src/lib/voting/hierarchical-aggregator.js +56 -0
- package/src/lib/voting/hierarchical-aggregator.js.map +1 -0
- package/src/lib/voting/index.d.ts +43 -7
- package/src/lib/voting/index.d.ts.map +1 -1
- package/src/lib/voting/index.js +53 -10
- package/src/lib/voting/index.js.map +1 -1
- package/src/lib/voting/interfaces/aggregated-tally.d.ts +10 -0
- package/src/lib/voting/interfaces/aggregated-tally.d.ts.map +1 -0
- package/src/lib/voting/interfaces/aggregated-tally.js +3 -0
- package/src/lib/voting/interfaces/aggregated-tally.js.map +1 -0
- package/src/lib/voting/interfaces/audit-entry.d.ts +10 -0
- package/src/lib/voting/interfaces/audit-entry.d.ts.map +1 -0
- package/src/lib/voting/interfaces/audit-entry.js +3 -0
- package/src/lib/voting/interfaces/audit-entry.js.map +1 -0
- package/src/lib/voting/interfaces/audit-log.d.ts +10 -0
- package/src/lib/voting/interfaces/audit-log.d.ts.map +1 -0
- package/src/lib/voting/interfaces/audit-log.js +3 -0
- package/src/lib/voting/interfaces/audit-log.js.map +1 -0
- package/src/lib/voting/interfaces/bulletin-board-entry.d.ts +10 -0
- package/src/lib/voting/interfaces/bulletin-board-entry.d.ts.map +1 -0
- package/src/lib/voting/interfaces/bulletin-board-entry.js +3 -0
- package/src/lib/voting/interfaces/bulletin-board-entry.js.map +1 -0
- package/src/lib/voting/interfaces/bulletin-board.d.ts +10 -0
- package/src/lib/voting/interfaces/bulletin-board.d.ts.map +1 -0
- package/src/lib/voting/interfaces/bulletin-board.js +3 -0
- package/src/lib/voting/interfaces/bulletin-board.js.map +1 -0
- package/src/lib/voting/interfaces/checkpoint-manager-extended.d.ts +10 -0
- package/src/lib/voting/interfaces/checkpoint-manager-extended.d.ts.map +1 -0
- package/src/lib/voting/interfaces/checkpoint-manager-extended.js +3 -0
- package/src/lib/voting/interfaces/checkpoint-manager-extended.js.map +1 -0
- package/src/lib/voting/interfaces/checkpoint-manager.d.ts +9 -0
- package/src/lib/voting/interfaces/checkpoint-manager.d.ts.map +1 -0
- package/src/lib/voting/interfaces/checkpoint-manager.js +3 -0
- package/src/lib/voting/interfaces/checkpoint-manager.js.map +1 -0
- package/src/lib/voting/interfaces/checkpoint-metadata.d.ts +8 -0
- package/src/lib/voting/interfaces/checkpoint-metadata.d.ts.map +1 -0
- package/src/lib/voting/interfaces/checkpoint-metadata.js +3 -0
- package/src/lib/voting/interfaces/checkpoint-metadata.js.map +1 -0
- package/src/lib/voting/interfaces/ecies-service-with-voting.d.ts +8 -0
- package/src/lib/voting/interfaces/ecies-service-with-voting.d.ts.map +1 -0
- package/src/lib/voting/interfaces/ecies-service-with-voting.js +3 -0
- package/src/lib/voting/interfaces/ecies-service-with-voting.js.map +1 -0
- package/src/lib/voting/interfaces/encrypted-vote.d.ts +10 -0
- package/src/lib/voting/interfaces/encrypted-vote.d.ts.map +1 -0
- package/src/lib/voting/interfaces/encrypted-vote.js +3 -0
- package/src/lib/voting/interfaces/encrypted-vote.js.map +1 -0
- package/src/lib/voting/interfaces/event-log-entry.d.ts +10 -0
- package/src/lib/voting/interfaces/event-log-entry.d.ts.map +1 -0
- package/src/lib/voting/interfaces/event-log-entry.js +3 -0
- package/src/lib/voting/interfaces/event-log-entry.js.map +1 -0
- package/src/lib/voting/interfaces/event-logger.d.ts +10 -0
- package/src/lib/voting/interfaces/event-logger.d.ts.map +1 -0
- package/src/lib/voting/interfaces/event-logger.js +3 -0
- package/src/lib/voting/interfaces/event-logger.js.map +1 -0
- package/src/lib/voting/interfaces/index.d.ts +37 -0
- package/src/lib/voting/interfaces/index.d.ts.map +1 -0
- package/src/lib/voting/interfaces/index.js +9 -0
- package/src/lib/voting/interfaces/index.js.map +1 -0
- package/src/lib/voting/interfaces/jurisdiction-config.d.ts +10 -0
- package/src/lib/voting/interfaces/jurisdiction-config.d.ts.map +1 -0
- package/src/lib/voting/interfaces/jurisdiction-config.js +3 -0
- package/src/lib/voting/interfaces/jurisdiction-config.js.map +1 -0
- package/src/lib/voting/interfaces/plaintext-vote.d.ts +10 -0
- package/src/lib/voting/interfaces/plaintext-vote.d.ts.map +1 -0
- package/src/lib/voting/interfaces/plaintext-vote.js +3 -0
- package/src/lib/voting/interfaces/plaintext-vote.js.map +1 -0
- package/src/lib/voting/interfaces/poll-configuration.d.ts +8 -0
- package/src/lib/voting/interfaces/poll-configuration.d.ts.map +1 -0
- package/src/lib/voting/interfaces/poll-configuration.js +3 -0
- package/src/lib/voting/interfaces/poll-configuration.js.map +1 -0
- package/src/lib/voting/interfaces/poll-results.d.ts +8 -0
- package/src/lib/voting/interfaces/poll-results.d.ts.map +1 -0
- package/src/lib/voting/interfaces/poll-results.js +3 -0
- package/src/lib/voting/interfaces/poll-results.js.map +1 -0
- package/src/lib/voting/interfaces/poll-tallier.d.ts +10 -0
- package/src/lib/voting/interfaces/poll-tallier.d.ts.map +1 -0
- package/src/lib/voting/interfaces/poll-tallier.js +3 -0
- package/src/lib/voting/interfaces/poll-tallier.js.map +1 -0
- package/src/lib/voting/interfaces/poll.d.ts +10 -0
- package/src/lib/voting/interfaces/poll.d.ts.map +1 -0
- package/src/lib/voting/interfaces/poll.js +3 -0
- package/src/lib/voting/interfaces/poll.js.map +1 -0
- package/src/lib/voting/interfaces/round-result.d.ts +8 -0
- package/src/lib/voting/interfaces/round-result.d.ts.map +1 -0
- package/src/lib/voting/interfaces/round-result.js +3 -0
- package/src/lib/voting/interfaces/round-result.js.map +1 -0
- package/src/lib/voting/interfaces/state-snapshot.d.ts +15 -0
- package/src/lib/voting/interfaces/state-snapshot.d.ts.map +1 -0
- package/src/lib/voting/interfaces/state-snapshot.js +3 -0
- package/src/lib/voting/interfaces/state-snapshot.js.map +1 -0
- package/src/lib/voting/interfaces/supermajority-config.d.ts +8 -0
- package/src/lib/voting/interfaces/supermajority-config.d.ts.map +1 -0
- package/src/lib/voting/interfaces/supermajority-config.js +3 -0
- package/src/lib/voting/interfaces/supermajority-config.js.map +1 -0
- package/src/lib/voting/interfaces/tally-proof.d.ts +10 -0
- package/src/lib/voting/interfaces/tally-proof.d.ts.map +1 -0
- package/src/lib/voting/interfaces/tally-proof.js +3 -0
- package/src/lib/voting/interfaces/tally-proof.js.map +1 -0
- package/src/lib/voting/interfaces/vote-encoder.d.ts +10 -0
- package/src/lib/voting/interfaces/vote-encoder.d.ts.map +1 -0
- package/src/lib/voting/interfaces/vote-encoder.js +3 -0
- package/src/lib/voting/interfaces/vote-encoder.js.map +1 -0
- package/src/lib/voting/interfaces/vote-logger-extended.d.ts +10 -0
- package/src/lib/voting/interfaces/vote-logger-extended.d.ts.map +1 -0
- package/src/lib/voting/interfaces/vote-logger-extended.js +3 -0
- package/src/lib/voting/interfaces/vote-logger-extended.js.map +1 -0
- package/src/lib/voting/interfaces/vote-logger.d.ts +9 -0
- package/src/lib/voting/interfaces/vote-logger.d.ts.map +1 -0
- package/src/lib/voting/interfaces/vote-logger.js +3 -0
- package/src/lib/voting/interfaces/vote-logger.js.map +1 -0
- package/src/lib/voting/interfaces/voting-consts.d.ts +9 -0
- package/src/lib/voting/interfaces/voting-consts.d.ts.map +1 -0
- package/src/lib/voting/interfaces/voting-consts.js +3 -0
- package/src/lib/voting/interfaces/voting-consts.js.map +1 -0
- package/src/lib/voting/interfaces/voting-key-derivation-options.d.ts +7 -0
- package/src/lib/voting/interfaces/voting-key-derivation-options.d.ts.map +1 -0
- package/src/lib/voting/interfaces/voting-key-derivation-options.js +3 -0
- package/src/lib/voting/interfaces/voting-key-derivation-options.js.map +1 -0
- package/src/lib/voting/interfaces/voting-poll-results.d.ts +7 -0
- package/src/lib/voting/interfaces/voting-poll-results.d.ts.map +1 -0
- package/src/lib/voting/interfaces/voting-poll-results.js +3 -0
- package/src/lib/voting/interfaces/voting-poll-results.js.map +1 -0
- package/src/lib/voting/interfaces/voting-receipt.d.ts +10 -0
- package/src/lib/voting/interfaces/voting-receipt.d.ts.map +1 -0
- package/src/lib/voting/interfaces/voting-receipt.js +3 -0
- package/src/lib/voting/interfaces/voting-receipt.js.map +1 -0
- package/src/lib/voting/interfaces/voting-security-validator.d.ts +8 -0
- package/src/lib/voting/interfaces/voting-security-validator.d.ts.map +1 -0
- package/src/lib/voting/interfaces/voting-security-validator.js +3 -0
- package/src/lib/voting/interfaces/voting-security-validator.js.map +1 -0
- package/src/lib/voting/node-persistent-state.d.ts +40 -0
- package/src/lib/voting/node-persistent-state.d.ts.map +1 -0
- package/src/lib/voting/node-persistent-state.js +222 -0
- package/src/lib/voting/node-persistent-state.js.map +1 -0
- package/src/lib/voting/persistent-state.d.ts +44 -0
- package/src/lib/voting/persistent-state.d.ts.map +1 -0
- package/src/lib/voting/persistent-state.js +106 -0
- package/src/lib/voting/persistent-state.js.map +1 -0
- package/src/lib/voting/poll-core.d.ts +14 -29
- package/src/lib/voting/poll-core.d.ts.map +1 -1
- package/src/lib/voting/poll-core.js +13 -174
- package/src/lib/voting/poll-core.js.map +1 -1
- package/src/lib/voting/poll.d.ts +12 -11
- package/src/lib/voting/poll.d.ts.map +1 -1
- package/src/lib/voting/poll.js +5 -4
- package/src/lib/voting/poll.js.map +1 -1
- package/src/lib/voting/security.d.ts +9 -15
- package/src/lib/voting/security.d.ts.map +1 -1
- package/src/lib/voting/security.js +12 -44
- package/src/lib/voting/security.js.map +1 -1
- package/src/lib/voting/tallier.d.ts +12 -20
- package/src/lib/voting/tallier.d.ts.map +1 -1
- package/src/lib/voting/tallier.js +17 -366
- package/src/lib/voting/tallier.js.map +1 -1
- package/src/lib/voting/test-voter-pool.d.ts +16 -0
- package/src/lib/voting/test-voter-pool.d.ts.map +1 -0
- package/src/lib/voting/test-voter-pool.js +69 -0
- package/src/lib/voting/test-voter-pool.js.map +1 -0
- package/src/lib/voting/us-election-example.d.ts +2 -0
- package/src/lib/voting/us-election-example.d.ts.map +1 -0
- package/src/lib/voting/us-election-example.js +170 -0
- package/src/lib/voting/us-election-example.js.map +1 -0
- package/src/member.d.ts +5 -2
- package/src/member.d.ts.map +1 -1
- package/src/member.js +42 -17
- package/src/member.js.map +1 -1
- package/src/secure-buffer.d.ts +1 -2
- package/src/secure-buffer.d.ts.map +1 -1
- package/src/secure-buffer.js +3 -8
- package/src/secure-buffer.js.map +1 -1
- package/src/services/ecies/crypto-core.d.ts.map +1 -1
- package/src/services/ecies/crypto-core.js +24 -0
- package/src/services/ecies/crypto-core.js.map +1 -1
- package/src/services/ecies/multi-recipient.d.ts +16 -7
- package/src/services/ecies/multi-recipient.d.ts.map +1 -1
- package/src/services/ecies/multi-recipient.js +164 -23
- package/src/services/ecies/multi-recipient.js.map +1 -1
- package/src/services/ecies/service.d.ts +63 -21
- package/src/services/ecies/service.d.ts.map +1 -1
- package/src/services/ecies/service.js +196 -39
- package/src/services/ecies/service.js.map +1 -1
- package/src/services/ecies/single-recipient.d.ts.map +1 -1
- package/src/services/ecies/single-recipient.js +4 -2
- package/src/services/ecies/single-recipient.js.map +1 -1
- package/src/services/encryption-stream.d.ts +1 -1
- package/src/services/encryption-stream.d.ts.map +1 -1
- package/src/services/encryption-stream.js +4 -8
- package/src/services/encryption-stream.js.map +1 -1
- package/src/services/multi-recipient-processor.d.ts +16 -12
- package/src/services/multi-recipient-processor.d.ts.map +1 -1
- package/src/services/multi-recipient-processor.js +29 -10
- package/src/services/multi-recipient-processor.js.map +1 -1
- package/src/test-mocks/mock-backend-member.d.ts +22 -3
- package/src/test-mocks/mock-backend-member.d.ts.map +1 -1
- package/src/test-mocks/mock-backend-member.js +71 -0
- package/src/test-mocks/mock-backend-member.js.map +1 -1
- package/src/lib/voting/types.d.ts +0 -66
- package/src/lib/voting/types.d.ts.map +0 -1
- package/src/lib/voting/types.js +0 -29
- package/src/lib/voting/types.js.map +0 -1
|
@@ -1,372 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PollTallier = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
switch (poll.method) {
|
|
22
|
-
case types_1.VotingMethod.Plurality:
|
|
23
|
-
case types_1.VotingMethod.Approval:
|
|
24
|
-
case types_1.VotingMethod.Weighted:
|
|
25
|
-
return this._tallyAdditive(poll, votes, choiceCount);
|
|
26
|
-
case types_1.VotingMethod.Borda:
|
|
27
|
-
case types_1.VotingMethod.Score:
|
|
28
|
-
return this._tallyScored(poll, votes, choiceCount);
|
|
29
|
-
case types_1.VotingMethod.YesNo:
|
|
30
|
-
case types_1.VotingMethod.YesNoAbstain:
|
|
31
|
-
case types_1.VotingMethod.Supermajority:
|
|
32
|
-
return this._tallyYesNo(poll, votes, choiceCount);
|
|
33
|
-
case types_1.VotingMethod.RankedChoice:
|
|
34
|
-
return this._tallyRankedChoice(poll, votes, choiceCount);
|
|
35
|
-
case types_1.VotingMethod.TwoRound:
|
|
36
|
-
return this._tallyTwoRound(poll, votes, choiceCount);
|
|
37
|
-
case types_1.VotingMethod.STAR:
|
|
38
|
-
return this._tallySTAR(poll, votes, choiceCount);
|
|
39
|
-
case types_1.VotingMethod.STV:
|
|
40
|
-
return this._tallySTV(poll, votes, choiceCount);
|
|
41
|
-
case types_1.VotingMethod.Quadratic:
|
|
42
|
-
return this._tallyQuadratic(poll, votes, choiceCount);
|
|
43
|
-
case types_1.VotingMethod.Consensus:
|
|
44
|
-
return this._tallyConsensus(poll, votes, choiceCount);
|
|
45
|
-
case types_1.VotingMethod.ConsentBased:
|
|
46
|
-
return this._tallyConsentBased(poll, votes, choiceCount);
|
|
47
|
-
default:
|
|
48
|
-
throw new Error(`Unknown voting method: ${poll.method}`);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
_tallyAdditive(poll, votes, choiceCount) {
|
|
52
|
-
const tallies = new Array(choiceCount).fill(0n);
|
|
53
|
-
for (const encrypted of votes.values()) {
|
|
54
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
55
|
-
tallies[i] += this.votingPrivateKey.decrypt(encrypted[i]);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
const maxVotes = tallies.reduce((max, v) => (v > max ? v : max), 0n);
|
|
59
|
-
const winners = tallies
|
|
60
|
-
.map((v, i) => (v === maxVotes ? i : -1))
|
|
61
|
-
.filter((i) => i >= 0);
|
|
62
|
-
return {
|
|
63
|
-
method: poll.method,
|
|
64
|
-
choices: [...poll.choices],
|
|
65
|
-
winner: winners.length === 1 ? winners[0] : undefined,
|
|
66
|
-
winners: winners.length > 1 ? winners : undefined,
|
|
67
|
-
tallies,
|
|
68
|
-
voterCount: poll.voterCount,
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
_tallyScored(poll, votes, choiceCount) {
|
|
72
|
-
return this._tallyAdditive(poll, votes, choiceCount);
|
|
73
|
-
}
|
|
74
|
-
_tallyYesNo(poll, votes, choiceCount) {
|
|
75
|
-
return this._tallyAdditive(poll, votes, choiceCount);
|
|
76
|
-
}
|
|
77
|
-
_tallyRankedChoice(poll, votes, choiceCount) {
|
|
78
|
-
const rounds = [];
|
|
79
|
-
const eliminated = new Set();
|
|
80
|
-
const rankings = this._decryptRankings(votes, choiceCount);
|
|
81
|
-
let round = 0;
|
|
82
|
-
while (true) {
|
|
83
|
-
round++;
|
|
84
|
-
const tallies = this._countFirstChoices(rankings, eliminated, choiceCount);
|
|
85
|
-
const totalVotes = tallies.reduce((sum, v) => sum + v, 0n);
|
|
86
|
-
const majority = totalVotes / 2n;
|
|
87
|
-
let maxVotes = 0n;
|
|
88
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
89
|
-
if (!eliminated.has(i) && tallies[i] > maxVotes)
|
|
90
|
-
maxVotes = tallies[i];
|
|
91
|
-
}
|
|
92
|
-
const topCandidates = tallies
|
|
93
|
-
.map((v, i) => (!eliminated.has(i) && v === maxVotes ? i : -1))
|
|
94
|
-
.filter((i) => i >= 0);
|
|
95
|
-
rounds.push({
|
|
96
|
-
round,
|
|
97
|
-
tallies: [...tallies],
|
|
98
|
-
eliminated: undefined,
|
|
99
|
-
winner: undefined,
|
|
100
|
-
});
|
|
101
|
-
if (maxVotes > majority && topCandidates.length === 1) {
|
|
102
|
-
rounds[rounds.length - 1].winner = topCandidates[0];
|
|
103
|
-
return {
|
|
104
|
-
method: types_1.VotingMethod.RankedChoice,
|
|
105
|
-
choices: [...poll.choices],
|
|
106
|
-
winner: topCandidates[0],
|
|
107
|
-
eliminated: Array.from(eliminated),
|
|
108
|
-
rounds,
|
|
109
|
-
tallies,
|
|
110
|
-
voterCount: poll.voterCount,
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
const remaining = choiceCount - eliminated.size;
|
|
114
|
-
if (remaining === 1) {
|
|
115
|
-
const winner = tallies.findIndex((_, i) => !eliminated.has(i));
|
|
116
|
-
rounds[rounds.length - 1].winner = winner;
|
|
117
|
-
return {
|
|
118
|
-
method: types_1.VotingMethod.RankedChoice,
|
|
119
|
-
choices: [...poll.choices],
|
|
120
|
-
winner,
|
|
121
|
-
eliminated: Array.from(eliminated),
|
|
122
|
-
rounds,
|
|
123
|
-
tallies,
|
|
124
|
-
voterCount: poll.voterCount,
|
|
125
|
-
};
|
|
126
|
-
}
|
|
127
|
-
let minVotes = totalVotes;
|
|
128
|
-
let toEliminate = -1;
|
|
129
|
-
for (let i = choiceCount - 1; i >= 0; i--) {
|
|
130
|
-
if (!eliminated.has(i) && tallies[i] <= minVotes) {
|
|
131
|
-
minVotes = tallies[i];
|
|
132
|
-
toEliminate = i;
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
if (toEliminate === -1)
|
|
136
|
-
break;
|
|
137
|
-
eliminated.add(toEliminate);
|
|
138
|
-
rounds[rounds.length - 1].eliminated = toEliminate;
|
|
139
|
-
}
|
|
140
|
-
const finalTallies = this._countFirstChoices(rankings, eliminated, choiceCount);
|
|
141
|
-
let maxVotes = 0n;
|
|
142
|
-
let winner = 0;
|
|
143
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
144
|
-
if (!eliminated.has(i) && finalTallies[i] > maxVotes) {
|
|
145
|
-
maxVotes = finalTallies[i];
|
|
146
|
-
winner = i;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
return {
|
|
150
|
-
method: types_1.VotingMethod.RankedChoice,
|
|
151
|
-
choices: [...poll.choices],
|
|
152
|
-
winner,
|
|
153
|
-
eliminated: Array.from(eliminated),
|
|
154
|
-
rounds,
|
|
155
|
-
tallies: finalTallies,
|
|
156
|
-
voterCount: poll.voterCount,
|
|
157
|
-
};
|
|
158
|
-
}
|
|
159
|
-
_decryptRankings(votes, choiceCount) {
|
|
160
|
-
const rankings = [];
|
|
161
|
-
for (const encrypted of votes.values()) {
|
|
162
|
-
const rankedChoices = [];
|
|
163
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
164
|
-
const rank = Number(this.votingPrivateKey.decrypt(encrypted[i]));
|
|
165
|
-
if (rank > 0)
|
|
166
|
-
rankedChoices.push({ choice: i, rank });
|
|
167
|
-
}
|
|
168
|
-
rankedChoices.sort((a, b) => a.rank - b.rank);
|
|
169
|
-
rankings.push(rankedChoices.map((rc) => rc.choice));
|
|
170
|
-
}
|
|
171
|
-
return rankings;
|
|
172
|
-
}
|
|
173
|
-
_countFirstChoices(rankings, eliminated, choiceCount) {
|
|
174
|
-
const tallies = new Array(choiceCount).fill(0n);
|
|
175
|
-
for (const ranking of rankings) {
|
|
176
|
-
for (const choice of ranking) {
|
|
177
|
-
if (!eliminated.has(choice)) {
|
|
178
|
-
tallies[choice]++;
|
|
179
|
-
break;
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
return tallies;
|
|
184
|
-
}
|
|
185
|
-
_tallyQuadratic(poll, votes, choiceCount) {
|
|
186
|
-
const tallies = new Array(choiceCount).fill(0n);
|
|
187
|
-
for (const encrypted of votes.values()) {
|
|
188
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
189
|
-
const weight = this.votingPrivateKey.decrypt(encrypted[i]);
|
|
190
|
-
tallies[i] += weight * weight;
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
const maxVotes = tallies.reduce((max, v) => (v > max ? v : max), 0n);
|
|
194
|
-
const winners = tallies
|
|
195
|
-
.map((v, i) => (v === maxVotes ? i : -1))
|
|
196
|
-
.filter((i) => i >= 0);
|
|
197
|
-
return {
|
|
198
|
-
method: types_1.VotingMethod.Quadratic,
|
|
199
|
-
choices: [...poll.choices],
|
|
200
|
-
winner: winners.length === 1 ? winners[0] : undefined,
|
|
201
|
-
winners: winners.length > 1 ? winners : undefined,
|
|
202
|
-
tallies,
|
|
203
|
-
voterCount: poll.voterCount,
|
|
204
|
-
};
|
|
205
|
-
}
|
|
206
|
-
_tallyConsensus(poll, votes, choiceCount) {
|
|
207
|
-
const tallies = new Array(choiceCount).fill(0n);
|
|
208
|
-
const totalVoters = BigInt(votes.size);
|
|
209
|
-
for (const encrypted of votes.values()) {
|
|
210
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
211
|
-
tallies[i] += this.votingPrivateKey.decrypt(encrypted[i]);
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
const threshold = (totalVoters * 95n) / 100n;
|
|
215
|
-
const winners = tallies
|
|
216
|
-
.map((v, i) => (v >= threshold ? i : -1))
|
|
217
|
-
.filter((i) => i >= 0);
|
|
218
|
-
return {
|
|
219
|
-
method: types_1.VotingMethod.Consensus,
|
|
220
|
-
choices: [...poll.choices],
|
|
221
|
-
winner: winners.length === 1 ? winners[0] : undefined,
|
|
222
|
-
winners: winners.length > 0 ? winners : undefined,
|
|
223
|
-
tallies,
|
|
224
|
-
voterCount: poll.voterCount,
|
|
225
|
-
};
|
|
226
|
-
}
|
|
227
|
-
_tallyConsentBased(poll, votes, choiceCount) {
|
|
228
|
-
const tallies = new Array(choiceCount).fill(0n);
|
|
229
|
-
const objections = new Array(choiceCount).fill(0n);
|
|
230
|
-
for (const encrypted of votes.values()) {
|
|
231
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
232
|
-
const vote = this.votingPrivateKey.decrypt(encrypted[i]);
|
|
233
|
-
if (vote > 0n)
|
|
234
|
-
tallies[i]++;
|
|
235
|
-
else if (vote < 0n)
|
|
236
|
-
objections[i]++;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
const winners = objections
|
|
240
|
-
.map((obj, i) => (obj === 0n ? i : -1))
|
|
241
|
-
.filter((i) => i >= 0);
|
|
242
|
-
return {
|
|
243
|
-
method: types_1.VotingMethod.ConsentBased,
|
|
244
|
-
choices: [...poll.choices],
|
|
245
|
-
winner: winners.length === 1 ? winners[0] : undefined,
|
|
246
|
-
winners: winners.length > 0 ? winners : undefined,
|
|
247
|
-
tallies,
|
|
248
|
-
voterCount: poll.voterCount,
|
|
249
|
-
};
|
|
250
|
-
}
|
|
251
|
-
_tallyTwoRound(poll, votes, choiceCount) {
|
|
252
|
-
const rounds = [];
|
|
253
|
-
const tallies = new Array(choiceCount).fill(0n);
|
|
254
|
-
for (const encrypted of votes.values()) {
|
|
255
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
256
|
-
tallies[i] += this.votingPrivateKey.decrypt(encrypted[i]);
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
const totalVotes = tallies.reduce((sum, v) => sum + v, 0n);
|
|
260
|
-
const majority = totalVotes / 2n;
|
|
261
|
-
rounds.push({ round: 1, tallies: [...tallies] });
|
|
262
|
-
const maxVotes = tallies.reduce((max, v) => (v > max ? v : max), 0n);
|
|
263
|
-
if (maxVotes > majority) {
|
|
264
|
-
const winner = tallies.findIndex((v) => v === maxVotes);
|
|
265
|
-
rounds[0].winner = winner;
|
|
266
|
-
return {
|
|
267
|
-
method: types_1.VotingMethod.TwoRound,
|
|
268
|
-
choices: [...poll.choices],
|
|
269
|
-
winner,
|
|
270
|
-
rounds,
|
|
271
|
-
tallies,
|
|
272
|
-
voterCount: poll.voterCount,
|
|
273
|
-
};
|
|
274
|
-
}
|
|
275
|
-
const sorted = tallies
|
|
276
|
-
.map((v, i) => ({ votes: v, index: i }))
|
|
277
|
-
.sort((a, b) => (b.votes > a.votes ? 1 : -1));
|
|
278
|
-
const top2 = [sorted[0].index, sorted[1].index];
|
|
279
|
-
const runoffTallies = new Array(choiceCount).fill(0n);
|
|
280
|
-
runoffTallies[top2[0]] = sorted[0].votes;
|
|
281
|
-
runoffTallies[top2[1]] = sorted[1].votes;
|
|
282
|
-
const winner = sorted[0].index;
|
|
283
|
-
rounds.push({ round: 2, tallies: runoffTallies, winner });
|
|
284
|
-
return {
|
|
285
|
-
method: types_1.VotingMethod.TwoRound,
|
|
286
|
-
choices: [...poll.choices],
|
|
287
|
-
winner,
|
|
288
|
-
rounds,
|
|
289
|
-
tallies: runoffTallies,
|
|
290
|
-
voterCount: poll.voterCount,
|
|
291
|
-
};
|
|
292
|
-
}
|
|
293
|
-
_tallySTAR(poll, votes, choiceCount) {
|
|
294
|
-
const rounds = [];
|
|
295
|
-
const scores = new Array(choiceCount).fill(0n);
|
|
296
|
-
for (const encrypted of votes.values()) {
|
|
297
|
-
for (let i = 0; i < choiceCount; i++) {
|
|
298
|
-
scores[i] += this.votingPrivateKey.decrypt(encrypted[i]);
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
rounds.push({ round: 1, tallies: [...scores] });
|
|
302
|
-
const sorted = scores
|
|
303
|
-
.map((s, i) => ({ score: s, index: i }))
|
|
304
|
-
.sort((a, b) => (b.score > a.score ? 1 : -1));
|
|
305
|
-
const top2 = [sorted[0].index, sorted[1].index];
|
|
306
|
-
const runoffTallies = new Array(choiceCount).fill(0n);
|
|
307
|
-
for (const encrypted of votes.values()) {
|
|
308
|
-
const score0 = this.votingPrivateKey.decrypt(encrypted[top2[0]]);
|
|
309
|
-
const score1 = this.votingPrivateKey.decrypt(encrypted[top2[1]]);
|
|
310
|
-
if (score0 > score1)
|
|
311
|
-
runoffTallies[top2[0]]++;
|
|
312
|
-
else if (score1 > score0)
|
|
313
|
-
runoffTallies[top2[1]]++;
|
|
314
|
-
}
|
|
315
|
-
const winner = runoffTallies[top2[0]] >= runoffTallies[top2[1]] ? top2[0] : top2[1];
|
|
316
|
-
rounds.push({ round: 2, tallies: runoffTallies, winner });
|
|
317
|
-
return {
|
|
318
|
-
method: types_1.VotingMethod.STAR,
|
|
319
|
-
choices: [...poll.choices],
|
|
320
|
-
winner,
|
|
321
|
-
rounds,
|
|
322
|
-
tallies: runoffTallies,
|
|
323
|
-
voterCount: poll.voterCount,
|
|
324
|
-
};
|
|
325
|
-
}
|
|
326
|
-
_tallySTV(poll, votes, choiceCount) {
|
|
327
|
-
const rounds = [];
|
|
328
|
-
const eliminated = new Set();
|
|
329
|
-
const winners = [];
|
|
330
|
-
const rankings = this._decryptRankings(votes, choiceCount);
|
|
331
|
-
const seatsToFill = Math.min(3, choiceCount);
|
|
332
|
-
const quota = BigInt(votes.size) / BigInt(seatsToFill + 1) + 1n;
|
|
333
|
-
let round = 0;
|
|
334
|
-
while (winners.length < seatsToFill && eliminated.size < choiceCount) {
|
|
335
|
-
round++;
|
|
336
|
-
const tallies = this._countFirstChoices(rankings, eliminated, choiceCount);
|
|
337
|
-
rounds.push({ round, tallies: [...tallies] });
|
|
338
|
-
const meetingQuota = tallies
|
|
339
|
-
.map((v, i) => !eliminated.has(i) && !winners.includes(i) && v >= quota ? i : -1)
|
|
340
|
-
.filter((i) => i >= 0);
|
|
341
|
-
if (meetingQuota.length > 0) {
|
|
342
|
-
winners.push(...meetingQuota);
|
|
343
|
-
meetingQuota.forEach((i) => eliminated.add(i));
|
|
344
|
-
rounds[rounds.length - 1].winner = meetingQuota[0];
|
|
345
|
-
continue;
|
|
346
|
-
}
|
|
347
|
-
const remaining = tallies
|
|
348
|
-
.map((v, i) => !eliminated.has(i) && !winners.includes(i)
|
|
349
|
-
? { votes: v, index: i }
|
|
350
|
-
: null)
|
|
351
|
-
.filter((x) => x !== null);
|
|
352
|
-
if (remaining.length === 0)
|
|
353
|
-
break;
|
|
354
|
-
const minVotes = remaining.reduce((min, x) => (x.votes < min ? x.votes : min), remaining[0].votes);
|
|
355
|
-
const toEliminate = remaining.find((x) => x.votes === minVotes).index;
|
|
356
|
-
eliminated.add(toEliminate);
|
|
357
|
-
rounds[rounds.length - 1].eliminated = toEliminate;
|
|
358
|
-
}
|
|
359
|
-
const finalTallies = new Array(choiceCount).fill(0n);
|
|
360
|
-
winners.forEach((w) => (finalTallies[w] = 1n));
|
|
361
|
-
return {
|
|
362
|
-
method: types_1.VotingMethod.STV,
|
|
363
|
-
choices: [...poll.choices],
|
|
364
|
-
winners,
|
|
365
|
-
eliminated: Array.from(eliminated),
|
|
366
|
-
rounds,
|
|
367
|
-
tallies: finalTallies,
|
|
368
|
-
voterCount: poll.voterCount,
|
|
369
|
-
};
|
|
4
|
+
/**
|
|
5
|
+
* Poll Tallier - Node.js optimized
|
|
6
|
+
* Extends ecies-lib PollTallier with Buffer support
|
|
7
|
+
*/
|
|
8
|
+
const ecies_lib_1 = require("@digitaldefiance/ecies-lib");
|
|
9
|
+
/**
|
|
10
|
+
* Node.js PollTallier that extends ecies-lib PollTallier
|
|
11
|
+
* Specializes the generic TID parameter to Buffer for Node.js compatibility
|
|
12
|
+
*
|
|
13
|
+
* All tallying logic is inherited from ecies-lib PollTallier.
|
|
14
|
+
* This class only provides type specialization for Buffer-based operations.
|
|
15
|
+
*/
|
|
16
|
+
class PollTallier extends ecies_lib_1.PollTallier {
|
|
17
|
+
constructor(authority, votingPrivateKey, votingPublicKey) {
|
|
18
|
+
// Cast authority to work around type incompatibility between
|
|
19
|
+
// node-ecies-lib IMember (Buffer-based) and ecies-lib IMember (Uint8Array-based)
|
|
20
|
+
super(authority, votingPrivateKey, votingPublicKey);
|
|
370
21
|
}
|
|
371
22
|
}
|
|
372
23
|
exports.PollTallier = PollTallier;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tallier.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/tallier.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"tallier.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/tallier.ts"],"names":[],"mappings":";;;AAAA;;;GAGG;AACH,0DAGoC;AAMpC;;;;;;GAMG;AACH,MAAa,WAEX,SAAQ,uBAAoB;IAC5B,YACE,SAAuB,EACvB,gBAA4B,EAC5B,eAA0B;QAE1B,6DAA6D;QAC7D,iFAAiF;QACjF,KAAK,CACH,SAAoD,EACpD,gBAAgB,EAChB,eAAe,CAChB,CAAC;IACJ,CAAC;CAKF;AApBD,kCAoBC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Member } from '../../member';
|
|
2
|
+
import { ECIESService } from '../../services/ecies/service';
|
|
3
|
+
export declare class TestVoterPool {
|
|
4
|
+
private static voters;
|
|
5
|
+
private static authority;
|
|
6
|
+
private static eciesService;
|
|
7
|
+
private static initialized;
|
|
8
|
+
static initialize(poolSize?: number): Promise<void>;
|
|
9
|
+
static getAuthority(): Member;
|
|
10
|
+
static getEciesService(): ECIESService;
|
|
11
|
+
static getVoter(index: number): Member;
|
|
12
|
+
static getVoters(count: number, startIndex?: number): Member[];
|
|
13
|
+
static getPoolSize(): number;
|
|
14
|
+
static reset(): void;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=test-voter-pool.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-voter-pool.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/test-voter-pool.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAE5D,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAgB;IACrC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAyC;IACjE,OAAO,CAAC,MAAM,CAAC,YAAY,CAA+C;IAC1E,OAAO,CAAC,MAAM,CAAC,WAAW,CAAS;WAEtB,UAAU,CAAC,QAAQ,SAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAkCvD,MAAM,CAAC,YAAY,IAAI,MAAM;IAK7B,MAAM,CAAC,eAAe,IAAI,YAAY;IAKtC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAUtC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,SAAI,GAAG,MAAM,EAAE;IAUzD,MAAM,CAAC,WAAW,IAAI,MAAM;IAI5B,MAAM,CAAC,KAAK,IAAI,IAAI;CAMrB"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TestVoterPool = void 0;
|
|
4
|
+
const ecies_lib_1 = require("@digitaldefiance/ecies-lib");
|
|
5
|
+
const member_1 = require("../../member");
|
|
6
|
+
const service_1 = require("../../services/ecies/service");
|
|
7
|
+
class TestVoterPool {
|
|
8
|
+
static voters = [];
|
|
9
|
+
static authority = undefined;
|
|
10
|
+
static eciesService = undefined;
|
|
11
|
+
static initialized = false;
|
|
12
|
+
static async initialize(poolSize = 1000) {
|
|
13
|
+
if (this.initialized)
|
|
14
|
+
return;
|
|
15
|
+
// Create ECIESService with proper configuration
|
|
16
|
+
this.eciesService = new service_1.ECIESService({
|
|
17
|
+
symmetricAlgorithm: 'aes-256-gcm',
|
|
18
|
+
symmetricKeyBits: 256,
|
|
19
|
+
symmetricKeyMode: 'gcm',
|
|
20
|
+
});
|
|
21
|
+
const result = member_1.Member.newMember(this.eciesService, ecies_lib_1.MemberType.System, 'Authority', new ecies_lib_1.EmailString('auth@test.com'));
|
|
22
|
+
this.authority = result.member;
|
|
23
|
+
await this.authority.deriveVotingKeys();
|
|
24
|
+
// Create voters in parallel
|
|
25
|
+
const voterPromises = Array.from({ length: poolSize }, (_, i) => {
|
|
26
|
+
const voter = member_1.Member.newMember(this.eciesService, ecies_lib_1.MemberType.User, `Voter${i}`, new ecies_lib_1.EmailString(`voter${i}@test.com`)).member;
|
|
27
|
+
return voter.deriveVotingKeys().then(() => voter);
|
|
28
|
+
});
|
|
29
|
+
this.voters = await Promise.all(voterPromises);
|
|
30
|
+
this.initialized = true;
|
|
31
|
+
}
|
|
32
|
+
static getAuthority() {
|
|
33
|
+
if (!this.authority)
|
|
34
|
+
throw new Error('Pool not initialized');
|
|
35
|
+
return this.authority;
|
|
36
|
+
}
|
|
37
|
+
static getEciesService() {
|
|
38
|
+
if (!this.eciesService)
|
|
39
|
+
throw new Error('Pool not initialized');
|
|
40
|
+
return this.eciesService;
|
|
41
|
+
}
|
|
42
|
+
static getVoter(index) {
|
|
43
|
+
if (!this.initialized)
|
|
44
|
+
throw new Error('Pool not initialized');
|
|
45
|
+
if (index < 0 || index >= this.voters.length) {
|
|
46
|
+
throw new Error(`Voter index ${index} out of range [0, ${this.voters.length})`);
|
|
47
|
+
}
|
|
48
|
+
return this.voters[index];
|
|
49
|
+
}
|
|
50
|
+
static getVoters(count, startIndex = 0) {
|
|
51
|
+
if (!this.initialized)
|
|
52
|
+
throw new Error('Pool not initialized');
|
|
53
|
+
if (startIndex + count > this.voters.length) {
|
|
54
|
+
throw new Error(`Not enough voters: requested ${count} from ${startIndex}, pool size ${this.voters.length}`);
|
|
55
|
+
}
|
|
56
|
+
return this.voters.slice(startIndex, startIndex + count);
|
|
57
|
+
}
|
|
58
|
+
static getPoolSize() {
|
|
59
|
+
return this.voters.length;
|
|
60
|
+
}
|
|
61
|
+
static reset() {
|
|
62
|
+
this.voters = [];
|
|
63
|
+
this.authority = undefined;
|
|
64
|
+
this.eciesService = undefined;
|
|
65
|
+
this.initialized = false;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.TestVoterPool = TestVoterPool;
|
|
69
|
+
//# sourceMappingURL=test-voter-pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-voter-pool.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/test-voter-pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"us-election-example.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/us-election-example.ts"],"names":[],"mappings":""}
|