UNPKG

pulsar-contracts

Version:

211 lines (210 loc) 11.4 kB
import { Field, Provable } from 'o1js'; import { SignaturePublicKeyList } from './types/signaturePubKeyList.js'; export { ValidateReduceProof, ValidateReduceProgram, ValidateReducePublicInput, }; declare const ValidateReducePublicInput_base: (new (value: { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }) => { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }) & { _isStruct: true; } & Omit<import("o1js/dist/node/lib/provable/types/provable-intf.js").Provable<{ merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }, { merkleListRoot: bigint; depositListHash: bigint; withdrawalListHash: bigint; }>, "fromFields"> & { fromFields: (fields: import("o1js/dist/node/lib/provable/field.js").Field[]) => { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }; } & { fromValue: (value: { merkleListRoot: string | number | bigint | import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: string | number | bigint | import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: string | number | bigint | import("o1js/dist/node/lib/provable/field.js").Field; }) => { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }; toInput: (x: { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }) => { fields?: Field[] | undefined; packed?: [Field, number][] | undefined; }; toJSON: (x: { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }) => { merkleListRoot: string; depositListHash: string; withdrawalListHash: string; }; fromJSON: (x: { merkleListRoot: string; depositListHash: string; withdrawalListHash: string; }) => { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }; empty: () => { merkleListRoot: import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: import("o1js/dist/node/lib/provable/field.js").Field; }; }; declare class ValidateReducePublicInput extends ValidateReducePublicInput_base { static default: ValidateReducePublicInput; hash(): import("o1js/dist/node/lib/provable/field.js").Field; static fromJSON(json: { merkleListRoot: string; depositListHash: string; withdrawalListHash: string; }): ValidateReducePublicInput; toJSON(): { merkleListRoot: string; depositListHash: string; withdrawalListHash: string; }; } declare const ValidateReduceProgram: { name: string; maxProofsVerified(): Promise<0 | 1 | 2>; compile: (options?: { cache?: import("o1js").Cache; forceRecompile?: boolean; proofsEnabled?: boolean; withRuntimeTables?: boolean; numChunks?: number; lazyMode?: boolean; }) => Promise<{ verificationKey: { data: string; hash: Field; }; }>; verify: (proof: import("o1js").Proof<ValidateReducePublicInput, void>) => Promise<boolean>; digest: () => Promise<string>; analyzeMethods: () => Promise<{ verifySignatures: import("o1js/dist/node/lib/provable/core/provable-context.js").ConstraintSystemSummary & { proofs: import("o1js/dist/node/lib/proof-system/proof.js").ProofClass[]; }; }>; analyzeSingleMethod<K extends "verifySignatures">(methodName: K): Promise<import("o1js/dist/node/lib/provable/core/provable-context.js").ConstraintSystemSummary & { proofs: import("o1js/dist/node/lib/proof-system/proof.js").ProofClass[]; }>; publicInputType: typeof ValidateReducePublicInput; publicOutputType: import("o1js").ProvablePureExtended<void, void, null>; privateInputTypes: { verifySignatures: [typeof SignaturePublicKeyList]; }; auxiliaryOutputTypes: { verifySignatures: undefined; }; rawMethods: { verifySignatures: (publicInput: ValidateReducePublicInput, args_0: SignaturePublicKeyList) => Promise<void>; }; Proof: { new ({ proof, publicInput, publicOutput, maxProofsVerified, }: { proof: import("o1js/dist/node/bindings.js").Pickles.Proof; publicInput: ValidateReducePublicInput; publicOutput: void; maxProofsVerified: 0 | 1 | 2; }): import("o1js").Proof<ValidateReducePublicInput, void>; fromJSON<S extends import("o1js/dist/node/lib/util/types.js").Subclass<typeof import("o1js").Proof>>(this: S, { maxProofsVerified, proof: proofString, publicInput: publicInputJson, publicOutput: publicOutputJson, }: import("o1js").JsonProof): Promise<import("o1js").Proof<import("o1js").InferProvable<S["publicInputType"]>, import("o1js").InferProvable<S["publicOutputType"]>>>; dummy<Input, OutPut>(publicInput: Input, publicOutput: OutPut, maxProofsVerified: 0 | 1 | 2, domainLog2?: number): Promise<import("o1js").Proof<Input, OutPut>>; get provable(): { toFields: (value: import("o1js").Proof<any, any>) => import("o1js/dist/node/lib/provable/field.js").Field[]; toAuxiliary: (value?: import("o1js").Proof<any, any> | undefined) => any[]; fromFields: (fields: import("o1js/dist/node/lib/provable/field.js").Field[], aux: any[]) => import("o1js").Proof<any, any>; sizeInFields(): number; check: (value: import("o1js").Proof<any, any>) => void; toValue: (x: import("o1js").Proof<any, any>) => import("o1js/dist/node/lib/proof-system/proof.js").ProofValue<any, any>; fromValue: (x: import("o1js").Proof<any, any> | import("o1js/dist/node/lib/proof-system/proof.js").ProofValue<any, any>) => import("o1js").Proof<any, any>; toCanonical?: ((x: import("o1js").Proof<any, any>) => import("o1js").Proof<any, any>) | undefined; }; publicInputType: import("o1js").FlexibleProvable<any>; publicOutputType: import("o1js").FlexibleProvable<any>; tag: () => { name: string; }; publicFields(value: import("o1js").ProofBase): { input: import("o1js/dist/node/lib/provable/field.js").Field[]; output: import("o1js/dist/node/lib/provable/field.js").Field[]; }; _proofFromBase64(proofString: import("o1js/dist/node/bindings.js").Base64ProofString, maxProofsVerified: 0 | 1 | 2): unknown; _proofToBase64(proof: import("o1js/dist/node/bindings.js").Pickles.Proof, maxProofsVerified: 0 | 1 | 2): string; }; proofsEnabled: boolean; setProofsEnabled(proofsEnabled: boolean): void; } & { verifySignatures: (publicInput: ValidateReducePublicInput | { merkleListRoot: string | number | bigint | import("o1js/dist/node/lib/provable/field.js").Field; depositListHash: string | number | bigint | import("o1js/dist/node/lib/provable/field.js").Field; withdrawalListHash: string | number | bigint | import("o1js/dist/node/lib/provable/field.js").Field; }, args_0: SignaturePublicKeyList | { list: import("./types/signaturePubKeyList.js").SignaturePublicKey[] | { signature: any; publicKey: { x: bigint; isOdd: boolean; }; }[]; }) => Promise<{ proof: import("o1js").Proof<ValidateReducePublicInput, void>; auxiliaryOutput: undefined; }>; }; declare const ValidateReduceProof_base: { new ({ proof, publicInput, publicOutput, maxProofsVerified, }: { proof: unknown; publicInput: ValidateReducePublicInput; publicOutput: void; maxProofsVerified: 0 | 2 | 1; }): import("o1js").Proof<ValidateReducePublicInput, void>; fromJSON<S extends import("o1js/dist/node/lib/util/types.js").Subclass<typeof import("o1js").Proof>>(this: S, { maxProofsVerified, proof: proofString, publicInput: publicInputJson, publicOutput: publicOutputJson, }: import("o1js").JsonProof): Promise<import("o1js").Proof<import("o1js").InferProvable<S["publicInputType"]>, import("o1js").InferProvable<S["publicOutputType"]>>>; dummy<Input, OutPut>(publicInput: Input, publicOutput: OutPut, maxProofsVerified: 0 | 2 | 1, domainLog2?: number): Promise<import("o1js").Proof<Input, OutPut>>; readonly provable: { toFields: (value: import("o1js").Proof<any, any>) => import("o1js/dist/node/lib/provable/field.js").Field[]; toAuxiliary: (value?: import("o1js").Proof<any, any> | undefined) => any[]; fromFields: (fields: import("o1js/dist/node/lib/provable/field.js").Field[], aux: any[]) => import("o1js").Proof<any, any>; sizeInFields(): number; check: (value: import("o1js").Proof<any, any>) => void; toValue: (x: import("o1js").Proof<any, any>) => import("o1js/dist/node/lib/proof-system/proof.js").ProofValue<any, any>; fromValue: (x: import("o1js").Proof<any, any> | import("o1js/dist/node/lib/proof-system/proof.js").ProofValue<any, any>) => import("o1js").Proof<any, any>; toCanonical?: ((x: import("o1js").Proof<any, any>) => import("o1js").Proof<any, any>) | undefined; }; publicInputType: import("o1js").FlexibleProvable<any>; publicOutputType: import("o1js").FlexibleProvable<any>; tag: () => { name: string; }; publicFields(value: import("o1js").ProofBase<any, any>): { input: import("o1js/dist/node/lib/provable/field.js").Field[]; output: import("o1js/dist/node/lib/provable/field.js").Field[]; }; _proofFromBase64(proofString: string, maxProofsVerified: 0 | 2 | 1): unknown; _proofToBase64(proof: unknown, maxProofsVerified: 0 | 2 | 1): string; } & { provable: Provable<import("o1js").Proof<ValidateReducePublicInput, void>, import("o1js/dist/node/lib/proof-system/proof.js").ProofValue<{ merkleListRoot: bigint; depositListHash: bigint; withdrawalListHash: bigint; }, void>>; }; declare class ValidateReduceProof extends ValidateReduceProof_base { }