@fairblock/stabletrust 1.0.0
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/README.md +304 -0
- package/package.json +41 -0
- package/pkg/LICENSE +176 -0
- package/pkg/confidential_transfer_proof_generation.d.ts +65 -0
- package/pkg/confidential_transfer_proof_generation.js +654 -0
- package/pkg/confidential_transfer_proof_generation_bg.wasm +0 -0
- package/pkg/confidential_transfer_proof_generation_bg.wasm.d.ts +17 -0
- package/pkg/package.json +28 -0
- package/pkg/proof_generator_wasm_bg.wasm +0 -0
- package/src/client.js +885 -0
- package/src/constants.js +32 -0
- package/src/crypto.js +90 -0
- package/src/index.d.ts +275 -0
- package/src/index.js +5 -0
- package/src/utils.js +84 -0
- package/src/wasm-loader.js +85 -0
|
@@ -0,0 +1,654 @@
|
|
|
1
|
+
let wasm;
|
|
2
|
+
|
|
3
|
+
const heap = new Array(128).fill(undefined);
|
|
4
|
+
|
|
5
|
+
heap.push(undefined, null, true, false);
|
|
6
|
+
|
|
7
|
+
function getObject(idx) { return heap[idx]; }
|
|
8
|
+
|
|
9
|
+
let heap_next = heap.length;
|
|
10
|
+
|
|
11
|
+
function addHeapObject(obj) {
|
|
12
|
+
if (heap_next === heap.length) heap.push(heap.length + 1);
|
|
13
|
+
const idx = heap_next;
|
|
14
|
+
heap_next = heap[idx];
|
|
15
|
+
|
|
16
|
+
heap[idx] = obj;
|
|
17
|
+
return idx;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function handleError(f, args) {
|
|
21
|
+
try {
|
|
22
|
+
return f.apply(this, args);
|
|
23
|
+
} catch (e) {
|
|
24
|
+
wasm.__wbindgen_export_0(addHeapObject(e));
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const cachedTextDecoder = (typeof TextDecoder !== 'undefined' ? new TextDecoder('utf-8', { ignoreBOM: true, fatal: true }) : { decode: () => { throw Error('TextDecoder not available') } } );
|
|
29
|
+
|
|
30
|
+
if (typeof TextDecoder !== 'undefined') { cachedTextDecoder.decode(); };
|
|
31
|
+
|
|
32
|
+
let cachedUint8ArrayMemory0 = null;
|
|
33
|
+
|
|
34
|
+
function getUint8ArrayMemory0() {
|
|
35
|
+
if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {
|
|
36
|
+
cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);
|
|
37
|
+
}
|
|
38
|
+
return cachedUint8ArrayMemory0;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function getStringFromWasm0(ptr, len) {
|
|
42
|
+
ptr = ptr >>> 0;
|
|
43
|
+
return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function dropObject(idx) {
|
|
47
|
+
if (idx < 132) return;
|
|
48
|
+
heap[idx] = heap_next;
|
|
49
|
+
heap_next = idx;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function takeObject(idx) {
|
|
53
|
+
const ret = getObject(idx);
|
|
54
|
+
dropObject(idx);
|
|
55
|
+
return ret;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function isLikeNone(x) {
|
|
59
|
+
return x === undefined || x === null;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
let WASM_VECTOR_LEN = 0;
|
|
63
|
+
|
|
64
|
+
const cachedTextEncoder = (typeof TextEncoder !== 'undefined' ? new TextEncoder('utf-8') : { encode: () => { throw Error('TextEncoder not available') } } );
|
|
65
|
+
|
|
66
|
+
const encodeString = (typeof cachedTextEncoder.encodeInto === 'function'
|
|
67
|
+
? function (arg, view) {
|
|
68
|
+
return cachedTextEncoder.encodeInto(arg, view);
|
|
69
|
+
}
|
|
70
|
+
: function (arg, view) {
|
|
71
|
+
const buf = cachedTextEncoder.encode(arg);
|
|
72
|
+
view.set(buf);
|
|
73
|
+
return {
|
|
74
|
+
read: arg.length,
|
|
75
|
+
written: buf.length
|
|
76
|
+
};
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
function passStringToWasm0(arg, malloc, realloc) {
|
|
80
|
+
|
|
81
|
+
if (realloc === undefined) {
|
|
82
|
+
const buf = cachedTextEncoder.encode(arg);
|
|
83
|
+
const ptr = malloc(buf.length, 1) >>> 0;
|
|
84
|
+
getUint8ArrayMemory0().subarray(ptr, ptr + buf.length).set(buf);
|
|
85
|
+
WASM_VECTOR_LEN = buf.length;
|
|
86
|
+
return ptr;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
let len = arg.length;
|
|
90
|
+
let ptr = malloc(len, 1) >>> 0;
|
|
91
|
+
|
|
92
|
+
const mem = getUint8ArrayMemory0();
|
|
93
|
+
|
|
94
|
+
let offset = 0;
|
|
95
|
+
|
|
96
|
+
for (; offset < len; offset++) {
|
|
97
|
+
const code = arg.charCodeAt(offset);
|
|
98
|
+
if (code > 0x7F) break;
|
|
99
|
+
mem[ptr + offset] = code;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
if (offset !== len) {
|
|
103
|
+
if (offset !== 0) {
|
|
104
|
+
arg = arg.slice(offset);
|
|
105
|
+
}
|
|
106
|
+
ptr = realloc(ptr, len, len = offset + arg.length * 3, 1) >>> 0;
|
|
107
|
+
const view = getUint8ArrayMemory0().subarray(ptr + offset, ptr + len);
|
|
108
|
+
const ret = encodeString(arg, view);
|
|
109
|
+
|
|
110
|
+
offset += ret.written;
|
|
111
|
+
ptr = realloc(ptr, len, offset, 1) >>> 0;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
WASM_VECTOR_LEN = offset;
|
|
115
|
+
return ptr;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
let cachedDataViewMemory0 = null;
|
|
119
|
+
|
|
120
|
+
function getDataViewMemory0() {
|
|
121
|
+
if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) {
|
|
122
|
+
cachedDataViewMemory0 = new DataView(wasm.memory.buffer);
|
|
123
|
+
}
|
|
124
|
+
return cachedDataViewMemory0;
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* @param {string} input
|
|
128
|
+
* @returns {string}
|
|
129
|
+
*/
|
|
130
|
+
export function generate_withdraw_proof(input) {
|
|
131
|
+
let deferred3_0;
|
|
132
|
+
let deferred3_1;
|
|
133
|
+
try {
|
|
134
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
135
|
+
const ptr0 = passStringToWasm0(input, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
136
|
+
const len0 = WASM_VECTOR_LEN;
|
|
137
|
+
wasm.generate_withdraw_proof(retptr, ptr0, len0);
|
|
138
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
139
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
140
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
141
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
142
|
+
var ptr2 = r0;
|
|
143
|
+
var len2 = r1;
|
|
144
|
+
if (r3) {
|
|
145
|
+
ptr2 = 0; len2 = 0;
|
|
146
|
+
throw takeObject(r2);
|
|
147
|
+
}
|
|
148
|
+
deferred3_0 = ptr2;
|
|
149
|
+
deferred3_1 = len2;
|
|
150
|
+
return getStringFromWasm0(ptr2, len2);
|
|
151
|
+
} finally {
|
|
152
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
153
|
+
wasm.__wbindgen_export_3(deferred3_0, deferred3_1, 1);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* @param {string} ciphertext_base64
|
|
159
|
+
* @param {string} keypair_base64
|
|
160
|
+
* @returns {string}
|
|
161
|
+
*/
|
|
162
|
+
export function decrypt_ciphertext(ciphertext_base64, keypair_base64) {
|
|
163
|
+
let deferred4_0;
|
|
164
|
+
let deferred4_1;
|
|
165
|
+
try {
|
|
166
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
167
|
+
const ptr0 = passStringToWasm0(ciphertext_base64, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
168
|
+
const len0 = WASM_VECTOR_LEN;
|
|
169
|
+
const ptr1 = passStringToWasm0(keypair_base64, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
170
|
+
const len1 = WASM_VECTOR_LEN;
|
|
171
|
+
wasm.decrypt_ciphertext(retptr, ptr0, len0, ptr1, len1);
|
|
172
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
173
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
174
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
175
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
176
|
+
var ptr3 = r0;
|
|
177
|
+
var len3 = r1;
|
|
178
|
+
if (r3) {
|
|
179
|
+
ptr3 = 0; len3 = 0;
|
|
180
|
+
throw takeObject(r2);
|
|
181
|
+
}
|
|
182
|
+
deferred4_0 = ptr3;
|
|
183
|
+
deferred4_1 = len3;
|
|
184
|
+
return getStringFromWasm0(ptr3, len3);
|
|
185
|
+
} finally {
|
|
186
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
187
|
+
wasm.__wbindgen_export_3(deferred4_0, deferred4_1, 1);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
/**
|
|
192
|
+
* Generate a deterministic ElGamal keypair from an EIP-712 signature
|
|
193
|
+
* @param {string} signature_hex
|
|
194
|
+
* @param {string} domain_context
|
|
195
|
+
* @returns {string}
|
|
196
|
+
*/
|
|
197
|
+
export function generate_deterministic_keypair(signature_hex, domain_context) {
|
|
198
|
+
let deferred4_0;
|
|
199
|
+
let deferred4_1;
|
|
200
|
+
try {
|
|
201
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
202
|
+
const ptr0 = passStringToWasm0(signature_hex, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
203
|
+
const len0 = WASM_VECTOR_LEN;
|
|
204
|
+
const ptr1 = passStringToWasm0(domain_context, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
205
|
+
const len1 = WASM_VECTOR_LEN;
|
|
206
|
+
wasm.generate_deterministic_keypair(retptr, ptr0, len0, ptr1, len1);
|
|
207
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
208
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
209
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
210
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
211
|
+
var ptr3 = r0;
|
|
212
|
+
var len3 = r1;
|
|
213
|
+
if (r3) {
|
|
214
|
+
ptr3 = 0; len3 = 0;
|
|
215
|
+
throw takeObject(r2);
|
|
216
|
+
}
|
|
217
|
+
deferred4_0 = ptr3;
|
|
218
|
+
deferred4_1 = len3;
|
|
219
|
+
return getStringFromWasm0(ptr3, len3);
|
|
220
|
+
} finally {
|
|
221
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
222
|
+
wasm.__wbindgen_export_3(deferred4_0, deferred4_1, 1);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
/**
|
|
227
|
+
* @returns {string}
|
|
228
|
+
*/
|
|
229
|
+
export function test_wasm() {
|
|
230
|
+
let deferred2_0;
|
|
231
|
+
let deferred2_1;
|
|
232
|
+
try {
|
|
233
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
234
|
+
wasm.test_wasm(retptr);
|
|
235
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
236
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
237
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
238
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
239
|
+
var ptr1 = r0;
|
|
240
|
+
var len1 = r1;
|
|
241
|
+
if (r3) {
|
|
242
|
+
ptr1 = 0; len1 = 0;
|
|
243
|
+
throw takeObject(r2);
|
|
244
|
+
}
|
|
245
|
+
deferred2_0 = ptr1;
|
|
246
|
+
deferred2_1 = len1;
|
|
247
|
+
return getStringFromWasm0(ptr1, len1);
|
|
248
|
+
} finally {
|
|
249
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
250
|
+
wasm.__wbindgen_export_3(deferred2_0, deferred2_1, 1);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* @param {string} input
|
|
256
|
+
* @returns {string}
|
|
257
|
+
*/
|
|
258
|
+
export function generate_transfer_proof(input) {
|
|
259
|
+
let deferred3_0;
|
|
260
|
+
let deferred3_1;
|
|
261
|
+
try {
|
|
262
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
263
|
+
const ptr0 = passStringToWasm0(input, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
264
|
+
const len0 = WASM_VECTOR_LEN;
|
|
265
|
+
wasm.generate_transfer_proof(retptr, ptr0, len0);
|
|
266
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
267
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
268
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
269
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
270
|
+
var ptr2 = r0;
|
|
271
|
+
var len2 = r1;
|
|
272
|
+
if (r3) {
|
|
273
|
+
ptr2 = 0; len2 = 0;
|
|
274
|
+
throw takeObject(r2);
|
|
275
|
+
}
|
|
276
|
+
deferred3_0 = ptr2;
|
|
277
|
+
deferred3_1 = len2;
|
|
278
|
+
return getStringFromWasm0(ptr2, len2);
|
|
279
|
+
} finally {
|
|
280
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
281
|
+
wasm.__wbindgen_export_3(deferred3_0, deferred3_1, 1);
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
/**
|
|
286
|
+
* Decode transfer proof from contract input data and extract transfer amount ciphertext
|
|
287
|
+
* handle_index: 0 for sender, 1 for recipient
|
|
288
|
+
* @param {string} validity_proof_base64
|
|
289
|
+
* @param {number} handle_index
|
|
290
|
+
* @returns {string}
|
|
291
|
+
*/
|
|
292
|
+
export function decode_transfer_proof(validity_proof_base64, handle_index) {
|
|
293
|
+
let deferred3_0;
|
|
294
|
+
let deferred3_1;
|
|
295
|
+
try {
|
|
296
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
297
|
+
const ptr0 = passStringToWasm0(validity_proof_base64, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
298
|
+
const len0 = WASM_VECTOR_LEN;
|
|
299
|
+
wasm.decode_transfer_proof(retptr, ptr0, len0, handle_index);
|
|
300
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
301
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
302
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
303
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
304
|
+
var ptr2 = r0;
|
|
305
|
+
var len2 = r1;
|
|
306
|
+
if (r3) {
|
|
307
|
+
ptr2 = 0; len2 = 0;
|
|
308
|
+
throw takeObject(r2);
|
|
309
|
+
}
|
|
310
|
+
deferred3_0 = ptr2;
|
|
311
|
+
deferred3_1 = len2;
|
|
312
|
+
return getStringFromWasm0(ptr2, len2);
|
|
313
|
+
} finally {
|
|
314
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
315
|
+
wasm.__wbindgen_export_3(deferred3_0, deferred3_1, 1);
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
/**
|
|
320
|
+
* Generate a random ElGamal keypair (for compatibility)
|
|
321
|
+
* @returns {string}
|
|
322
|
+
*/
|
|
323
|
+
export function generate_keypair() {
|
|
324
|
+
let deferred2_0;
|
|
325
|
+
let deferred2_1;
|
|
326
|
+
try {
|
|
327
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
328
|
+
wasm.generate_keypair(retptr);
|
|
329
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
330
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
331
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
332
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
333
|
+
var ptr1 = r0;
|
|
334
|
+
var len1 = r1;
|
|
335
|
+
if (r3) {
|
|
336
|
+
ptr1 = 0; len1 = 0;
|
|
337
|
+
throw takeObject(r2);
|
|
338
|
+
}
|
|
339
|
+
deferred2_0 = ptr1;
|
|
340
|
+
deferred2_1 = len1;
|
|
341
|
+
return getStringFromWasm0(ptr1, len1);
|
|
342
|
+
} finally {
|
|
343
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
344
|
+
wasm.__wbindgen_export_3(deferred2_0, deferred2_1, 1);
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
|
|
348
|
+
/**
|
|
349
|
+
* @param {bigint} amount
|
|
350
|
+
* @param {string} pubkey_base64
|
|
351
|
+
* @returns {string}
|
|
352
|
+
*/
|
|
353
|
+
export function encrypt_amount(amount, pubkey_base64) {
|
|
354
|
+
let deferred3_0;
|
|
355
|
+
let deferred3_1;
|
|
356
|
+
try {
|
|
357
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
358
|
+
const ptr0 = passStringToWasm0(pubkey_base64, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
359
|
+
const len0 = WASM_VECTOR_LEN;
|
|
360
|
+
wasm.encrypt_amount(retptr, amount, ptr0, len0);
|
|
361
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
362
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
363
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
364
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
365
|
+
var ptr2 = r0;
|
|
366
|
+
var len2 = r1;
|
|
367
|
+
if (r3) {
|
|
368
|
+
ptr2 = 0; len2 = 0;
|
|
369
|
+
throw takeObject(r2);
|
|
370
|
+
}
|
|
371
|
+
deferred3_0 = ptr2;
|
|
372
|
+
deferred3_1 = len2;
|
|
373
|
+
return getStringFromWasm0(ptr2, len2);
|
|
374
|
+
} finally {
|
|
375
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
376
|
+
wasm.__wbindgen_export_3(deferred3_0, deferred3_1, 1);
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
/**
|
|
381
|
+
* Generate a deterministic ElGamal keypair using legacy method (for backward compatibility)
|
|
382
|
+
* @param {string} signature_hex
|
|
383
|
+
* @returns {string}
|
|
384
|
+
*/
|
|
385
|
+
export function generate_deterministic_keypair_legacy(signature_hex) {
|
|
386
|
+
let deferred3_0;
|
|
387
|
+
let deferred3_1;
|
|
388
|
+
try {
|
|
389
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
390
|
+
const ptr0 = passStringToWasm0(signature_hex, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
391
|
+
const len0 = WASM_VECTOR_LEN;
|
|
392
|
+
wasm.generate_deterministic_keypair_legacy(retptr, ptr0, len0);
|
|
393
|
+
var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);
|
|
394
|
+
var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);
|
|
395
|
+
var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);
|
|
396
|
+
var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);
|
|
397
|
+
var ptr2 = r0;
|
|
398
|
+
var len2 = r1;
|
|
399
|
+
if (r3) {
|
|
400
|
+
ptr2 = 0; len2 = 0;
|
|
401
|
+
throw takeObject(r2);
|
|
402
|
+
}
|
|
403
|
+
deferred3_0 = ptr2;
|
|
404
|
+
deferred3_1 = len2;
|
|
405
|
+
return getStringFromWasm0(ptr2, len2);
|
|
406
|
+
} finally {
|
|
407
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
408
|
+
wasm.__wbindgen_export_3(deferred3_0, deferred3_1, 1);
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
async function __wbg_load(module, imports) {
|
|
413
|
+
if (typeof Response === 'function' && module instanceof Response) {
|
|
414
|
+
if (typeof WebAssembly.instantiateStreaming === 'function') {
|
|
415
|
+
try {
|
|
416
|
+
return await WebAssembly.instantiateStreaming(module, imports);
|
|
417
|
+
|
|
418
|
+
} catch (e) {
|
|
419
|
+
if (module.headers.get('Content-Type') != 'application/wasm') {
|
|
420
|
+
console.warn("`WebAssembly.instantiateStreaming` failed because your server does not serve Wasm with `application/wasm` MIME type. Falling back to `WebAssembly.instantiate` which is slower. Original error:\n", e);
|
|
421
|
+
|
|
422
|
+
} else {
|
|
423
|
+
throw e;
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
const bytes = await module.arrayBuffer();
|
|
429
|
+
return await WebAssembly.instantiate(bytes, imports);
|
|
430
|
+
|
|
431
|
+
} else {
|
|
432
|
+
const instance = await WebAssembly.instantiate(module, imports);
|
|
433
|
+
|
|
434
|
+
if (instance instanceof WebAssembly.Instance) {
|
|
435
|
+
return { instance, module };
|
|
436
|
+
|
|
437
|
+
} else {
|
|
438
|
+
return instance;
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
function __wbg_get_imports() {
|
|
444
|
+
const imports = {};
|
|
445
|
+
imports.wbg = {};
|
|
446
|
+
imports.wbg.__wbg_buffer_609cc3eee51ed158 = function(arg0) {
|
|
447
|
+
const ret = getObject(arg0).buffer;
|
|
448
|
+
return addHeapObject(ret);
|
|
449
|
+
};
|
|
450
|
+
imports.wbg.__wbg_call_672a4d21634d4a24 = function() { return handleError(function (arg0, arg1) {
|
|
451
|
+
const ret = getObject(arg0).call(getObject(arg1));
|
|
452
|
+
return addHeapObject(ret);
|
|
453
|
+
}, arguments) };
|
|
454
|
+
imports.wbg.__wbg_call_7cccdd69e0791ae2 = function() { return handleError(function (arg0, arg1, arg2) {
|
|
455
|
+
const ret = getObject(arg0).call(getObject(arg1), getObject(arg2));
|
|
456
|
+
return addHeapObject(ret);
|
|
457
|
+
}, arguments) };
|
|
458
|
+
imports.wbg.__wbg_crypto_574e78ad8b13b65f = function(arg0) {
|
|
459
|
+
const ret = getObject(arg0).crypto;
|
|
460
|
+
return addHeapObject(ret);
|
|
461
|
+
};
|
|
462
|
+
imports.wbg.__wbg_getRandomValues_b8f5dbd5f3995a9e = function() { return handleError(function (arg0, arg1) {
|
|
463
|
+
getObject(arg0).getRandomValues(getObject(arg1));
|
|
464
|
+
}, arguments) };
|
|
465
|
+
imports.wbg.__wbg_getTime_46267b1c24877e30 = function(arg0) {
|
|
466
|
+
const ret = getObject(arg0).getTime();
|
|
467
|
+
return ret;
|
|
468
|
+
};
|
|
469
|
+
imports.wbg.__wbg_log_03eafded1f977497 = function(arg0, arg1) {
|
|
470
|
+
console.log(getStringFromWasm0(arg0, arg1));
|
|
471
|
+
};
|
|
472
|
+
imports.wbg.__wbg_msCrypto_a61aeb35a24c1329 = function(arg0) {
|
|
473
|
+
const ret = getObject(arg0).msCrypto;
|
|
474
|
+
return addHeapObject(ret);
|
|
475
|
+
};
|
|
476
|
+
imports.wbg.__wbg_new0_f788a2397c7ca929 = function() {
|
|
477
|
+
const ret = new Date();
|
|
478
|
+
return addHeapObject(ret);
|
|
479
|
+
};
|
|
480
|
+
imports.wbg.__wbg_new_a12002a7f91c75be = function(arg0) {
|
|
481
|
+
const ret = new Uint8Array(getObject(arg0));
|
|
482
|
+
return addHeapObject(ret);
|
|
483
|
+
};
|
|
484
|
+
imports.wbg.__wbg_newnoargs_105ed471475aaf50 = function(arg0, arg1) {
|
|
485
|
+
const ret = new Function(getStringFromWasm0(arg0, arg1));
|
|
486
|
+
return addHeapObject(ret);
|
|
487
|
+
};
|
|
488
|
+
imports.wbg.__wbg_newwithbyteoffsetandlength_d97e637ebe145a9a = function(arg0, arg1, arg2) {
|
|
489
|
+
const ret = new Uint8Array(getObject(arg0), arg1 >>> 0, arg2 >>> 0);
|
|
490
|
+
return addHeapObject(ret);
|
|
491
|
+
};
|
|
492
|
+
imports.wbg.__wbg_newwithlength_a381634e90c276d4 = function(arg0) {
|
|
493
|
+
const ret = new Uint8Array(arg0 >>> 0);
|
|
494
|
+
return addHeapObject(ret);
|
|
495
|
+
};
|
|
496
|
+
imports.wbg.__wbg_node_905d3e251edff8a2 = function(arg0) {
|
|
497
|
+
const ret = getObject(arg0).node;
|
|
498
|
+
return addHeapObject(ret);
|
|
499
|
+
};
|
|
500
|
+
imports.wbg.__wbg_process_dc0fbacc7c1c06f7 = function(arg0) {
|
|
501
|
+
const ret = getObject(arg0).process;
|
|
502
|
+
return addHeapObject(ret);
|
|
503
|
+
};
|
|
504
|
+
imports.wbg.__wbg_randomFillSync_ac0988aba3254290 = function() { return handleError(function (arg0, arg1) {
|
|
505
|
+
getObject(arg0).randomFillSync(takeObject(arg1));
|
|
506
|
+
}, arguments) };
|
|
507
|
+
imports.wbg.__wbg_require_60cc747a6bc5215a = function() { return handleError(function () {
|
|
508
|
+
const ret = module.require;
|
|
509
|
+
return addHeapObject(ret);
|
|
510
|
+
}, arguments) };
|
|
511
|
+
imports.wbg.__wbg_set_65595bdd868b3009 = function(arg0, arg1, arg2) {
|
|
512
|
+
getObject(arg0).set(getObject(arg1), arg2 >>> 0);
|
|
513
|
+
};
|
|
514
|
+
imports.wbg.__wbg_static_accessor_GLOBAL_88a902d13a557d07 = function() {
|
|
515
|
+
const ret = typeof global === 'undefined' ? null : global;
|
|
516
|
+
return isLikeNone(ret) ? 0 : addHeapObject(ret);
|
|
517
|
+
};
|
|
518
|
+
imports.wbg.__wbg_static_accessor_GLOBAL_THIS_56578be7e9f832b0 = function() {
|
|
519
|
+
const ret = typeof globalThis === 'undefined' ? null : globalThis;
|
|
520
|
+
return isLikeNone(ret) ? 0 : addHeapObject(ret);
|
|
521
|
+
};
|
|
522
|
+
imports.wbg.__wbg_static_accessor_SELF_37c5d418e4bf5819 = function() {
|
|
523
|
+
const ret = typeof self === 'undefined' ? null : self;
|
|
524
|
+
return isLikeNone(ret) ? 0 : addHeapObject(ret);
|
|
525
|
+
};
|
|
526
|
+
imports.wbg.__wbg_static_accessor_WINDOW_5de37043a91a9c40 = function() {
|
|
527
|
+
const ret = typeof window === 'undefined' ? null : window;
|
|
528
|
+
return isLikeNone(ret) ? 0 : addHeapObject(ret);
|
|
529
|
+
};
|
|
530
|
+
imports.wbg.__wbg_subarray_aa9065fa9dc5df96 = function(arg0, arg1, arg2) {
|
|
531
|
+
const ret = getObject(arg0).subarray(arg1 >>> 0, arg2 >>> 0);
|
|
532
|
+
return addHeapObject(ret);
|
|
533
|
+
};
|
|
534
|
+
imports.wbg.__wbg_versions_c01dfd4722a88165 = function(arg0) {
|
|
535
|
+
const ret = getObject(arg0).versions;
|
|
536
|
+
return addHeapObject(ret);
|
|
537
|
+
};
|
|
538
|
+
imports.wbg.__wbindgen_is_function = function(arg0) {
|
|
539
|
+
const ret = typeof(getObject(arg0)) === 'function';
|
|
540
|
+
return ret;
|
|
541
|
+
};
|
|
542
|
+
imports.wbg.__wbindgen_is_object = function(arg0) {
|
|
543
|
+
const val = getObject(arg0);
|
|
544
|
+
const ret = typeof(val) === 'object' && val !== null;
|
|
545
|
+
return ret;
|
|
546
|
+
};
|
|
547
|
+
imports.wbg.__wbindgen_is_string = function(arg0) {
|
|
548
|
+
const ret = typeof(getObject(arg0)) === 'string';
|
|
549
|
+
return ret;
|
|
550
|
+
};
|
|
551
|
+
imports.wbg.__wbindgen_is_undefined = function(arg0) {
|
|
552
|
+
const ret = getObject(arg0) === undefined;
|
|
553
|
+
return ret;
|
|
554
|
+
};
|
|
555
|
+
imports.wbg.__wbindgen_memory = function() {
|
|
556
|
+
const ret = wasm.memory;
|
|
557
|
+
return addHeapObject(ret);
|
|
558
|
+
};
|
|
559
|
+
imports.wbg.__wbindgen_object_clone_ref = function(arg0) {
|
|
560
|
+
const ret = getObject(arg0);
|
|
561
|
+
return addHeapObject(ret);
|
|
562
|
+
};
|
|
563
|
+
imports.wbg.__wbindgen_object_drop_ref = function(arg0) {
|
|
564
|
+
takeObject(arg0);
|
|
565
|
+
};
|
|
566
|
+
imports.wbg.__wbindgen_string_get = function(arg0, arg1) {
|
|
567
|
+
const obj = getObject(arg1);
|
|
568
|
+
const ret = typeof(obj) === 'string' ? obj : undefined;
|
|
569
|
+
var ptr1 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_export_1, wasm.__wbindgen_export_2);
|
|
570
|
+
var len1 = WASM_VECTOR_LEN;
|
|
571
|
+
getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true);
|
|
572
|
+
getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true);
|
|
573
|
+
};
|
|
574
|
+
imports.wbg.__wbindgen_string_new = function(arg0, arg1) {
|
|
575
|
+
const ret = getStringFromWasm0(arg0, arg1);
|
|
576
|
+
return addHeapObject(ret);
|
|
577
|
+
};
|
|
578
|
+
imports.wbg.__wbindgen_throw = function(arg0, arg1) {
|
|
579
|
+
throw new Error(getStringFromWasm0(arg0, arg1));
|
|
580
|
+
};
|
|
581
|
+
|
|
582
|
+
return imports;
|
|
583
|
+
}
|
|
584
|
+
|
|
585
|
+
function __wbg_init_memory(imports, memory) {
|
|
586
|
+
|
|
587
|
+
}
|
|
588
|
+
|
|
589
|
+
function __wbg_finalize_init(instance, module) {
|
|
590
|
+
wasm = instance.exports;
|
|
591
|
+
__wbg_init.__wbindgen_wasm_module = module;
|
|
592
|
+
cachedDataViewMemory0 = null;
|
|
593
|
+
cachedUint8ArrayMemory0 = null;
|
|
594
|
+
|
|
595
|
+
|
|
596
|
+
|
|
597
|
+
return wasm;
|
|
598
|
+
}
|
|
599
|
+
|
|
600
|
+
function initSync(module) {
|
|
601
|
+
if (wasm !== undefined) return wasm;
|
|
602
|
+
|
|
603
|
+
|
|
604
|
+
if (typeof module !== 'undefined') {
|
|
605
|
+
if (Object.getPrototypeOf(module) === Object.prototype) {
|
|
606
|
+
({module} = module)
|
|
607
|
+
} else {
|
|
608
|
+
console.warn('using deprecated parameters for `initSync()`; pass a single object instead')
|
|
609
|
+
}
|
|
610
|
+
}
|
|
611
|
+
|
|
612
|
+
const imports = __wbg_get_imports();
|
|
613
|
+
|
|
614
|
+
__wbg_init_memory(imports);
|
|
615
|
+
|
|
616
|
+
if (!(module instanceof WebAssembly.Module)) {
|
|
617
|
+
module = new WebAssembly.Module(module);
|
|
618
|
+
}
|
|
619
|
+
|
|
620
|
+
const instance = new WebAssembly.Instance(module, imports);
|
|
621
|
+
|
|
622
|
+
return __wbg_finalize_init(instance, module);
|
|
623
|
+
}
|
|
624
|
+
|
|
625
|
+
async function __wbg_init(module_or_path) {
|
|
626
|
+
if (wasm !== undefined) return wasm;
|
|
627
|
+
|
|
628
|
+
|
|
629
|
+
if (typeof module_or_path !== 'undefined') {
|
|
630
|
+
if (Object.getPrototypeOf(module_or_path) === Object.prototype) {
|
|
631
|
+
({module_or_path} = module_or_path)
|
|
632
|
+
} else {
|
|
633
|
+
console.warn('using deprecated parameters for the initialization function; pass a single object instead')
|
|
634
|
+
}
|
|
635
|
+
}
|
|
636
|
+
|
|
637
|
+
if (typeof module_or_path === 'undefined') {
|
|
638
|
+
module_or_path = new URL('confidential_transfer_proof_generation_bg.wasm', import.meta.url);
|
|
639
|
+
}
|
|
640
|
+
const imports = __wbg_get_imports();
|
|
641
|
+
|
|
642
|
+
if (typeof module_or_path === 'string' || (typeof Request === 'function' && module_or_path instanceof Request) || (typeof URL === 'function' && module_or_path instanceof URL)) {
|
|
643
|
+
module_or_path = fetch(module_or_path);
|
|
644
|
+
}
|
|
645
|
+
|
|
646
|
+
__wbg_init_memory(imports);
|
|
647
|
+
|
|
648
|
+
const { instance, module } = await __wbg_load(await module_or_path, imports);
|
|
649
|
+
|
|
650
|
+
return __wbg_finalize_init(instance, module);
|
|
651
|
+
}
|
|
652
|
+
|
|
653
|
+
export { initSync };
|
|
654
|
+
export default __wbg_init;
|
|
Binary file
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/* tslint:disable */
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
export const memory: WebAssembly.Memory;
|
|
4
|
+
export const decode_transfer_proof: (a: number, b: number, c: number, d: number) => void;
|
|
5
|
+
export const decrypt_ciphertext: (a: number, b: number, c: number, d: number, e: number) => void;
|
|
6
|
+
export const encrypt_amount: (a: number, b: bigint, c: number, d: number) => void;
|
|
7
|
+
export const generate_deterministic_keypair: (a: number, b: number, c: number, d: number, e: number) => void;
|
|
8
|
+
export const generate_deterministic_keypair_legacy: (a: number, b: number, c: number) => void;
|
|
9
|
+
export const generate_keypair: (a: number) => void;
|
|
10
|
+
export const generate_transfer_proof: (a: number, b: number, c: number) => void;
|
|
11
|
+
export const generate_withdraw_proof: (a: number, b: number, c: number) => void;
|
|
12
|
+
export const test_wasm: (a: number) => void;
|
|
13
|
+
export const __wbindgen_export_0: (a: number) => void;
|
|
14
|
+
export const __wbindgen_export_1: (a: number, b: number) => number;
|
|
15
|
+
export const __wbindgen_export_2: (a: number, b: number, c: number, d: number) => number;
|
|
16
|
+
export const __wbindgen_add_to_stack_pointer: (a: number) => number;
|
|
17
|
+
export const __wbindgen_export_3: (a: number, b: number, c: number) => void;
|
package/pkg/package.json
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "confidential-transfer-proof-generation",
|
|
3
|
+
"type": "module",
|
|
4
|
+
"description": "Confidential transfer proof generation tool",
|
|
5
|
+
"version": "0.4.0",
|
|
6
|
+
"license": "Apache-2.0",
|
|
7
|
+
"repository": {
|
|
8
|
+
"type": "git",
|
|
9
|
+
"url": "https://github.com/Fairblock/he-confidential-transfers"
|
|
10
|
+
},
|
|
11
|
+
"files": [
|
|
12
|
+
"confidential_transfer_proof_generation_bg.wasm",
|
|
13
|
+
"confidential_transfer_proof_generation.js",
|
|
14
|
+
"confidential_transfer_proof_generation.d.ts"
|
|
15
|
+
],
|
|
16
|
+
"main": "confidential_transfer_proof_generation.js",
|
|
17
|
+
"types": "confidential_transfer_proof_generation.d.ts",
|
|
18
|
+
"sideEffects": [
|
|
19
|
+
"./snippets/*"
|
|
20
|
+
],
|
|
21
|
+
"keywords": [
|
|
22
|
+
"confidential",
|
|
23
|
+
"transfers",
|
|
24
|
+
"proofs",
|
|
25
|
+
"elgamal",
|
|
26
|
+
"cosmwasm"
|
|
27
|
+
]
|
|
28
|
+
}
|
|
Binary file
|