@digitaldefiance/ecies-lib 4.8.7 → 4.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +8 -8
- package/src/builders/member-builder.d.ts +1 -2
- package/src/builders/member-builder.d.ts.map +1 -1
- package/src/builders/member-builder.js.map +1 -1
- package/src/constants.d.ts +1 -1
- package/src/constants.d.ts.map +1 -1
- package/src/constants.js +2 -0
- package/src/constants.js.map +1 -1
- package/src/interfaces/constants.d.ts +1 -1
- package/src/interfaces/constants.d.ts.map +1 -1
- package/src/interfaces/ecies-consts.d.ts +1 -0
- package/src/interfaces/ecies-consts.d.ts.map +1 -1
- package/src/interfaces/index.d.ts +2 -4
- package/src/interfaces/index.d.ts.map +1 -1
- package/src/interfaces/index.js +2 -5
- package/src/interfaces/index.js.map +1 -1
- package/src/interfaces/isolated-private-key-async.d.ts +13 -0
- package/src/interfaces/isolated-private-key-async.d.ts.map +1 -0
- package/src/interfaces/isolated-private-key-async.js +3 -0
- package/src/interfaces/isolated-private-key-async.js.map +1 -0
- package/src/interfaces/isolated-public-key-async.d.ts +17 -0
- package/src/interfaces/isolated-public-key-async.d.ts.map +1 -0
- package/src/interfaces/isolated-public-key-async.js +3 -0
- package/src/interfaces/isolated-public-key-async.js.map +1 -0
- package/src/interfaces/platform-buffer.d.ts +5 -5
- package/src/interfaces/platform-buffer.d.ts.map +1 -1
- package/src/interfaces/voting-service.d.ts +0 -111
- package/src/interfaces/voting-service.d.ts.map +1 -1
- package/src/interfaces/voting-service.js +0 -7
- package/src/interfaces/voting-service.js.map +1 -1
- package/src/lib/id-providers/index.d.ts +1 -0
- package/src/lib/id-providers/index.d.ts.map +1 -1
- package/src/lib/id-providers/index.js +3 -1
- package/src/lib/id-providers/index.js.map +1 -1
- package/src/lib/id-providers/uint8array-provider.d.ts +54 -0
- package/src/lib/id-providers/uint8array-provider.d.ts.map +1 -0
- package/src/lib/id-providers/uint8array-provider.js +97 -0
- package/src/lib/id-providers/uint8array-provider.js.map +1 -0
- package/src/lib/voting/audit.d.ts +4 -38
- package/src/lib/voting/audit.d.ts.map +1 -1
- package/src/lib/voting/audit.js +8 -10
- package/src/lib/voting/audit.js.map +1 -1
- package/src/lib/voting/bulletin-board.d.ts +4 -56
- package/src/lib/voting/bulletin-board.d.ts.map +1 -1
- package/src/lib/voting/bulletin-board.js.map +1 -1
- package/src/lib/voting/encoder.d.ts +2 -1
- package/src/lib/voting/encoder.d.ts.map +1 -1
- package/src/lib/voting/encoder.js +9 -9
- package/src/lib/voting/encoder.js.map +1 -1
- package/src/lib/voting/enumerations/audit-event-type.d.ts +6 -0
- package/src/lib/voting/enumerations/audit-event-type.d.ts.map +1 -0
- package/src/lib/voting/enumerations/audit-event-type.js +10 -0
- package/src/lib/voting/enumerations/audit-event-type.js.map +1 -0
- package/src/lib/voting/enumerations/event-type.d.ts +9 -0
- package/src/lib/voting/enumerations/event-type.d.ts.map +1 -0
- package/src/lib/voting/enumerations/event-type.js +13 -0
- package/src/lib/voting/enumerations/event-type.js.map +1 -0
- 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 +9 -0
- package/src/lib/voting/enumerations/index.js.map +1 -0
- package/src/lib/voting/enumerations/jurisdictional-level.d.ts +7 -0
- package/src/lib/voting/enumerations/jurisdictional-level.d.ts.map +1 -0
- package/src/lib/voting/enumerations/jurisdictional-level.js +11 -0
- package/src/lib/voting/enumerations/jurisdictional-level.js.map +1 -0
- package/src/lib/voting/enumerations/security-level.d.ts +6 -0
- package/src/lib/voting/enumerations/security-level.d.ts.map +1 -0
- package/src/lib/voting/enumerations/security-level.js +10 -0
- package/src/lib/voting/enumerations/security-level.js.map +1 -0
- package/src/lib/voting/enumerations/voting-method.d.ts +41 -0
- package/src/lib/voting/enumerations/voting-method.d.ts.map +1 -0
- package/src/lib/voting/{types.js → enumerations/voting-method.js} +1 -1
- package/src/lib/voting/enumerations/voting-method.js.map +1 -0
- package/src/lib/voting/event-logger.d.ts +14 -65
- package/src/lib/voting/event-logger.d.ts.map +1 -1
- package/src/lib/voting/event-logger.js +32 -19
- package/src/lib/voting/event-logger.js.map +1 -1
- package/src/lib/voting/factory.d.ts +2 -2
- package/src/lib/voting/factory.d.ts.map +1 -1
- package/src/lib/voting/factory.js +6 -6
- package/src/lib/voting/factory.js.map +1 -1
- package/src/lib/voting/hierarchical-aggregator.d.ts +72 -0
- package/src/lib/voting/hierarchical-aggregator.d.ts.map +1 -0
- package/src/lib/voting/hierarchical-aggregator.js +234 -0
- package/src/lib/voting/hierarchical-aggregator.js.map +1 -0
- package/src/lib/voting/index.d.ts +8 -5
- package/src/lib/voting/index.d.ts.map +1 -1
- package/src/lib/voting/index.js +12 -7
- package/src/lib/voting/index.js.map +1 -1
- package/src/lib/voting/interfaces/aggregated-tally.d.ts +11 -0
- package/src/lib/voting/interfaces/aggregated-tally.d.ts.map +1 -0
- package/src/{interfaces/member-with-mnemonic.js → lib/voting/interfaces/aggregated-tally.js} +1 -1
- package/src/lib/voting/interfaces/aggregated-tally.js.map +1 -0
- package/src/lib/voting/interfaces/audit-entry.d.ts +25 -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 +13 -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 +20 -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 +24 -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 +14 -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 +8 -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 +9 -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 +55 -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 +23 -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 +24 -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 +25 -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 +31 -0
- package/src/lib/voting/interfaces/index.d.ts.map +1 -0
- package/src/lib/voting/interfaces/index.js +5 -0
- package/src/lib/voting/interfaces/index.js.map +1 -0
- package/src/lib/voting/interfaces/jurisdiction-config.d.ts +9 -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 +18 -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 +10 -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 +25 -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 +18 -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 +41 -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 +15 -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 +9 -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 +11 -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 +18 -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 +59 -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 +15 -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 +11 -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.map +1 -0
- package/src/lib/voting/interfaces/voting-consts.js.map +1 -0
- package/src/lib/voting/interfaces/voting-key-derivation-options.d.ts +26 -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 +20 -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 +18 -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 +37 -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/persistent-state.d.ts +21 -0
- package/src/lib/voting/persistent-state.d.ts.map +1 -0
- package/src/lib/voting/persistent-state.js +32 -0
- package/src/lib/voting/persistent-state.js.map +1 -0
- package/src/lib/voting/poll-core.d.ts +3 -3
- package/src/lib/voting/poll-core.d.ts.map +1 -1
- package/src/lib/voting/poll-core.js +6 -7
- package/src/lib/voting/poll-core.js.map +1 -1
- package/src/lib/voting/security.d.ts +2 -6
- package/src/lib/voting/security.d.ts.map +1 -1
- package/src/lib/voting/security.js +25 -28
- package/src/lib/voting/security.js.map +1 -1
- package/src/lib/voting/tallier.d.ts +5 -5
- package/src/lib/voting/tallier.d.ts.map +1 -1
- package/src/lib/voting/tallier.js +26 -26
- 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 +65 -0
- package/src/lib/voting/test-voter-pool.js.map +1 -0
- package/src/member.d.ts +8 -1
- package/src/member.d.ts.map +1 -1
- package/src/member.js +6 -6
- package/src/member.js.map +1 -1
- package/src/services/ecies/interfaces/decryption-result.d.ts +5 -0
- package/src/services/ecies/interfaces/decryption-result.d.ts.map +1 -0
- package/src/services/ecies/interfaces/decryption-result.js +3 -0
- package/src/services/ecies/interfaces/decryption-result.js.map +1 -0
- package/src/services/ecies/interfaces/encryption-result.d.ts +7 -0
- package/src/services/ecies/interfaces/encryption-result.d.ts.map +1 -0
- package/src/services/ecies/interfaces/encryption-result.js +3 -0
- package/src/services/ecies/interfaces/encryption-result.js.map +1 -0
- package/src/services/ecies/interfaces/index.d.ts +9 -0
- package/src/services/ecies/interfaces/index.d.ts.map +1 -0
- package/src/services/ecies/interfaces/index.js +3 -0
- package/src/services/ecies/interfaces/index.js.map +1 -0
- package/src/services/ecies/interfaces/multi-encrypted-message.d.ts +11 -0
- package/src/services/ecies/interfaces/multi-encrypted-message.d.ts.map +1 -0
- package/src/services/ecies/interfaces/multi-encrypted-message.js +3 -0
- package/src/services/ecies/interfaces/multi-encrypted-message.js.map +1 -0
- package/src/services/ecies/interfaces/multi-encrypted-parsed-header.d.ts +10 -0
- package/src/services/ecies/interfaces/multi-encrypted-parsed-header.d.ts.map +1 -0
- package/src/services/ecies/interfaces/multi-encrypted-parsed-header.js +3 -0
- package/src/services/ecies/interfaces/multi-encrypted-parsed-header.js.map +1 -0
- package/src/services/ecies/interfaces/multi-recipient.d.ts +6 -0
- package/src/services/ecies/interfaces/multi-recipient.d.ts.map +1 -0
- package/src/services/ecies/interfaces/multi-recipient.js +3 -0
- package/src/services/ecies/interfaces/multi-recipient.js.map +1 -0
- package/src/services/ecies/interfaces/simple-keypair.d.ts +5 -0
- package/src/services/ecies/interfaces/simple-keypair.d.ts.map +1 -0
- package/src/services/ecies/interfaces/simple-keypair.js +3 -0
- package/src/services/ecies/interfaces/simple-keypair.js.map +1 -0
- package/src/services/ecies/interfaces/single-encrypted-parsed-header.d.ts +11 -0
- package/src/services/ecies/interfaces/single-encrypted-parsed-header.d.ts.map +1 -0
- package/src/services/ecies/interfaces/single-encrypted-parsed-header.js +3 -0
- package/src/services/ecies/interfaces/single-encrypted-parsed-header.js.map +1 -0
- package/src/services/ecies/interfaces/wallet-seed.d.ts +6 -0
- package/src/services/ecies/interfaces/wallet-seed.d.ts.map +1 -0
- package/src/services/ecies/interfaces/wallet-seed.js +3 -0
- package/src/services/ecies/interfaces/wallet-seed.js.map +1 -0
- package/src/services/ecies/multi-recipient.d.ts.map +1 -1
- package/src/services/ecies/multi-recipient.js +14 -5
- package/src/services/ecies/multi-recipient.js.map +1 -1
- package/src/interfaces/member-with-mnemonic.d.ts +0 -8
- package/src/interfaces/member-with-mnemonic.d.ts.map +0 -1
- package/src/interfaces/member-with-mnemonic.js.map +0 -1
- package/src/interfaces/voting-consts.d.ts.map +0 -1
- package/src/interfaces/voting-consts.js.map +0 -1
- package/src/interfaces/voting-poll.d.ts +0 -455
- package/src/interfaces/voting-poll.d.ts.map +0 -1
- package/src/interfaces/voting-poll.js +0 -54
- package/src/interfaces/voting-poll.js.map +0 -1
- package/src/lib/voting/poll.d.ts +0 -125
- package/src/lib/voting/poll.d.ts.map +0 -1
- package/src/lib/voting/poll.js +0 -323
- package/src/lib/voting/poll.js.map +0 -1
- package/src/lib/voting/types.d.ts +0 -146
- package/src/lib/voting/types.d.ts.map +0 -1
- package/src/lib/voting/types.js.map +0 -1
- package/src/services/ecies/interfaces.d.ts +0 -55
- package/src/services/ecies/interfaces.d.ts.map +0 -1
- package/src/services/ecies/interfaces.js +0 -6
- package/src/services/ecies/interfaces.js.map +0 -1
- /package/src/{interfaces → lib/voting/interfaces}/voting-consts.d.ts +0 -0
- /package/src/{interfaces → lib/voting/interfaces}/voting-consts.js +0 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import type { PlatformID } from '../../../interfaces';
|
|
2
|
+
import { VotingMethod } from '../enumerations';
|
|
3
|
+
import { EncryptedVote } from './encrypted-vote';
|
|
4
|
+
/**
|
|
5
|
+
* Vote encoder interface for encrypting votes.
|
|
6
|
+
* Converts vote choices into encrypted Paillier ciphertexts.
|
|
7
|
+
*/
|
|
8
|
+
export interface IVoteEncoder<TID extends PlatformID = Uint8Array> {
|
|
9
|
+
/**
|
|
10
|
+
* Encode a plurality vote (single choice).
|
|
11
|
+
* @param choiceIndex - Index of chosen option
|
|
12
|
+
* @param choiceCount - Total number of choices
|
|
13
|
+
* @returns Encrypted vote
|
|
14
|
+
*/
|
|
15
|
+
encodePlurality(choiceIndex: number, choiceCount: number): EncryptedVote<TID>;
|
|
16
|
+
/**
|
|
17
|
+
* Encode an approval vote (multiple choices).
|
|
18
|
+
* @param choices - Indices of approved options
|
|
19
|
+
* @param choiceCount - Total number of choices
|
|
20
|
+
* @returns Encrypted vote
|
|
21
|
+
*/
|
|
22
|
+
encodeApproval(choices: number[], choiceCount: number): EncryptedVote<TID>;
|
|
23
|
+
/**
|
|
24
|
+
* Encode a weighted vote.
|
|
25
|
+
* @param choiceIndex - Index of chosen option
|
|
26
|
+
* @param weight - Vote weight (must be positive)
|
|
27
|
+
* @param choiceCount - Total number of choices
|
|
28
|
+
* @returns Encrypted vote
|
|
29
|
+
*/
|
|
30
|
+
encodeWeighted(choiceIndex: number, weight: bigint, choiceCount: number): EncryptedVote<TID>;
|
|
31
|
+
/**
|
|
32
|
+
* Encode a Borda count vote (ranked with points).
|
|
33
|
+
* @param rankings - Indices in preference order
|
|
34
|
+
* @param choiceCount - Total number of choices
|
|
35
|
+
* @returns Encrypted vote
|
|
36
|
+
*/
|
|
37
|
+
encodeBorda(rankings: number[], choiceCount: number): EncryptedVote<TID>;
|
|
38
|
+
/**
|
|
39
|
+
* Encode a ranked choice vote (for IRV).
|
|
40
|
+
* @param rankings - Indices in preference order
|
|
41
|
+
* @param choiceCount - Total number of choices
|
|
42
|
+
* @returns Encrypted vote
|
|
43
|
+
*/
|
|
44
|
+
encodeRankedChoice(rankings: number[], choiceCount: number): EncryptedVote<TID>;
|
|
45
|
+
/**
|
|
46
|
+
* Encode vote based on method.
|
|
47
|
+
* @param method - Voting method
|
|
48
|
+
* @param data - Vote data
|
|
49
|
+
* @param choiceCount - Total number of choices
|
|
50
|
+
* @returns Encrypted vote
|
|
51
|
+
*/
|
|
52
|
+
encode(method: VotingMethod, data: {
|
|
53
|
+
choiceIndex?: number;
|
|
54
|
+
choices?: number[];
|
|
55
|
+
rankings?: number[];
|
|
56
|
+
weight?: bigint;
|
|
57
|
+
}, choiceCount: number): EncryptedVote<TID>;
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=vote-encoder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vote-encoder.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/vote-encoder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD;;;GAGG;AACH,MAAM,WAAW,YAAY,CAAC,GAAG,SAAS,UAAU,GAAG,UAAU;IAC/D;;;;;OAKG;IACH,eAAe,CAAC,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IAC9E;;;;;OAKG;IACH,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IAC3E;;;;;;OAMG;IACH,cAAc,CACZ,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,GAClB,aAAa,CAAC,GAAG,CAAC,CAAC;IACtB;;;;;OAKG;IACH,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IACzE;;;;;OAKG;IACH,kBAAkB,CAChB,QAAQ,EAAE,MAAM,EAAE,EAClB,WAAW,EAAE,MAAM,GAClB,aAAa,CAAC,GAAG,CAAC,CAAC;IACtB;;;;;;OAMG;IACH,MAAM,CACJ,MAAM,EAAE,YAAY,EACpB,IAAI,EAAE;QACJ,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;QACpB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,EACD,WAAW,EAAE,MAAM,GAClB,aAAa,CAAC,GAAG,CAAC,CAAC;CACvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vote-encoder.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/vote-encoder.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { PlatformID } from '../../../interfaces';
|
|
2
|
+
import { IVoteLogger } from './vote-logger';
|
|
3
|
+
/**
|
|
4
|
+
* Vote logger interface - implemented in node-ecies-lib
|
|
5
|
+
*/
|
|
6
|
+
export interface IVoteLoggerExtended<TID extends PlatformID = Uint8Array> extends IVoteLogger<TID> {
|
|
7
|
+
appendVote(voterId: TID, encryptedVote: bigint[], timestamp: number): Promise<void>;
|
|
8
|
+
getVoteCount(): number;
|
|
9
|
+
replayVotes(): AsyncGenerator<{
|
|
10
|
+
voterId: TID;
|
|
11
|
+
encryptedVote: bigint[];
|
|
12
|
+
timestamp: number;
|
|
13
|
+
}>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=vote-logger-extended.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vote-logger-extended.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/vote-logger-extended.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C;;GAEG;AACH,MAAM,WAAW,mBAAmB,CAClC,GAAG,SAAS,UAAU,GAAG,UAAU,CACnC,SAAQ,WAAW,CAAC,GAAG,CAAC;IACxB,UAAU,CACR,OAAO,EAAE,GAAG,EACZ,aAAa,EAAE,MAAM,EAAE,EACvB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,IAAI,CAAC,CAAC;IACjB,YAAY,IAAI,MAAM,CAAC;IACvB,WAAW,IAAI,cAAc,CAAC;QAC5B,OAAO,EAAE,GAAG,CAAC;QACb,aAAa,EAAE,MAAM,EAAE,CAAC;QACxB,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC,CAAC;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vote-logger-extended.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/vote-logger-extended.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { PlatformID } from '../../../interfaces';
|
|
2
|
+
export interface IVoteLogger<TID extends PlatformID = Uint8Array> {
|
|
3
|
+
appendVote(voterId: TID, encryptedVote: bigint[], timestamp: number): Promise<void>;
|
|
4
|
+
getVoteCount(): number;
|
|
5
|
+
replayVotes(): AsyncGenerator<{
|
|
6
|
+
voterId: TID;
|
|
7
|
+
encryptedVote: bigint[];
|
|
8
|
+
timestamp: number;
|
|
9
|
+
}>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=vote-logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vote-logger.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/vote-logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,MAAM,WAAW,WAAW,CAAC,GAAG,SAAS,UAAU,GAAG,UAAU;IAC9D,UAAU,CACR,OAAO,EAAE,GAAG,EACZ,aAAa,EAAE,MAAM,EAAE,EACvB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,IAAI,CAAC,CAAC;IACjB,YAAY,IAAI,MAAM,CAAC;IACvB,WAAW,IAAI,cAAc,CAAC;QAC5B,OAAO,EAAE,GAAG,CAAC;QACb,aAAa,EAAE,MAAM,EAAE,CAAC;QACxB,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC,CAAC;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vote-logger.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/vote-logger.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-consts.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-consts.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,WAAW,aAAa;IAC5B;;;OAGG;IACH,QAAQ,CAAC,cAAc,EAAE,kBAAkB,CAAC;IAE5C;;;OAGG;IACH,QAAQ,CAAC,qBAAqB,EAAE,GAAG,CAAC;IAEpC;;;OAGG;IACH,QAAQ,CAAC,kBAAkB,EAAE,IAAI,CAAC;IAElC;;;OAGG;IACH,QAAQ,CAAC,cAAc,EAAE,GAAG,CAAC;IAE7B;;;OAGG;IACH,QAAQ,CAAC,WAAW,EAAE,EAAE,CAAC;IAEzB;;OAEG;IACH,QAAQ,CAAC,cAAc,EAAE,QAAQ,CAAC;IAElC;;OAEG;IACH,QAAQ,CAAC,cAAc,EAAE,QAAQ,CAAC;IAElC;;OAEG;IACH,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;IAEvB;;OAEG;IACH,QAAQ,CAAC,SAAS,EAAE,EAAE,CAAC;IAEvB;;OAEG;IACH,QAAQ,CAAC,UAAU,EAAE,KAAK,CAAC;IAE3B;;OAEG;IACH,QAAQ,CAAC,aAAa,EAAE,KAAK,CAAC;IAE9B;;;OAGG;IACH,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;IAExB;;;OAGG;IACH,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAE3B;;;OAGG;IACH,QAAQ,CAAC,mBAAmB,EAAE,KAAK,CAAC;IAEpC;;;OAGG;IACH,QAAQ,CAAC,aAAa,EAAE,EAAE,CAAC;IAE3B;;;OAGG;IACH,QAAQ,CAAC,kBAAkB,EAAE,EAAE,CAAC;CACjC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-consts.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-consts.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Options for deriving Paillier voting keys from ECDH keys.
|
|
3
|
+
*/
|
|
4
|
+
export interface IVotingKeyDerivationOptions {
|
|
5
|
+
/** Elliptic curve name (default: 'secp256k1') */
|
|
6
|
+
curveName?: string;
|
|
7
|
+
/** Public key magic byte (default: 0x04) */
|
|
8
|
+
publicKeyMagic?: number;
|
|
9
|
+
/** Raw public key length (default: 64) */
|
|
10
|
+
rawPublicKeyLength?: number;
|
|
11
|
+
/** Public key length with prefix (default: 65) */
|
|
12
|
+
publicKeyLength?: number;
|
|
13
|
+
/** HMAC algorithm (default: 'sha512') */
|
|
14
|
+
hmacAlgorithm?: string;
|
|
15
|
+
/** HKDF info string (default: 'PaillierPrimeGen') */
|
|
16
|
+
hkdfInfo?: string;
|
|
17
|
+
/** HKDF output length (default: 64) */
|
|
18
|
+
hkdfLength?: number;
|
|
19
|
+
/** Key pair bit length (default: 3072) */
|
|
20
|
+
keypairBitLength?: number;
|
|
21
|
+
/** Prime test iterations (default: 256) */
|
|
22
|
+
primeTestIterations?: number;
|
|
23
|
+
/** Max prime generation attempts (default: 20000) */
|
|
24
|
+
maxPrimeAttempts?: number;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=voting-key-derivation-options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-key-derivation-options.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-key-derivation-options.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,2BAA2B;IAC1C,iDAAiD;IACjD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4CAA4C;IAC5C,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,0CAA0C;IAC1C,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,kDAAkD;IAClD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,yCAAyC;IACzC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,qDAAqD;IACrD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uCAAuC;IACvC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,0CAA0C;IAC1C,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,2CAA2C;IAC3C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,qDAAqD;IACrD,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-key-derivation-options.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-key-derivation-options.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Result of a voting poll with decrypted tallies
|
|
3
|
+
*/
|
|
4
|
+
export interface VotingPollResults {
|
|
5
|
+
/** Total number of votes cast */
|
|
6
|
+
totalVotes: bigint;
|
|
7
|
+
/** Tallies for each choice */
|
|
8
|
+
tallies: bigint[];
|
|
9
|
+
/** Choice names */
|
|
10
|
+
choices: string[];
|
|
11
|
+
/** Percentage for each choice (0-100) */
|
|
12
|
+
percentages: number[];
|
|
13
|
+
/** Index of the winning choice */
|
|
14
|
+
winnerIndex: number;
|
|
15
|
+
/** Name of the winning choice */
|
|
16
|
+
winnerName: string;
|
|
17
|
+
/** Number of unique voters */
|
|
18
|
+
voterCount: number;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=voting-poll-results.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-poll-results.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-poll-results.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,iCAAiC;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,8BAA8B;IAC9B,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,mBAAmB;IACnB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,yCAAyC;IACzC,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,kCAAkC;IAClC,WAAW,EAAE,MAAM,CAAC;IACpB,iCAAiC;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,8BAA8B;IAC9B,UAAU,EAAE,MAAM,CAAC;CACpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-poll-results.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-poll-results.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { PlatformID } from '../../../interfaces';
|
|
2
|
+
/**
|
|
3
|
+
* Cryptographically signed receipt proving a vote was cast.
|
|
4
|
+
* Can be used to verify participation without revealing vote content.
|
|
5
|
+
*/
|
|
6
|
+
export interface VoteReceipt<TID extends PlatformID = Uint8Array> {
|
|
7
|
+
/** Unique identifier of the voter */
|
|
8
|
+
voterId: TID;
|
|
9
|
+
/** Unique identifier of the poll */
|
|
10
|
+
pollId: TID;
|
|
11
|
+
/** Unix timestamp when vote was cast */
|
|
12
|
+
timestamp: number;
|
|
13
|
+
/** Cryptographic signature from poll authority */
|
|
14
|
+
signature: Uint8Array;
|
|
15
|
+
/** Random nonce for uniqueness */
|
|
16
|
+
nonce: Uint8Array;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=voting-receipt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-receipt.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-receipt.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEtD;;;GAGG;AACH,MAAM,WAAW,WAAW,CAAC,GAAG,SAAS,UAAU,GAAG,UAAU;IAC9D,qCAAqC;IACrC,OAAO,EAAE,GAAG,CAAC;IACb,oCAAoC;IACpC,MAAM,EAAE,GAAG,CAAC;IACZ,wCAAwC;IACxC,SAAS,EAAE,MAAM,CAAC;IAClB,kDAAkD;IAClD,SAAS,EAAE,UAAU,CAAC;IACtB,kCAAkC;IAClC,KAAK,EAAE,UAAU,CAAC;CACnB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-receipt.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-receipt.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { SecurityLevel, VotingMethod } from '../enumerations';
|
|
2
|
+
/**
|
|
3
|
+
* Voting security validator interface.
|
|
4
|
+
* Validates voting methods against security requirements.
|
|
5
|
+
*/
|
|
6
|
+
export interface IVotingSecurityValidator {
|
|
7
|
+
/**
|
|
8
|
+
* Check if voting method is fully secure (no intermediate decryption).
|
|
9
|
+
* @param method - Voting method to check
|
|
10
|
+
* @returns True if method is fully homomorphic
|
|
11
|
+
*/
|
|
12
|
+
isFullySecure(method: VotingMethod): boolean;
|
|
13
|
+
/**
|
|
14
|
+
* Check if voting method requires multiple rounds.
|
|
15
|
+
* @param method - Voting method to check
|
|
16
|
+
* @returns True if method requires intermediate decryption
|
|
17
|
+
*/
|
|
18
|
+
requiresMultipleRounds(method: VotingMethod): boolean;
|
|
19
|
+
/**
|
|
20
|
+
* Get security level for voting method.
|
|
21
|
+
* @param method - Voting method to check
|
|
22
|
+
* @returns Security level classification
|
|
23
|
+
*/
|
|
24
|
+
getSecurityLevel(method: VotingMethod): SecurityLevel;
|
|
25
|
+
/**
|
|
26
|
+
* Validate voting method against security requirements.
|
|
27
|
+
* Throws error if method doesn't meet requirements.
|
|
28
|
+
* @param method - Voting method to validate
|
|
29
|
+
* @param options - Validation options
|
|
30
|
+
* @throws Error if validation fails
|
|
31
|
+
*/
|
|
32
|
+
validate(method: VotingMethod, options?: {
|
|
33
|
+
requireFullySecure?: boolean;
|
|
34
|
+
allowInsecure?: boolean;
|
|
35
|
+
}): void;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=voting-security-validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-security-validator.d.ts","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-security-validator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE9D;;;GAGG;AACH,MAAM,WAAW,wBAAwB;IACvC;;;;OAIG;IACH,aAAa,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC;IAE7C;;;;OAIG;IACH,sBAAsB,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC;IAEtD;;;;OAIG;IACH,gBAAgB,CAAC,MAAM,EAAE,YAAY,GAAG,aAAa,CAAC;IAEtD;;;;;;OAMG;IACH,QAAQ,CACN,MAAM,EAAE,YAAY,EACpB,OAAO,CAAC,EAAE;QACR,kBAAkB,CAAC,EAAE,OAAO,CAAC;QAC7B,aAAa,CAAC,EAAE,OAAO,CAAC;KACzB,GACA,IAAI,CAAC;CACT"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting-security-validator.js","sourceRoot":"","sources":["../../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/interfaces/voting-security-validator.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Persistent State Interfaces for Large-Scale Elections
|
|
3
|
+
* Browser-compatible interfaces - actual persistence in node-ecies-lib
|
|
4
|
+
*/
|
|
5
|
+
interface VoteBatch {
|
|
6
|
+
voter: unknown;
|
|
7
|
+
vote: unknown;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Memory-efficient batch processor (browser-compatible)
|
|
11
|
+
*/
|
|
12
|
+
export declare class BatchVoteProcessor {
|
|
13
|
+
private readonly batchSize;
|
|
14
|
+
private currentBatch;
|
|
15
|
+
constructor(batchSize?: number);
|
|
16
|
+
addVote(voter: unknown, vote: unknown): boolean;
|
|
17
|
+
processBatch(processor: (batch: VoteBatch[]) => Promise<void>): Promise<void>;
|
|
18
|
+
getBatchSize(): number;
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=persistent-state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persistent-state.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/persistent-state.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,UAAU,SAAS;IACjB,KAAK,EAAE,OAAO,CAAC;IACf,IAAI,EAAE,OAAO,CAAC;CACf;AAED;;GAEG;AACH,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,YAAY,CAAmB;gBAE3B,SAAS,SAAO;IAI5B,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO;IAKzC,YAAY,CAChB,SAAS,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,GAC/C,OAAO,CAAC,IAAI,CAAC;IAMhB,YAAY,IAAI,MAAM;CAGvB"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Persistent State Interfaces for Large-Scale Elections
|
|
4
|
+
* Browser-compatible interfaces - actual persistence in node-ecies-lib
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.BatchVoteProcessor = void 0;
|
|
8
|
+
/**
|
|
9
|
+
* Memory-efficient batch processor (browser-compatible)
|
|
10
|
+
*/
|
|
11
|
+
class BatchVoteProcessor {
|
|
12
|
+
batchSize;
|
|
13
|
+
currentBatch = [];
|
|
14
|
+
constructor(batchSize = 1000) {
|
|
15
|
+
this.batchSize = batchSize;
|
|
16
|
+
}
|
|
17
|
+
addVote(voter, vote) {
|
|
18
|
+
this.currentBatch.push({ voter, vote });
|
|
19
|
+
return this.currentBatch.length >= this.batchSize;
|
|
20
|
+
}
|
|
21
|
+
async processBatch(processor) {
|
|
22
|
+
if (this.currentBatch.length === 0)
|
|
23
|
+
return;
|
|
24
|
+
await processor(this.currentBatch);
|
|
25
|
+
this.currentBatch = [];
|
|
26
|
+
}
|
|
27
|
+
getBatchSize() {
|
|
28
|
+
return this.currentBatch.length;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.BatchVoteProcessor = BatchVoteProcessor;
|
|
32
|
+
//# sourceMappingURL=persistent-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persistent-state.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/persistent-state.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAOH;;GAEG;AACH,MAAa,kBAAkB;IACZ,SAAS,CAAS;IAC3B,YAAY,GAAgB,EAAE,CAAC;IAEvC,YAAY,SAAS,GAAG,IAAI;QAC1B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IAED,OAAO,CAAC,KAAc,EAAE,IAAa;QACnC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,SAAgD;QAEhD,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAC3C,MAAM,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACnC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;CACF;AAxBD,gDAwBC"}
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
* Sits on top of ecies-lib with proper role separation
|
|
4
4
|
*/
|
|
5
5
|
import type { PublicKey } from 'paillier-bigint';
|
|
6
|
-
import { PlatformID } from '../../interfaces';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
6
|
+
import { IMember, PlatformID } from '../../interfaces';
|
|
7
|
+
import { VotingMethod } from './enumerations';
|
|
8
|
+
import { AuditLog, EncryptedVote, VoteReceipt } from './interfaces';
|
|
9
9
|
/**
|
|
10
10
|
* Poll aggregates encrypted votes using only public key.
|
|
11
11
|
* Cannot decrypt votes - requires separate Tallier with private key.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"poll-core.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/poll-core.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"poll-core.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/poll-core.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAGpE;;;GAGG;AACH,qBAAa,IAAI,CAAC,GAAG,SAAS,UAAU;IACtC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAM;IAC1B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAwB;IACjD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAe;IACvC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAe;IAC1C,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAY;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoC;IAC3D,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA4C;IACtE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAyB;gBAGjD,EAAE,EAAE,GAAG,EACP,OAAO,EAAE,MAAM,EAAE,EACjB,MAAM,EAAE,YAAY,EACpB,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,EACvB,eAAe,EAAE,SAAS,EAC1B,SAAS,CAAC,EAAE,MAAM,EAClB,aAAa,CAAC,EAAE,OAAO;IAyBzB,IAAI,EAAE,IAAI,GAAG,CAEZ;IACD,IAAI,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,CAEnC;IACD,IAAI,MAAM,IAAI,YAAY,CAEzB;IACD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IACD,IAAI,UAAU,IAAI,MAAM,CAEvB;IACD,IAAI,SAAS,IAAI,MAAM,CAEtB;IACD,IAAI,QAAQ,IAAI,MAAM,GAAG,SAAS,CAEjC;IAED,IAAI,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,CAE5B;IAED;;OAEG;IACH,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,aAAa,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC;IAuBrE;;OAEG;IACH,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,GAAG,OAAO;IAUtE;;OAEG;IACH,KAAK,IAAI,IAAI;IAWb;;OAEG;IACH,iBAAiB,IAAI,WAAW,CAAC,MAAM,EAAE,SAAS,MAAM,EAAE,CAAC;IAqB3D,OAAO,CAAC,aAAa;IA2CrB,OAAO,CAAC,gBAAgB;IAkBxB,OAAO,CAAC,YAAY;IAiBpB,OAAO,CAAC,MAAM;IAMd,OAAO,CAAC,YAAY;CAUrB"}
|
|
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.Poll = void 0;
|
|
4
4
|
const constants_1 = require("../../constants");
|
|
5
5
|
const audit_1 = require("./audit");
|
|
6
|
+
const enumerations_1 = require("./enumerations");
|
|
6
7
|
const security_1 = require("./security");
|
|
7
|
-
const types_1 = require("./types");
|
|
8
8
|
/**
|
|
9
9
|
* Poll aggregates encrypted votes using only public key.
|
|
10
10
|
* Cannot decrypt votes - requires separate Tallier with private key.
|
|
@@ -72,7 +72,6 @@ class Poll {
|
|
|
72
72
|
vote(voter, vote) {
|
|
73
73
|
if (this.isClosed)
|
|
74
74
|
throw new Error('Poll is closed');
|
|
75
|
-
// Use voter.idBytes directly - it's already the canonical Uint8Array format
|
|
76
75
|
const voterId = this._toKey(voter.idBytes);
|
|
77
76
|
if (this._receipts.has(voterId))
|
|
78
77
|
throw new Error('Already voted');
|
|
@@ -135,14 +134,14 @@ class Poll {
|
|
|
135
134
|
}
|
|
136
135
|
_validateVote(vote) {
|
|
137
136
|
switch (this._method) {
|
|
138
|
-
case
|
|
137
|
+
case enumerations_1.VotingMethod.Plurality:
|
|
139
138
|
if (vote.choiceIndex === undefined)
|
|
140
139
|
throw new Error('Choice required');
|
|
141
140
|
if (vote.choiceIndex < 0 || vote.choiceIndex >= this._choices.length) {
|
|
142
141
|
throw new Error('Invalid choice');
|
|
143
142
|
}
|
|
144
143
|
break;
|
|
145
|
-
case
|
|
144
|
+
case enumerations_1.VotingMethod.Approval:
|
|
146
145
|
if (!vote.choices?.length)
|
|
147
146
|
throw new Error('Choices required');
|
|
148
147
|
for (const c of vote.choices) {
|
|
@@ -150,7 +149,7 @@ class Poll {
|
|
|
150
149
|
throw new Error('Invalid choice');
|
|
151
150
|
}
|
|
152
151
|
break;
|
|
153
|
-
case
|
|
152
|
+
case enumerations_1.VotingMethod.Weighted:
|
|
154
153
|
if (vote.choiceIndex === undefined)
|
|
155
154
|
throw new Error('Choice required');
|
|
156
155
|
if (!vote.weight || vote.weight <= 0n)
|
|
@@ -159,8 +158,8 @@ class Poll {
|
|
|
159
158
|
throw new Error('Weight exceeds maximum');
|
|
160
159
|
}
|
|
161
160
|
break;
|
|
162
|
-
case
|
|
163
|
-
case
|
|
161
|
+
case enumerations_1.VotingMethod.Borda:
|
|
162
|
+
case enumerations_1.VotingMethod.RankedChoice: {
|
|
164
163
|
if (!vote.rankings?.length)
|
|
165
164
|
throw new Error('Rankings required');
|
|
166
165
|
const seen = new Set();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"poll-core.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/poll-core.ts"],"names":[],"mappings":";;;AAKA,+CAA4C;AAE5C,
|
|
1
|
+
{"version":3,"file":"poll-core.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/poll-core.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,12 +2,7 @@
|
|
|
2
2
|
* Voting Security Validator
|
|
3
3
|
* Enforces cryptographic security requirements
|
|
4
4
|
*/
|
|
5
|
-
import { VotingMethod } from './
|
|
6
|
-
export declare enum SecurityLevel {
|
|
7
|
-
FullyHomomorphic = "fully-homomorphic",// No intermediate decryption
|
|
8
|
-
MultiRound = "multi-round",// Requires intermediate decryption
|
|
9
|
-
Insecure = "insecure"
|
|
10
|
-
}
|
|
5
|
+
import { SecurityLevel, VotingMethod } from './enumerations';
|
|
11
6
|
export declare const VOTING_SECURITY: Record<VotingMethod, SecurityLevel>;
|
|
12
7
|
export declare class VotingSecurityValidator {
|
|
13
8
|
/**
|
|
@@ -30,4 +25,5 @@ export declare class VotingSecurityValidator {
|
|
|
30
25
|
allowInsecure?: boolean;
|
|
31
26
|
}): void;
|
|
32
27
|
}
|
|
28
|
+
export { SecurityLevel } from './enumerations/security-level';
|
|
33
29
|
//# sourceMappingURL=security.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/security.ts"],"names":[],"mappings":"AAAA;;;GAGG;
|
|
1
|
+
{"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/security.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE7D,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,YAAY,EAAE,aAAa,CAgB/D,CAAC;AAEF,qBAAa,uBAAuB;IAClC;;OAEG;IACH,MAAM,CAAC,aAAa,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO;IAInD;;OAEG;IACH,MAAM,CAAC,sBAAsB,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO;IAI5D;;OAEG;IACH,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,YAAY,GAAG,aAAa;IAI5D;;OAEG;IACH,MAAM,CAAC,QAAQ,CACb,MAAM,EAAE,YAAY,EACpB,OAAO,CAAC,EAAE;QACR,kBAAkB,CAAC,EAAE,OAAO,CAAC;QAC7B,aAAa,CAAC,EAAE,OAAO,CAAC;KACzB,GACA,IAAI;CAoBR;AAGD,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC"}
|
|
@@ -1,46 +1,40 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.VotingSecurityValidator = exports.VOTING_SECURITY = exports.SecurityLevel = void 0;
|
|
4
2
|
/**
|
|
5
3
|
* Voting Security Validator
|
|
6
4
|
* Enforces cryptographic security requirements
|
|
7
5
|
*/
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
SecurityLevel["FullyHomomorphic"] = "fully-homomorphic";
|
|
12
|
-
SecurityLevel["MultiRound"] = "multi-round";
|
|
13
|
-
SecurityLevel["Insecure"] = "insecure";
|
|
14
|
-
})(SecurityLevel || (exports.SecurityLevel = SecurityLevel = {}));
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SecurityLevel = exports.VotingSecurityValidator = exports.VOTING_SECURITY = void 0;
|
|
8
|
+
const enumerations_1 = require("./enumerations");
|
|
15
9
|
exports.VOTING_SECURITY = {
|
|
16
|
-
[
|
|
17
|
-
[
|
|
18
|
-
[
|
|
19
|
-
[
|
|
20
|
-
[
|
|
21
|
-
[
|
|
22
|
-
[
|
|
23
|
-
[
|
|
24
|
-
[
|
|
25
|
-
[
|
|
26
|
-
[
|
|
27
|
-
[
|
|
28
|
-
[
|
|
29
|
-
[
|
|
30
|
-
[
|
|
10
|
+
[enumerations_1.VotingMethod.Plurality]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
11
|
+
[enumerations_1.VotingMethod.Approval]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
12
|
+
[enumerations_1.VotingMethod.Weighted]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
13
|
+
[enumerations_1.VotingMethod.Borda]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
14
|
+
[enumerations_1.VotingMethod.Score]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
15
|
+
[enumerations_1.VotingMethod.YesNo]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
16
|
+
[enumerations_1.VotingMethod.YesNoAbstain]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
17
|
+
[enumerations_1.VotingMethod.Supermajority]: enumerations_1.SecurityLevel.FullyHomomorphic,
|
|
18
|
+
[enumerations_1.VotingMethod.RankedChoice]: enumerations_1.SecurityLevel.MultiRound,
|
|
19
|
+
[enumerations_1.VotingMethod.TwoRound]: enumerations_1.SecurityLevel.MultiRound,
|
|
20
|
+
[enumerations_1.VotingMethod.STAR]: enumerations_1.SecurityLevel.MultiRound,
|
|
21
|
+
[enumerations_1.VotingMethod.STV]: enumerations_1.SecurityLevel.MultiRound,
|
|
22
|
+
[enumerations_1.VotingMethod.Quadratic]: enumerations_1.SecurityLevel.Insecure,
|
|
23
|
+
[enumerations_1.VotingMethod.Consensus]: enumerations_1.SecurityLevel.Insecure,
|
|
24
|
+
[enumerations_1.VotingMethod.ConsentBased]: enumerations_1.SecurityLevel.Insecure,
|
|
31
25
|
};
|
|
32
26
|
class VotingSecurityValidator {
|
|
33
27
|
/**
|
|
34
28
|
* Check if voting method is fully secure (no intermediate decryption)
|
|
35
29
|
*/
|
|
36
30
|
static isFullySecure(method) {
|
|
37
|
-
return exports.VOTING_SECURITY[method] === SecurityLevel.FullyHomomorphic;
|
|
31
|
+
return exports.VOTING_SECURITY[method] === enumerations_1.SecurityLevel.FullyHomomorphic;
|
|
38
32
|
}
|
|
39
33
|
/**
|
|
40
34
|
* Check if voting method requires multiple rounds
|
|
41
35
|
*/
|
|
42
36
|
static requiresMultipleRounds(method) {
|
|
43
|
-
return exports.VOTING_SECURITY[method] === SecurityLevel.MultiRound;
|
|
37
|
+
return exports.VOTING_SECURITY[method] === enumerations_1.SecurityLevel.MultiRound;
|
|
44
38
|
}
|
|
45
39
|
/**
|
|
46
40
|
* Get security level for method
|
|
@@ -53,16 +47,19 @@ class VotingSecurityValidator {
|
|
|
53
47
|
*/
|
|
54
48
|
static validate(method, options) {
|
|
55
49
|
const level = exports.VOTING_SECURITY[method];
|
|
56
|
-
if (level === SecurityLevel.Insecure && !options?.allowInsecure) {
|
|
50
|
+
if (level === enumerations_1.SecurityLevel.Insecure && !options?.allowInsecure) {
|
|
57
51
|
throw new Error(`Voting method ${method} is not cryptographically secure with Paillier. ` +
|
|
58
52
|
`Set allowInsecure: true to use anyway (NOT RECOMMENDED).`);
|
|
59
53
|
}
|
|
60
54
|
if (options?.requireFullySecure &&
|
|
61
|
-
level !== SecurityLevel.FullyHomomorphic) {
|
|
55
|
+
level !== enumerations_1.SecurityLevel.FullyHomomorphic) {
|
|
62
56
|
throw new Error(`Voting method ${method} requires intermediate decryption. ` +
|
|
63
57
|
`Use a fully homomorphic method for maximum security.`);
|
|
64
58
|
}
|
|
65
59
|
}
|
|
66
60
|
}
|
|
67
61
|
exports.VotingSecurityValidator = VotingSecurityValidator;
|
|
62
|
+
// Re-export for convenience
|
|
63
|
+
var security_level_1 = require("./enumerations/security-level");
|
|
64
|
+
Object.defineProperty(exports, "SecurityLevel", { enumerable: true, get: function () { return security_level_1.SecurityLevel; } });
|
|
68
65
|
//# sourceMappingURL=security.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"security.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/security.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"security.js","sourceRoot":"","sources":["../../../../../../packages/digitaldefiance-ecies-lib/src/lib/voting/security.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,iDAA6D;AAEhD,QAAA,eAAe,GAAwC;IAClE,CAAC,2BAAY,CAAC,SAAS,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IACxD,CAAC,2BAAY,CAAC,QAAQ,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IACvD,CAAC,2BAAY,CAAC,QAAQ,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IACvD,CAAC,2BAAY,CAAC,KAAK,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IACpD,CAAC,2BAAY,CAAC,KAAK,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IACpD,CAAC,2BAAY,CAAC,KAAK,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IACpD,CAAC,2BAAY,CAAC,YAAY,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IAC3D,CAAC,2BAAY,CAAC,aAAa,CAAC,EAAE,4BAAa,CAAC,gBAAgB;IAC5D,CAAC,2BAAY,CAAC,YAAY,CAAC,EAAE,4BAAa,CAAC,UAAU;IACrD,CAAC,2BAAY,CAAC,QAAQ,CAAC,EAAE,4BAAa,CAAC,UAAU;IACjD,CAAC,2BAAY,CAAC,IAAI,CAAC,EAAE,4BAAa,CAAC,UAAU;IAC7C,CAAC,2BAAY,CAAC,GAAG,CAAC,EAAE,4BAAa,CAAC,UAAU;IAC5C,CAAC,2BAAY,CAAC,SAAS,CAAC,EAAE,4BAAa,CAAC,QAAQ;IAChD,CAAC,2BAAY,CAAC,SAAS,CAAC,EAAE,4BAAa,CAAC,QAAQ;IAChD,CAAC,2BAAY,CAAC,YAAY,CAAC,EAAE,4BAAa,CAAC,QAAQ;CACpD,CAAC;AAEF,MAAa,uBAAuB;IAClC;;OAEG;IACH,MAAM,CAAC,aAAa,CAAC,MAAoB;QACvC,OAAO,uBAAe,CAAC,MAAM,CAAC,KAAK,4BAAa,CAAC,gBAAgB,CAAC;IACpE,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,sBAAsB,CAAC,MAAoB;QAChD,OAAO,uBAAe,CAAC,MAAM,CAAC,KAAK,4BAAa,CAAC,UAAU,CAAC;IAC9D,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,gBAAgB,CAAC,MAAoB;QAC1C,OAAO,uBAAe,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,QAAQ,CACb,MAAoB,EACpB,OAGC;QAED,MAAM,KAAK,GAAG,uBAAe,CAAC,MAAM,CAAC,CAAC;QAEtC,IAAI,KAAK,KAAK,4BAAa,CAAC,QAAQ,IAAI,CAAC,OAAO,EAAE,aAAa,EAAE,CAAC;YAChE,MAAM,IAAI,KAAK,CACb,iBAAiB,MAAM,kDAAkD;gBACvE,0DAA0D,CAC7D,CAAC;QACJ,CAAC;QAED,IACE,OAAO,EAAE,kBAAkB;YAC3B,KAAK,KAAK,4BAAa,CAAC,gBAAgB,EACxC,CAAC;YACD,MAAM,IAAI,KAAK,CACb,iBAAiB,MAAM,qCAAqC;gBAC1D,sDAAsD,CACzD,CAAC;QACJ,CAAC;IACH,CAAC;CACF;AAnDD,0DAmDC;AAED,4BAA4B;AAC5B,gEAA8D;AAArD,+GAAA,aAAa,OAAA"}
|