2024-12-04 03:30:35 +00:00
|
|
|
import type { Element } from 'fixed-merkle-tree';
|
2024-10-16 14:19:49 +00:00
|
|
|
export interface snarkInputs {
|
2024-04-29 15:55:15 +00:00
|
|
|
root: Element;
|
|
|
|
nullifierHex: string;
|
2024-09-26 12:23:55 +00:00
|
|
|
recipient: string;
|
|
|
|
relayer: string;
|
2024-04-29 15:55:15 +00:00
|
|
|
fee: bigint;
|
|
|
|
refund: bigint;
|
|
|
|
nullifier: bigint;
|
|
|
|
secret: bigint;
|
|
|
|
pathElements: Element[];
|
|
|
|
pathIndices: Element[];
|
2024-10-16 14:19:49 +00:00
|
|
|
}
|
2024-09-26 12:29:29 +00:00
|
|
|
export type snarkArgs = [
|
|
|
|
_root: string,
|
|
|
|
_nullifierHash: string,
|
|
|
|
_recipient: string,
|
|
|
|
_relayer: string,
|
|
|
|
_fee: string,
|
|
|
|
_refund: string
|
|
|
|
];
|
2024-10-16 14:19:49 +00:00
|
|
|
export interface snarkProofs {
|
2024-09-26 12:23:55 +00:00
|
|
|
proof: string;
|
2024-09-26 12:29:29 +00:00
|
|
|
args: snarkArgs;
|
2024-10-16 14:19:49 +00:00
|
|
|
}
|
2024-04-30 16:55:51 +00:00
|
|
|
export declare function initGroth16(): Promise<void>;
|
2024-04-29 15:55:15 +00:00
|
|
|
export declare function calculateSnarkProof(input: snarkInputs, circuit: object, provingKey: ArrayBuffer): Promise<snarkProofs>;
|