@digitaldefiance/node-ecies-lib 4.6.4 → 4.7.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 (45) hide show
  1. package/package.json +2 -2
  2. package/src/constants.d.ts.map +1 -1
  3. package/src/constants.js.map +1 -1
  4. package/src/lib/index.d.ts +1 -0
  5. package/src/lib/index.d.ts.map +1 -1
  6. package/src/lib/index.js +1 -0
  7. package/src/lib/index.js.map +1 -1
  8. package/src/lib/voting/audit.d.ts +44 -0
  9. package/src/lib/voting/audit.d.ts.map +1 -0
  10. package/src/lib/voting/audit.js +129 -0
  11. package/src/lib/voting/audit.js.map +1 -0
  12. package/src/lib/voting/encoder.d.ts +22 -0
  13. package/src/lib/voting/encoder.d.ts.map +1 -0
  14. package/src/lib/voting/encoder.js +115 -0
  15. package/src/lib/voting/encoder.js.map +1 -0
  16. package/src/lib/voting/factory.d.ts +14 -0
  17. package/src/lib/voting/factory.d.ts.map +1 -0
  18. package/src/lib/voting/factory.js +36 -0
  19. package/src/lib/voting/factory.js.map +1 -0
  20. package/src/lib/voting/index.d.ts +11 -0
  21. package/src/lib/voting/index.d.ts.map +1 -0
  22. package/src/lib/voting/index.js +24 -0
  23. package/src/lib/voting/index.js.map +1 -0
  24. package/src/lib/voting/poll-core.d.ts +34 -0
  25. package/src/lib/voting/poll-core.d.ts.map +1 -0
  26. package/src/lib/voting/poll-core.js +183 -0
  27. package/src/lib/voting/poll-core.js.map +1 -0
  28. package/src/lib/voting/security.d.ts +21 -0
  29. package/src/lib/voting/security.d.ts.map +1 -0
  30. package/src/lib/voting/security.js +54 -0
  31. package/src/lib/voting/security.js.map +1 -0
  32. package/src/lib/voting/tallier.d.ts +27 -0
  33. package/src/lib/voting/tallier.d.ts.map +1 -0
  34. package/src/lib/voting/tallier.js +373 -0
  35. package/src/lib/voting/tallier.js.map +1 -0
  36. package/src/lib/voting/types.d.ts +66 -0
  37. package/src/lib/voting/types.d.ts.map +1 -0
  38. package/src/lib/voting/types.js +29 -0
  39. package/src/lib/voting/types.js.map +1 -0
  40. package/src/services/progress-tracker.d.ts.map +1 -1
  41. package/src/services/progress-tracker.js.map +1 -1
  42. package/src/services/voting.service.d.ts +0 -3
  43. package/src/services/voting.service.d.ts.map +1 -1
  44. package/src/services/voting.service.js +2 -3
  45. package/src/services/voting.service.js.map +1 -1
@@ -0,0 +1,373 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PollTallier = void 0;
4
+ const types_1 = require("./types");
5
+ class PollTallier {
6
+ __authority;
7
+ votingPrivateKey;
8
+ __votingPublicKey;
9
+ constructor(__authority, votingPrivateKey, __votingPublicKey) {
10
+ this.__authority = __authority;
11
+ this.votingPrivateKey = votingPrivateKey;
12
+ this.__votingPublicKey = __votingPublicKey;
13
+ if (!__authority.votingPrivateKey)
14
+ throw new Error('Authority must have private key');
15
+ }
16
+ tally(poll) {
17
+ if (!poll.isClosed)
18
+ throw new Error('Poll must be closed');
19
+ const votes = poll.getEncryptedVotes();
20
+ const choiceCount = poll.choices.length;
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
+ };
370
+ }
371
+ }
372
+ exports.PollTallier = PollTallier;
373
+ //# sourceMappingURL=tallier.js.map
@@ -0,0 +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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"}
@@ -0,0 +1,66 @@
1
+ /**
2
+ * Voting system types - Node.js optimized
3
+ * Uses Buffer instead of Uint8Array for better Node.js performance
4
+ */
5
+ export type { IMember } from '../../interfaces/member';
6
+ export declare enum VotingMethod {
7
+ Plurality = "plurality",
8
+ Approval = "approval",
9
+ Weighted = "weighted",
10
+ Borda = "borda",
11
+ Score = "score",
12
+ YesNo = "yes-no",
13
+ YesNoAbstain = "yes-no-abstain",
14
+ Supermajority = "supermajority",
15
+ RankedChoice = "ranked-choice",
16
+ TwoRound = "two-round",
17
+ STAR = "star",
18
+ STV = "stv",
19
+ Quadratic = "quadratic",
20
+ Consensus = "consensus",
21
+ ConsentBased = "consent-based"
22
+ }
23
+ export interface VoteReceipt {
24
+ voterId: Buffer;
25
+ pollId: Buffer;
26
+ timestamp: number;
27
+ signature: Buffer;
28
+ nonce: Buffer;
29
+ }
30
+ export interface PollResults {
31
+ method: VotingMethod;
32
+ choices: string[];
33
+ winner?: number;
34
+ winners?: number[];
35
+ eliminated?: number[];
36
+ rounds?: RoundResult[];
37
+ tallies: bigint[];
38
+ voterCount: number;
39
+ }
40
+ export interface RoundResult {
41
+ round: number;
42
+ tallies: bigint[];
43
+ eliminated?: number;
44
+ winner?: number;
45
+ }
46
+ export interface EncryptedVote {
47
+ choiceIndex?: number;
48
+ choices?: number[];
49
+ rankings?: number[];
50
+ weight?: bigint;
51
+ score?: number;
52
+ encrypted: bigint[];
53
+ plaintext?: PlaintextVote;
54
+ }
55
+ export interface PlaintextVote {
56
+ voterId: Buffer;
57
+ choiceIndex?: number;
58
+ choices?: number[];
59
+ weight?: bigint;
60
+ objection?: string;
61
+ }
62
+ export interface SupermajorityConfig {
63
+ numerator: number;
64
+ denominator: number;
65
+ }
66
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,YAAY,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAEvD,oBAAY,YAAY;IAEtB,SAAS,cAAc;IACvB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,KAAK,UAAU;IACf,KAAK,UAAU;IACf,KAAK,WAAW;IAChB,YAAY,mBAAmB;IAC/B,aAAa,kBAAkB;IAE/B,YAAY,kBAAkB;IAC9B,QAAQ,cAAc;IACtB,IAAI,SAAS;IACb,GAAG,QAAQ;IAEX,SAAS,cAAc;IACvB,SAAS,cAAc;IACvB,YAAY,kBAAkB;CAC/B;AAED,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,YAAY,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC;IACvB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,CAAC,EAAE,aAAa,CAAC;CAC3B;AAED,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ /**
3
+ * Voting system types - Node.js optimized
4
+ * Uses Buffer instead of Uint8Array for better Node.js performance
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.VotingMethod = void 0;
8
+ var VotingMethod;
9
+ (function (VotingMethod) {
10
+ // Fully homomorphic (single-round, privacy-preserving)
11
+ VotingMethod["Plurality"] = "plurality";
12
+ VotingMethod["Approval"] = "approval";
13
+ VotingMethod["Weighted"] = "weighted";
14
+ VotingMethod["Borda"] = "borda";
15
+ VotingMethod["Score"] = "score";
16
+ VotingMethod["YesNo"] = "yes-no";
17
+ VotingMethod["YesNoAbstain"] = "yes-no-abstain";
18
+ VotingMethod["Supermajority"] = "supermajority";
19
+ // Multi-round (requires decryption between rounds)
20
+ VotingMethod["RankedChoice"] = "ranked-choice";
21
+ VotingMethod["TwoRound"] = "two-round";
22
+ VotingMethod["STAR"] = "star";
23
+ VotingMethod["STV"] = "stv";
24
+ // Insecure (requires non-additive operations)
25
+ VotingMethod["Quadratic"] = "quadratic";
26
+ VotingMethod["Consensus"] = "consensus";
27
+ VotingMethod["ConsentBased"] = "consent-based";
28
+ })(VotingMethod || (exports.VotingMethod = VotingMethod = {}));
29
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-node-ecies-lib/src/lib/voting/types.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAIH,IAAY,YAmBX;AAnBD,WAAY,YAAY;IACtB,uDAAuD;IACvD,uCAAuB,CAAA;IACvB,qCAAqB,CAAA;IACrB,qCAAqB,CAAA;IACrB,+BAAe,CAAA;IACf,+BAAe,CAAA;IACf,gCAAgB,CAAA;IAChB,+CAA+B,CAAA;IAC/B,+CAA+B,CAAA;IAC/B,mDAAmD;IACnD,8CAA8B,CAAA;IAC9B,sCAAsB,CAAA;IACtB,6BAAa,CAAA;IACb,2BAAW,CAAA;IACX,8CAA8C;IAC9C,uCAAuB,CAAA;IACvB,uCAAuB,CAAA;IACvB,8CAA8B,CAAA;AAChC,CAAC,EAnBW,YAAY,4BAAZ,YAAY,QAmBvB"}
@@ -1 +1 @@
1
- {"version":3,"file":"progress-tracker.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-ecies-lib/src/services/progress-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAEhE,qBAAa,eAAe;IAQd,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;IAPxC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,eAAe,CAAa;IACpC,OAAO,CAAC,iBAAiB,CAAgB;IACzC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAK;gBAEb,UAAU,CAAC,EAAE,MAAM,YAAA;IAKzC,MAAM,CAAC,UAAU,EAAE,MAAM,GAAG,eAAe;IA+D3C,WAAW,IAAI,eAAe;CA+BtC"}
1
+ {"version":3,"file":"progress-tracker.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-ecies-lib/src/services/progress-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAEhE,qBAAa,eAAe;IAQd,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;IAPxC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,eAAe,CAAa;IACpC,OAAO,CAAC,iBAAiB,CAAgB;IACzC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAK;gBAEb,UAAU,CAAC,EAAE,MAAM,YAAA;IAKzC,MAAM,CAAC,UAAU,EAAE,MAAM,GAAG,eAAe;IAkE3C,WAAW,IAAI,eAAe;CAkCtC"}
@@ -1 +1 @@
1
- {"version":3,"file":"progress-tracker.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-ecies-lib/src/services/progress-tracker.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"progress-tracker.js","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-ecies-lib/src/services/progress-tracker.ts"],"names":[],"mappings":"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"}
@@ -31,9 +31,6 @@
31
31
  */
32
32
  import { IVotingService, IsolatedPrivateKey as SharedIsolatedPrivateKey, IsolatedPublicKey as SharedIsolatedPublicKey } from '@digitaldefiance/ecies-lib';
33
33
  import type { KeyPair, PrivateKey, PublicKey } from 'paillier-bigint';
34
- import { type IVotingConsts, VOTING } from '../interfaces/voting-consts';
35
- export type { IVotingConsts };
36
- export { VOTING };
37
34
  export interface DeriveVotingKeysOptions {
38
35
  /** Curve name (default: 'secp256k1') */
39
36
  curveName?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"voting.service.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-ecies-lib/src/services/voting.service.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"voting.service.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-node-ecies-lib/src/services/voting.service.ts"],"names":[],"mappings":"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"}
@@ -31,7 +31,7 @@
31
31
  * docs/SECURITY_ANALYSIS_ECIES_PAILLIER_BRIDGE.md
32
32
  */
33
33
  Object.defineProperty(exports, "__esModule", { value: true });
34
- exports.VotingService = exports.SecureDeterministicDRBG = exports.VOTING = void 0;
34
+ exports.VotingService = exports.SecureDeterministicDRBG = void 0;
35
35
  exports.millerRabinTest = millerRabinTest;
36
36
  exports.modPow = modPow;
37
37
  exports.modInverse = modInverse;
@@ -45,10 +45,9 @@ const crypto_1 = require("crypto");
45
45
  const secp256k1_js_1 = require("@noble/curves/secp256k1.js");
46
46
  const voting_error_type_1 = require("../enumerations/voting-error-type");
47
47
  const voting_1 = require("../errors/voting");
48
+ const voting_consts_1 = require("../interfaces/voting-consts");
48
49
  const isolated_private_1 = require("../isolated-private");
49
50
  const isolated_public_1 = require("../isolated-public");
50
- const voting_consts_1 = require("../interfaces/voting-consts");
51
- Object.defineProperty(exports, "VOTING", { enumerable: true, get: function () { return voting_consts_1.VOTING; } });
52
51
  /**
53
52
  * Miller-Rabin primality test with deterministic witnesses
54
53
  *