@zhoujun_aptos/octopus-ts-sdk-min 0.22.4 → 0.22.5

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 (95) hide show
  1. package/dist/common/index.d.ts +966 -0
  2. package/dist/common/index.js +4491 -0
  3. package/dist/common/index.js.map +1 -0
  4. package/dist/esm/index.d.mts +966 -0
  5. package/dist/esm/index.mjs +4449 -0
  6. package/dist/esm/index.mjs.map +1 -0
  7. package/package.json +22 -8
  8. package/dist/elgamal.d.ts +0 -31
  9. package/dist/elgamal.d.ts.map +0 -1
  10. package/dist/elgamal.js +0 -96
  11. package/dist/elgamal.js.map +0 -1
  12. package/dist/enc/index.d.ts +0 -42
  13. package/dist/enc/index.d.ts.map +0 -1
  14. package/dist/enc/index.js +0 -211
  15. package/dist/enc/index.js.map +0 -1
  16. package/dist/enc/simple_elgamal_ristretto255.d.ts +0 -28
  17. package/dist/enc/simple_elgamal_ristretto255.d.ts.map +0 -1
  18. package/dist/enc/simple_elgamal_ristretto255.js +0 -173
  19. package/dist/enc/simple_elgamal_ristretto255.js.map +0 -1
  20. package/dist/group.d.ts +0 -39
  21. package/dist/group.d.ts.map +0 -1
  22. package/dist/group.js +0 -165
  23. package/dist/group.js.map +0 -1
  24. package/dist/ibe/index.d.ts +0 -54
  25. package/dist/ibe/index.d.ts.map +0 -1
  26. package/dist/ibe/index.js +0 -280
  27. package/dist/ibe/index.js.map +0 -1
  28. package/dist/ibe/otp_hmac_boneh_franklin_bls12381_short_pk.d.ts +0 -38
  29. package/dist/ibe/otp_hmac_boneh_franklin_bls12381_short_pk.d.ts.map +0 -1
  30. package/dist/ibe/otp_hmac_boneh_franklin_bls12381_short_pk.js +0 -155
  31. package/dist/ibe/otp_hmac_boneh_franklin_bls12381_short_pk.js.map +0 -1
  32. package/dist/index.d.ts +0 -13
  33. package/dist/index.d.ts.map +0 -1
  34. package/dist/index.js +0 -50
  35. package/dist/index.js.map +0 -1
  36. package/dist/shamir_gf256.d.ts +0 -61
  37. package/dist/shamir_gf256.d.ts.map +0 -1
  38. package/dist/shamir_gf256.js +0 -295
  39. package/dist/shamir_gf256.js.map +0 -1
  40. package/dist/sig/index.d.ts +0 -42
  41. package/dist/sig/index.d.ts.map +0 -1
  42. package/dist/sig/index.js +0 -212
  43. package/dist/sig/index.js.map +0 -1
  44. package/dist/sig/schnorr_ristretto255.d.ts +0 -29
  45. package/dist/sig/schnorr_ristretto255.d.ts.map +0 -1
  46. package/dist/sig/schnorr_ristretto255.js +0 -142
  47. package/dist/sig/schnorr_ristretto255.js.map +0 -1
  48. package/dist/silent_setup_encryption.d.ts +0 -93
  49. package/dist/silent_setup_encryption.d.ts.map +0 -1
  50. package/dist/silent_setup_encryption.js +0 -342
  51. package/dist/silent_setup_encryption.js.map +0 -1
  52. package/dist/silent_setup_encryption_xchain/aptos.d.ts +0 -40
  53. package/dist/silent_setup_encryption_xchain/aptos.d.ts.map +0 -1
  54. package/dist/silent_setup_encryption_xchain/aptos.js +0 -125
  55. package/dist/silent_setup_encryption_xchain/aptos.js.map +0 -1
  56. package/dist/silent_setup_encryption_xchain/index.d.ts +0 -116
  57. package/dist/silent_setup_encryption_xchain/index.d.ts.map +0 -1
  58. package/dist/silent_setup_encryption_xchain/index.js +0 -471
  59. package/dist/silent_setup_encryption_xchain/index.js.map +0 -1
  60. package/dist/silent_setup_encryption_xchain/solana.d.ts +0 -42
  61. package/dist/silent_setup_encryption_xchain/solana.d.ts.map +0 -1
  62. package/dist/silent_setup_encryption_xchain/solana.js +0 -145
  63. package/dist/silent_setup_encryption_xchain/solana.js.map +0 -1
  64. package/dist/sym/aes256gcm.d.ts +0 -27
  65. package/dist/sym/aes256gcm.d.ts.map +0 -1
  66. package/dist/sym/aes256gcm.js +0 -107
  67. package/dist/sym/aes256gcm.js.map +0 -1
  68. package/dist/sym/index.d.ts +0 -27
  69. package/dist/sym/index.d.ts.map +0 -1
  70. package/dist/sym/index.js +0 -154
  71. package/dist/sym/index.js.map +0 -1
  72. package/dist/threshold-ibe/aptos.d.ts +0 -42
  73. package/dist/threshold-ibe/aptos.d.ts.map +0 -1
  74. package/dist/threshold-ibe/aptos.js +0 -324
  75. package/dist/threshold-ibe/aptos.js.map +0 -1
  76. package/dist/threshold-ibe/index.d.ts +0 -147
  77. package/dist/threshold-ibe/index.d.ts.map +0 -1
  78. package/dist/threshold-ibe/index.js +0 -453
  79. package/dist/threshold-ibe/index.js.map +0 -1
  80. package/dist/threshold-ibe/solana.d.ts +0 -38
  81. package/dist/threshold-ibe/solana.d.ts.map +0 -1
  82. package/dist/threshold-ibe/solana.js +0 -197
  83. package/dist/threshold-ibe/solana.js.map +0 -1
  84. package/dist/utils.d.ts +0 -12
  85. package/dist/utils.d.ts.map +0 -1
  86. package/dist/utils.js +0 -130
  87. package/dist/utils.js.map +0 -1
  88. package/dist/worker_config.d.ts +0 -30
  89. package/dist/worker_config.d.ts.map +0 -1
  90. package/dist/worker_config.js +0 -142
  91. package/dist/worker_config.js.map +0 -1
  92. package/dist/worker_task.d.ts +0 -29
  93. package/dist/worker_task.d.ts.map +0 -1
  94. package/dist/worker_task.js +0 -178
  95. package/dist/worker_task.js.map +0 -1
@@ -1,197 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ProofOfPermission = exports.ContractID = void 0;
4
- exports.verifyPermission = verifyPermission;
5
- const ts_sdk_1 = require("@aptos-labs/ts-sdk");
6
- const utils_1 = require("@noble/hashes/utils");
7
- const web3_js_1 = require("@solana/web3.js");
8
- class ContractID {
9
- knownChainName; // mainnet-beta/testnet/devnet
10
- programId;
11
- constructor({ knownChainName, programId }) {
12
- this.knownChainName = knownChainName;
13
- this.programId = programId;
14
- }
15
- static deserialize(deserializer) {
16
- const knownChainName = deserializer.deserializeStr();
17
- const programId = new web3_js_1.PublicKey(deserializer.deserializeBytes());
18
- return new ContractID({ knownChainName, programId });
19
- }
20
- static fromBytes(bytes) {
21
- const deserializer = new ts_sdk_1.Deserializer(bytes);
22
- return ContractID.deserialize(deserializer);
23
- }
24
- static fromHex(hex) {
25
- return ContractID.fromBytes((0, utils_1.hexToBytes)(hex));
26
- }
27
- serialize(serializer) {
28
- serializer.serializeStr(this.knownChainName);
29
- serializer.serializeBytes(this.programId.toBytes());
30
- }
31
- toBytes() {
32
- const serializer = new ts_sdk_1.Serializer();
33
- this.serialize(serializer);
34
- return serializer.toUint8Array();
35
- }
36
- toHex() {
37
- return (0, utils_1.bytesToHex)(this.toBytes());
38
- }
39
- toPrettyMessage(indent = 0) {
40
- const pad = ' '.repeat(indent);
41
- return `\n${pad}knownChainName: ${this.knownChainName}\n${pad}programId: ${this.programId.toBase58()}`;
42
- }
43
- }
44
- exports.ContractID = ContractID;
45
- class ProofOfPermission {
46
- static SCHEME_UNVERSIONED = 0;
47
- static SCHEME_VERSIONED = 1;
48
- scheme;
49
- inner;
50
- constructor(scheme, inner) {
51
- this.scheme = scheme;
52
- this.inner = inner;
53
- }
54
- static newVersioned(txn) {
55
- return new ProofOfPermission(ProofOfPermission.SCHEME_VERSIONED, txn);
56
- }
57
- static newUnversioned(txn) {
58
- return new ProofOfPermission(ProofOfPermission.SCHEME_UNVERSIONED, txn);
59
- }
60
- static deserialize(deserializer) {
61
- const scheme = deserializer.deserializeU8();
62
- const bytes = deserializer.deserializeBytes();
63
- if (scheme == ProofOfPermission.SCHEME_VERSIONED) {
64
- const inner = web3_js_1.VersionedTransaction.deserialize(bytes);
65
- return new ProofOfPermission(ProofOfPermission.SCHEME_VERSIONED, inner);
66
- }
67
- else if (scheme == ProofOfPermission.SCHEME_UNVERSIONED) {
68
- const inner = web3_js_1.Transaction.from(Buffer.from(bytes));
69
- return new ProofOfPermission(ProofOfPermission.SCHEME_UNVERSIONED, inner);
70
- }
71
- else {
72
- throw new Error(`Unknown scheme: ${scheme}`);
73
- }
74
- }
75
- static fromBytes(bytes) {
76
- const deserializer = new ts_sdk_1.Deserializer(bytes);
77
- return ProofOfPermission.deserialize(deserializer);
78
- }
79
- static fromHex(hex) {
80
- return ProofOfPermission.fromBytes((0, utils_1.hexToBytes)(hex));
81
- }
82
- serialize(serializer) {
83
- serializer.serializeU8(this.scheme);
84
- if (this.scheme == ProofOfPermission.SCHEME_VERSIONED) {
85
- serializer.serializeBytes(this.inner.serialize());
86
- }
87
- else if (this.scheme == ProofOfPermission.SCHEME_UNVERSIONED) {
88
- serializer.serializeBytes(this.inner.serialize());
89
- }
90
- else {
91
- throw new Error(`Unknown scheme: ${this.scheme}`);
92
- }
93
- }
94
- toBytes() {
95
- const serializer = new ts_sdk_1.Serializer();
96
- this.serialize(serializer);
97
- return serializer.toUint8Array();
98
- }
99
- toHex() {
100
- return (0, utils_1.bytesToHex)(this.toBytes());
101
- }
102
- }
103
- exports.ProofOfPermission = ProofOfPermission;
104
- async function verifyPermission({ fullDecryptionDomain, proof }) {
105
- const txn = proof.inner;
106
- assertTransactionValid({ txn, fullDecryptionDomain });
107
- await assertTransactionSimulationPasses(txn, fullDecryptionDomain.getSolanaContractID().knownChainName);
108
- }
109
- /**
110
- * Ensure the proof-of-permission transaction is valid and matches the decryption context.
111
- */
112
- function assertTransactionValid({ txn, fullDecryptionDomain }) {
113
- let instructions;
114
- if (txn instanceof web3_js_1.VersionedTransaction) {
115
- const message = txn.message;
116
- instructions = message.compiledInstructions.map(ix => {
117
- if (ix.programIdIndex >= message.staticAccountKeys.length) {
118
- throw new Error(`Program ID index ${ix.programIdIndex} is out of bounds for static account keys (length: ${message.staticAccountKeys.length}). Address table lookups are not supported for validation.`);
119
- }
120
- const programId = message.staticAccountKeys[ix.programIdIndex];
121
- return { programId, data: Buffer.from(ix.data) };
122
- });
123
- }
124
- else {
125
- instructions = txn.instructions.map(ix => ({
126
- programId: ix.programId,
127
- data: Buffer.from(ix.data)
128
- }));
129
- }
130
- // Check: Ensure there's only 1 instruction
131
- if (instructions.length !== 1) {
132
- throw new Error(`transaction must contain exactly 1 instruction, found ${instructions.length}`);
133
- }
134
- const instruction = instructions[0];
135
- // Check: Ensure txn program matches contractIDV0.programId
136
- if (!instruction.programId.equals(fullDecryptionDomain.getSolanaContractID().programId)) {
137
- throw new Error(`transaction instruction program ID (${instruction.programId.toString()}) does not match contract program ID`);
138
- }
139
- // Parse instruction data and ensure parameter equals decryptionContext.domain
140
- // Anchor instruction format:
141
- // - First 8 bytes: discriminator (method selector)
142
- // - Remaining bytes: Borsh-serialized parameters
143
- // For assert_access(full_blob_name_bytes: Vec<u8>):
144
- // - After discriminator: 4 bytes (u32 little-endian) for Vec length, then the Vec bytes
145
- const instructionData = instruction.data;
146
- if (instructionData.length < 12) {
147
- throw new Error('instruction data too short (must be at least 12 bytes: 8-byte discriminator + 4-byte Vec length)');
148
- }
149
- // Skip 8-byte discriminator
150
- const paramData = instructionData.slice(8);
151
- const vecLength = paramData.readUInt32LE(0);
152
- if (paramData.length < 4 + vecLength) {
153
- throw new Error(`instruction data incomplete: expected ${4 + vecLength} bytes after discriminator, found ${paramData.length}`);
154
- }
155
- const fullBlobNameBytes = paramData.slice(4, 4 + vecLength);
156
- // Ensure there are no extra bytes after the parameter
157
- const expectedParamDataLength = 4 + vecLength;
158
- if (paramData.length > expectedParamDataLength) {
159
- throw new Error(`instruction data has extra bytes: expected exactly ${expectedParamDataLength} bytes after discriminator, found ${paramData.length}`);
160
- }
161
- // Compare with decryptionContext.domain
162
- if ((0, utils_1.bytesToHex)(fullBlobNameBytes) !== fullDecryptionDomain.toHex()) {
163
- throw new Error(`domain mismatch: instruction parameter does not match decryptionContext.domain`);
164
- }
165
- }
166
- async function assertTransactionSimulationPasses(txn, chainName) {
167
- let rpcUrl;
168
- if (chainName === 'localnet' || chainName === 'localhost') {
169
- rpcUrl = 'http://127.0.0.1:8899';
170
- }
171
- else if (chainName === 'devnet') {
172
- rpcUrl = 'https://api.devnet.solana.com';
173
- }
174
- else if (chainName === 'testnet') {
175
- rpcUrl = 'https://api.testnet.solana.com';
176
- }
177
- else if (chainName === 'mainnet-beta') {
178
- rpcUrl = 'https://api.mainnet-beta.solana.com';
179
- }
180
- else {
181
- throw new Error(`Unknown chain name: ${chainName}`);
182
- }
183
- const connection = new web3_js_1.Connection(rpcUrl, 'confirmed');
184
- let simulation;
185
- if (txn instanceof web3_js_1.VersionedTransaction) {
186
- simulation = await connection.simulateTransaction(txn, {
187
- sigVerify: true,
188
- });
189
- }
190
- else {
191
- simulation = await connection.simulateTransaction(txn);
192
- }
193
- if (simulation.value.err) {
194
- throw new Error(`transaction simulation failed: ${JSON.stringify(simulation.value.err)}`);
195
- }
196
- }
197
- //# sourceMappingURL=solana.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"solana.js","sourceRoot":"","sources":["../../src/threshold-ibe/solana.ts"],"names":[],"mappings":"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"}
package/dist/utils.d.ts DELETED
@@ -1,12 +0,0 @@
1
- import { AptosConfig } from "@aptos-labs/ts-sdk";
2
- export declare const CONTRACT_ADDRESS_HEX: string;
3
- export declare const SHELBYNET_CONTRACT_ADDRESS_HEX: string;
4
- export declare function randBytes(length: number): Uint8Array;
5
- export declare function xorBytes(blinder: Uint8Array<ArrayBufferLike>, plaintext: Uint8Array<ArrayBufferLike>): Uint8Array;
6
- export declare function concatBytes(a: Uint8Array, b: Uint8Array): Uint8Array;
7
- export declare function kdf(seed: Uint8Array, dst: Uint8Array, targetLength: number): Uint8Array;
8
- export declare function hmac_sha3_256(key: Uint8Array, message: Uint8Array): Uint8Array;
9
- export declare function sha3_256(message: Uint8Array): Uint8Array;
10
- export declare function sha3_512(message: Uint8Array): Uint8Array;
11
- export declare function getAptosConfig(networkName: string): AptosConfig;
12
- //# sourceMappingURL=utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAuB,MAAM,oBAAoB,CAAC;AAGtE,eAAO,MAAM,oBAAoB,EAAE,MAA6E,CAAC;AACjH,eAAO,MAAM,8BAA8B,EAAE,MAA6E,CAAC;AAG3H,wBAAgB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,CAUpD;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC,eAAe,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,eAAe,CAAC,GAAG,UAAU,CAKjH;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,UAAU,GAAG,UAAU,CAKpE;AA6BD,wBAAgB,GAAG,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,GAAG,UAAU,CAavF;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,GAAG,UAAU,CAc9E;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,UAAU,GAAG,UAAU,CAExD;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,UAAU,GAAG,UAAU,CAExD;AAED,wBAAgB,cAAc,CAAC,WAAW,EAAE,MAAM,GAAG,WAAW,CA4B/D"}
package/dist/utils.js DELETED
@@ -1,130 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SHELBYNET_CONTRACT_ADDRESS_HEX = exports.CONTRACT_ADDRESS_HEX = void 0;
4
- exports.randBytes = randBytes;
5
- exports.xorBytes = xorBytes;
6
- exports.concatBytes = concatBytes;
7
- exports.kdf = kdf;
8
- exports.hmac_sha3_256 = hmac_sha3_256;
9
- exports.sha3_256 = sha3_256;
10
- exports.sha3_512 = sha3_512;
11
- exports.getAptosConfig = getAptosConfig;
12
- const gas_station_client_1 = require("@aptos-labs/gas-station-client");
13
- const ts_sdk_1 = require("@aptos-labs/ts-sdk");
14
- const sha3_1 = require("@noble/hashes/sha3");
15
- exports.CONTRACT_ADDRESS_HEX = "0x114f3ad54703b5afb48d596103253fdfeed121e131edb83a25dfed6cb92b73ed";
16
- exports.SHELBYNET_CONTRACT_ADDRESS_HEX = "0xaa5c09269872b767ebe0dad214fc02dc9f00074380d05ff78cbcf4a1c49e0e62";
17
- // Browser-compatible random bytes function (fallback)
18
- function randBytes(length) {
19
- if (typeof crypto !== 'undefined' && crypto.getRandomValues) {
20
- return crypto.getRandomValues(new Uint8Array(length));
21
- }
22
- // Fallback for environments without crypto.getRandomValues
23
- const bytes = new Uint8Array(length);
24
- for (let i = 0; i < length; i++) {
25
- bytes[i] = Math.floor(Math.random() * 256);
26
- }
27
- return bytes;
28
- }
29
- function xorBytes(blinder, plaintext) {
30
- if (blinder.length != plaintext.length) {
31
- throw new Error("Blinder and plaintext must be the same length");
32
- }
33
- return new Uint8Array(blinder.map((byte, index) => byte ^ plaintext[index]));
34
- }
35
- function concatBytes(a, b) {
36
- const result = new Uint8Array(a.length + b.length);
37
- result.set(a, 0);
38
- result.set(b, a.length);
39
- return result;
40
- }
41
- class KeyBlockDeriveInput {
42
- seed;
43
- dst;
44
- targetLength;
45
- blockIndex;
46
- constructor(seed, dst, targetLength, blockIndex) {
47
- this.seed = seed;
48
- this.dst = dst;
49
- this.targetLength = targetLength;
50
- this.blockIndex = blockIndex;
51
- }
52
- serialize(serializer) {
53
- serializer.serializeBytes(this.seed);
54
- serializer.serializeBytes(this.dst);
55
- serializer.serializeU64(this.targetLength);
56
- serializer.serializeU64(this.blockIndex);
57
- }
58
- toBytes() {
59
- const serializer = new ts_sdk_1.Serializer();
60
- this.serialize(serializer);
61
- return serializer.toUint8Array();
62
- }
63
- }
64
- function kdf(seed, dst, targetLength) {
65
- if (seed.length < 32) {
66
- throw new Error("Seed must be at least 32 bytes");
67
- }
68
- let blockPreImage = new KeyBlockDeriveInput(seed, dst, targetLength, 0);
69
- let output = new Uint8Array(0);
70
- while (targetLength > 0) {
71
- let blockOutput = new Uint8Array(sha3_256(blockPreImage.toBytes()).slice(0, Math.min(32, targetLength)));
72
- output = concatBytes(output, blockOutput);
73
- targetLength -= blockOutput.length;
74
- blockPreImage.blockIndex++;
75
- }
76
- return output;
77
- }
78
- function hmac_sha3_256(key, message) {
79
- if (key.length !== 32) {
80
- throw new Error("Key must be 32 bytes");
81
- }
82
- key = concatBytes(key, new Uint8Array(32));
83
- let ipad = new Uint8Array(64);
84
- let opad = new Uint8Array(64);
85
- for (let i = 0; i < 64; i++) {
86
- ipad[i] = 0x36;
87
- opad[i] = 0x5c;
88
- }
89
- const innerInput = concatBytes(xorBytes(ipad, key), message);
90
- const outerInput = concatBytes(xorBytes(opad, key), sha3_256(innerInput));
91
- return sha3_256(outerInput);
92
- }
93
- function sha3_256(message) {
94
- return (0, sha3_1.sha3_256)(message);
95
- }
96
- function sha3_512(message) {
97
- return (0, sha3_1.sha3_512)(message);
98
- }
99
- function getAptosConfig(networkName) {
100
- if (networkName === "testnet") {
101
- return new ts_sdk_1.AptosConfig({
102
- network: ts_sdk_1.Network.TESTNET,
103
- clientConfig: {
104
- API_KEY: "AG-AQYQBGCUUXENJVPK8S6BQXSKXLFP7WN6U"
105
- },
106
- pluginSettings: { TRANSACTION_SUBMITTER: new gas_station_client_1.GasStationTransactionSubmitter({
107
- network: ts_sdk_1.Network.TESTNET,
108
- apiKey: "aptoslabs_UjL29oi1TsS_88HcxKLRWoDssNhLCfiasWygcioZP9MFn"
109
- }) }
110
- });
111
- }
112
- else if (networkName === "shelbynet") {
113
- return new ts_sdk_1.AptosConfig({
114
- network: ts_sdk_1.Network.CUSTOM,
115
- clientConfig: {
116
- API_KEY: "AG-CTZKWQBKTBHPRZBDDTF6YWNTQ7MKSA1ZE"
117
- },
118
- pluginSettings: { TRANSACTION_SUBMITTER: new gas_station_client_1.GasStationTransactionSubmitter({
119
- network: ts_sdk_1.Network.CUSTOM,
120
- apiKey: "aptoslabs_BMhkGMQWaPj_7GLMCrSRKR34fYeESUAR82QfscPkVgtvb",
121
- baseUrl: "https://api.shelbynet.shelby.xyz/gs/v1"
122
- }) },
123
- fullnode: "https://api.shelbynet.shelby.xyz/v1"
124
- });
125
- }
126
- else {
127
- throw new Error(`Unsupported network name: ${networkName}`);
128
- }
129
- }
130
- //# sourceMappingURL=utils.js.map
package/dist/utils.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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"}
@@ -1,30 +0,0 @@
1
- import { AccountAddress, Aptos, Deserializer, Serializer } from "@aptos-labs/ts-sdk";
2
- import * as Enc from "./enc";
3
- import * as IBE from "./ibe";
4
- import * as Sig from "./sig";
5
- export declare class WorkerConfig {
6
- expiryTimeMicrosecs: number;
7
- endpoint: string;
8
- encEk: Enc.EncryptionKey;
9
- sigVk: Sig.VerifyingKey;
10
- ibeMpk: IBE.MasterPublicKey;
11
- constructor(expiryTimeMicrosecs: number, endpoint: string, encEk: Enc.EncryptionKey, sigVk: Sig.VerifyingKey, ibeMpk: IBE.MasterPublicKey);
12
- static dummy(): WorkerConfig;
13
- static deserialize(deserializer: Deserializer): WorkerConfig;
14
- static fromBytes(bytes: Uint8Array): WorkerConfig;
15
- static fromHex(hex: string): WorkerConfig;
16
- serialize(serializer: Serializer): void;
17
- toBytes(): Uint8Array;
18
- toHex(): string;
19
- toPrettyJson(): string;
20
- }
21
- export declare function view(aptos: Aptos, worker: AccountAddress): Promise<WorkerConfig>;
22
- export declare function get(workerEndpoint: string): Promise<WorkerConfig>;
23
- export declare function randWorker(): {
24
- addr: AccountAddress;
25
- config: WorkerConfig;
26
- encDk: Enc.DecryptionKey;
27
- sigSk: Sig.SigningKey;
28
- ibeMsk: IBE.MasterPrivateKey;
29
- };
30
- //# sourceMappingURL=worker_config.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"worker_config.d.ts","sourceRoot":"","sources":["../src/worker_config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,YAAY,EAAW,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAG9F,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAC7B,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAC7B,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAE7B,qBAAa,YAAY;IACrB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,GAAG,CAAC,aAAa,CAAC;IACzB,KAAK,EAAE,GAAG,CAAC,YAAY,CAAC;IACxB,MAAM,EAAE,GAAG,CAAC,eAAe,CAAC;gBAEhB,mBAAmB,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,CAAC,eAAe;IAQzI,MAAM,CAAC,KAAK,IAAI,YAAY;IAU5B,MAAM,CAAC,WAAW,CAAC,YAAY,EAAE,YAAY,GAAG,YAAY;IAS5D,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY;IAKjD,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY;IAIzC,SAAS,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAQvC,OAAO,IAAI,UAAU;IAMrB,KAAK,IAAI,MAAM;IAIf,YAAY,IAAI,MAAM;CASzB;AAED,wBAAsB,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,CAAC,CAUtF;AAED,wBAAsB,GAAG,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAUvE;AAED,wBAAgB,UAAU,IAAI;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,MAAM,EAAE,YAAY,CAAC;IAAC,KAAK,EAAE,GAAG,CAAC,aAAa,CAAC;IAAC,KAAK,EAAE,GAAG,CAAC,UAAU,CAAC;IAAC,MAAM,EAAE,GAAG,CAAC,gBAAgB,CAAA;CAAE,CAU1J"}
@@ -1,142 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.WorkerConfig = void 0;
37
- exports.view = view;
38
- exports.get = get;
39
- exports.randWorker = randWorker;
40
- const ts_sdk_1 = require("@aptos-labs/ts-sdk");
41
- const utils_1 = require("@noble/curves/utils");
42
- const _1 = require(".");
43
- const Enc = __importStar(require("./enc"));
44
- const IBE = __importStar(require("./ibe"));
45
- const Sig = __importStar(require("./sig"));
46
- class WorkerConfig {
47
- expiryTimeMicrosecs;
48
- endpoint;
49
- encEk;
50
- sigVk;
51
- ibeMpk;
52
- constructor(expiryTimeMicrosecs, endpoint, encEk, sigVk, ibeMpk) {
53
- this.expiryTimeMicrosecs = expiryTimeMicrosecs;
54
- this.endpoint = endpoint;
55
- this.encEk = encEk;
56
- this.sigVk = sigVk;
57
- this.ibeMpk = ibeMpk;
58
- }
59
- static dummy() {
60
- const encDk = Enc.keygen();
61
- const encEk = Enc.deriveEncryptionKey(encDk);
62
- const sigSk = Sig.keygen();
63
- const sigVk = Sig.deriveVerifyingKey(sigSk);
64
- const ibeMsk = IBE.keygen();
65
- const ibeMpk = IBE.derivePublicKey(ibeMsk);
66
- return new WorkerConfig(999999999999999999, "http://localhost:3000", encEk, sigVk, ibeMpk);
67
- }
68
- static deserialize(deserializer) {
69
- const expiryTimeMicrosecs = Number(deserializer.deserializeU64());
70
- const endpoint = deserializer.deserializeStr();
71
- const encEk = Enc.EncryptionKey.deserialize(deserializer);
72
- const sigVk = Sig.VerifyingKey.deserialize(deserializer);
73
- const ibeMpk = IBE.MasterPublicKey.deserialize(deserializer);
74
- return new WorkerConfig(expiryTimeMicrosecs, endpoint, encEk, sigVk, ibeMpk);
75
- }
76
- static fromBytes(bytes) {
77
- const deserializer = new ts_sdk_1.Deserializer(bytes);
78
- return WorkerConfig.deserialize(deserializer);
79
- }
80
- static fromHex(hex) {
81
- return WorkerConfig.fromBytes((0, utils_1.hexToBytes)(hex));
82
- }
83
- serialize(serializer) {
84
- serializer.serializeU64(BigInt(this.expiryTimeMicrosecs));
85
- serializer.serializeStr(this.endpoint);
86
- this.encEk.serialize(serializer);
87
- this.sigVk.serialize(serializer);
88
- this.ibeMpk.serialize(serializer);
89
- }
90
- toBytes() {
91
- const serializer = new ts_sdk_1.Serializer();
92
- this.serialize(serializer);
93
- return serializer.toUint8Array();
94
- }
95
- toHex() {
96
- return (0, utils_1.bytesToHex)(this.toBytes());
97
- }
98
- toPrettyJson() {
99
- return JSON.stringify({
100
- expiryTimeMicrosecs: this.expiryTimeMicrosecs,
101
- endpoint: this.endpoint,
102
- encEk: this.encEk.toHex(),
103
- sigVk: this.sigVk.toHex(),
104
- ibeMpk: this.ibeMpk.toHex(),
105
- }, null, 2);
106
- }
107
- }
108
- exports.WorkerConfig = WorkerConfig;
109
- async function view(aptos, worker) {
110
- const moduleAddrHex = aptos.config.network === ts_sdk_1.Network.SHELBYNET ? _1.Utils.SHELBYNET_CONTRACT_ADDRESS_HEX : _1.Utils.CONTRACT_ADDRESS_HEX;
111
- const configBcsMoveVals = await aptos.view({
112
- payload: {
113
- function: `${moduleAddrHex}::worker_config::get_bcs`,
114
- typeArguments: [],
115
- functionArguments: [worker]
116
- }
117
- });
118
- return WorkerConfig.fromHex(configBcsMoveVals[0].toString().slice(2));
119
- }
120
- async function get(workerEndpoint) {
121
- const url = `${workerEndpoint}/config_bcs`;
122
- const response = await fetch(url, {
123
- method: "GET",
124
- });
125
- if (!response.ok) {
126
- throw new Error(`Failed to fetch worker config: ${response.status} ${response.statusText}`);
127
- }
128
- const hex = await response.text();
129
- return WorkerConfig.fromHex(hex);
130
- }
131
- function randWorker() {
132
- const addr = new ts_sdk_1.AccountAddress(_1.Utils.randBytes(32));
133
- const encDk = Enc.keygen();
134
- const encEk = Enc.deriveEncryptionKey(encDk);
135
- const sigSk = Sig.keygen();
136
- const sigVk = Sig.deriveVerifyingKey(sigSk);
137
- const ibeMsk = IBE.keygen();
138
- const ibeMpk = IBE.derivePublicKey(ibeMsk);
139
- const config = new WorkerConfig(1000000, "http://localhost:3000", encEk, sigVk, ibeMpk);
140
- return { addr, config, encDk, sigSk, ibeMsk };
141
- }
142
- //# sourceMappingURL=worker_config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"worker_config.js","sourceRoot":"","sources":["../src/worker_config.ts"],"names":[],"mappings":"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"}
@@ -1,29 +0,0 @@
1
- import { AccountAddress, Deserializer, Ed25519PublicKey, Ed25519Signature, Serializer } from '@aptos-labs/ts-sdk';
2
- import { SilentSetupEncryption, SilentSetupEncryptionXChain } from '.';
3
- import * as ThresholdIbe from './threshold-ibe';
4
- export declare class WorkerTask {
5
- taskType: number;
6
- inner: any;
7
- constructor(taskType: number, inner: any);
8
- static newSilentSetupDecryptionKey(decryptionContext: SilentSetupEncryption.DecryptionContext, userAddr: AccountAddress, publicKey: Ed25519PublicKey, signature: Ed25519Signature): WorkerTask;
9
- static newXChainSilentSetupDecryptionKey(decryptionContext: SilentSetupEncryptionXChain.DecryptionContext, proofOfPermission: SilentSetupEncryptionXChain.ProofOfPermission): WorkerTask;
10
- static newThresholdIbeDecryptionKey(args: {
11
- committee: ThresholdIbe.Committee;
12
- contractId: ThresholdIbe.ContractID;
13
- domain: Uint8Array;
14
- proof: ThresholdIbe.ProofOfPermission;
15
- }): WorkerTask;
16
- static deserialize(deserializer: Deserializer): WorkerTask;
17
- static fromBytes(bytes: Uint8Array): WorkerTask;
18
- static fromHex(hex: string): WorkerTask;
19
- serialize(serializer: Serializer): void;
20
- toBytes(): Uint8Array;
21
- toHex(): string;
22
- unpackThresholdIbeDecryptionKey(): {
23
- committee: ThresholdIbe.Committee;
24
- contractId: ThresholdIbe.ContractID;
25
- domain: Uint8Array;
26
- proof: ThresholdIbe.ProofOfPermission;
27
- };
28
- }
29
- //# sourceMappingURL=worker_task.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"worker_task.d.ts","sourceRoot":"","sources":["../src/worker_task.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAElH,OAAO,EAAE,qBAAqB,EAAE,2BAA2B,EAAE,MAAM,GAAG,CAAC;AACvE,OAAO,KAAK,YAAY,MAAM,iBAAiB,CAAC;AAUhD,qBAAa,UAAU;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,GAAG,CAAC;gBAEC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG;IAexC,MAAM,CAAC,2BAA2B,CAAC,iBAAiB,EAAE,qBAAqB,CAAC,iBAAiB,EAAE,QAAQ,EAAE,cAAc,EAAE,SAAS,EAAE,gBAAgB,EAAE,SAAS,EAAE,gBAAgB,GAAG,UAAU;IAI9L,MAAM,CAAC,iCAAiC,CAAC,iBAAiB,EAAE,2BAA2B,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,2BAA2B,CAAC,iBAAiB,GAAG,UAAU;IAIxL,MAAM,CAAC,4BAA4B,CAAC,IAAI,EAAE;QAAC,SAAS,EAAE,YAAY,CAAC,SAAS,CAAC;QAAC,UAAU,EAAE,YAAY,CAAC,UAAU,CAAC;QAAC,MAAM,EAAE,UAAU,CAAC;QAAC,KAAK,EAAE,YAAY,CAAC,iBAAiB,CAAA;KAAC,GAAG,UAAU;IAI1L,MAAM,CAAC,WAAW,CAAC,YAAY,EAAE,YAAY,GAAG,UAAU;IAe1D,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU;IAK/C,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU;IAIvC,SAAS,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAavC,OAAO,IAAI,UAAU;IAMrB,KAAK,IAAI,MAAM;IAIf,+BAA+B,IAAI;QAAC,SAAS,EAAE,YAAY,CAAC,SAAS,CAAC;QAAC,UAAU,EAAE,YAAY,CAAC,UAAU,CAAC;QAAC,MAAM,EAAE,UAAU,CAAC;QAAC,KAAK,EAAE,YAAY,CAAC,iBAAiB,CAAA;KAAC;CAYzK"}