UNPKG

o1js

Version:

TypeScript framework for zk-SNARKs and zkApps

73 lines (63 loc) 1.89 kB
import { Field, Bool } from '../../lib/provable/wrapped.js'; import { UInt32, UInt64, Sign } from '../../lib/provable/int.js'; import { PublicKey } from '../../lib/provable/crypto/signature.js'; import { derivedLeafTypes } from './derived-leaves.js'; import { createEvents } from '../../lib/mina/events.js'; import { Poseidon, HashHelpers, packToFields, emptyHashWithPrefix, } from '../../lib/provable/crypto/poseidon.js'; import { provable } from '../../lib/provable/types/provable-derivers.js'; import { mocks, protocolVersions } from '../crypto/constants.js'; export { PublicKey, Field, Bool, AuthRequired, UInt64, UInt32, Sign, TokenId }; export { Events, Actions, ZkappUri, TokenSymbol, ActionState, VerificationKeyHash, ReceiptChainHash, StateHash, TransactionVersion, }; type AuthRequired = { constant: Bool; signatureNecessary: Bool; signatureSufficient: Bool; }; type TokenId = Field; type StateHash = Field; type TokenSymbol = { symbol: string; field: Field }; type ZkappUri = { data: string; hash: Field }; const { TokenId, StateHash, TokenSymbol, AuthRequired, ZkappUri } = derivedLeafTypes({ Field, Bool, HashHelpers, packToFields }); type Event = Field[]; type Events = { hash: Field; data: Event[]; }; type Actions = Events; const { Events, Actions } = createEvents({ Field, Poseidon }); type ActionState = Field; const ActionState = { ...provable(Field), empty: Actions.emptyActionState, }; type VerificationKeyHash = Field; const VerificationKeyHash = { ...provable(Field), empty: () => Field(mocks.dummyVerificationKeyHash), }; type ReceiptChainHash = Field; const ReceiptChainHash = { ...provable(Field), empty: () => emptyHashWithPrefix('CodaReceiptEmpty'), }; type TransactionVersion = Field; const TransactionVersion = { ...provable(UInt32), empty: () => UInt32.from(protocolVersions.txnVersion), };