o1js
Version:
TypeScript framework for zk-SNARKs and zkApps
68 lines (58 loc) • 2.52 kB
text/typescript
/**
* This file contains bindings for JSOO written in TS and integrated with our normal code base.
* It is exposed to JSOO by populating a global variable with an object.
* It gets imported as the first thing in ../../snarky.js so that the global variable is ready by the time JSOO code gets executed.
*/
import { prefixHashes, prefixHashesLegacy } from '../crypto/constants.js';
import { Bigint256Bindings } from './bindings/bigint256.js';
import { PallasBindings, VestaBindings } from './bindings/curve.js';
import { FpBindings, FqBindings } from './bindings/field.js';
import { FpVectorBindings, FqVectorBindings } from './bindings/vector.js';
import type * as wasmNamespace from '../compiled/node_bindings/plonk_wasm.cjs';
import {
fieldsFromRustFlat,
fieldsToRustFlat,
} from './bindings/conversion-base.js';
import { proofConversion } from './bindings/conversion-proof.js';
import { conversionCore } from './bindings/conversion-core.js';
import { verifierIndexConversion } from './bindings/conversion-verifier-index.js';
import { oraclesConversion } from './bindings/conversion-oracles.js';
import { jsEnvironment } from './bindings/env.js';
import { srs } from './bindings/srs.js';
export { getRustConversion, RustConversion, Wasm };
const tsBindings = {
jsEnvironment,
prefixHashes,
prefixHashesLegacy,
...Bigint256Bindings,
...FpBindings,
...FqBindings,
...VestaBindings,
...PallasBindings,
...FpVectorBindings,
...FqVectorBindings,
rustConversion: createRustConversion,
srs: (wasm: Wasm) => srs(wasm, getRustConversion(wasm)),
};
// this is put in a global variable so that mina/src/lib/crypto/kimchi_bindings/js/bindings.js finds it
(globalThis as any).__snarkyTsBindings = tsBindings;
type Wasm = typeof wasmNamespace;
function createRustConversion(wasm: Wasm) {
let core = conversionCore(wasm);
let verifierIndex = verifierIndexConversion(wasm, core);
let oracles = oraclesConversion(wasm);
let proof = proofConversion(wasm, core);
return {
fp: { ...core.fp, ...verifierIndex.fp, ...oracles.fp, ...proof.fp },
fq: { ...core.fq, ...verifierIndex.fq, ...oracles.fq, ...proof.fq },
fieldsToRustFlat,
fieldsFromRustFlat,
wireToRust: core.wireToRust,
mapMlArrayToRustVector: core.mapMlArrayToRustVector,
};
}
type RustConversion = ReturnType<typeof createRustConversion>;
let rustConversion: RustConversion | undefined;
function getRustConversion(wasm: Wasm) {
return rustConversion ?? (rustConversion = createRustConversion(wasm));
}