pulsar-contracts
Version:
211 lines (210 loc) • 11.4 kB
TypeScript
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 {
}