UNPKG

o1js

Version:

TypeScript framework for zk-SNARKs and zkApps

582 lines (569 loc) 13.8 kB
// @generated this file is auto-generated - don't edit it directly import { PublicKey, UInt64, UInt32, TokenId, Field, Bool, AuthRequired, Sign, TransactionVersion, ZkappUri, TokenSymbol, StateHash, Events, Actions, ActionState, VerificationKeyHash, ReceiptChainHash, } from '../transaction-leaves-bigint.js'; import { GenericSignable } from '../../lib/generic.js'; import { SignableFromLayout, GenericLayout } from '../../lib/from-layout.js'; import * as Json from './transaction-json.js'; import { jsLayout } from './js-layout.js'; export { customTypes, ZkappCommand, AccountUpdate, Account }; export { Json }; export * from '../transaction-leaves-bigint.js'; export { signableFromLayout, toJSONEssential, empty, Layout, TypeMap }; type TypeMap = { PublicKey: PublicKey; UInt64: UInt64; UInt32: UInt32; TokenId: TokenId; Field: Field; Bool: Bool; AuthRequired: AuthRequired; Sign: Sign; }; const TypeMap: { [K in keyof TypeMap]: Signable<TypeMap[K], Json.TypeMap[K]>; } = { PublicKey, UInt64, UInt32, TokenId, Field, Bool, AuthRequired, Sign, }; type Signable<T, TJson> = GenericSignable<T, TJson, Field>; type Layout = GenericLayout<TypeMap>; type CustomTypes = { TransactionVersion: Signable<UInt32, Json.TypeMap['UInt32']>; ZkappUri: Signable< { data: string; hash: Field; }, string >; TokenSymbol: Signable< { symbol: string; field: Field; }, string >; StateHash: Signable<Field, Json.TypeMap['Field']>; Events: Signable< { data: Field[][]; hash: Field; }, Json.TypeMap['Field'][][] >; Actions: Signable< { data: Field[][]; hash: Field; }, Json.TypeMap['Field'][][] >; ActionState: Signable<Field, Json.TypeMap['Field']>; VerificationKeyHash: Signable<Field, Json.TypeMap['Field']>; ReceiptChainHash: Signable<Field, Json.TypeMap['Field']>; }; let customTypes: CustomTypes = { TransactionVersion, ZkappUri, TokenSymbol, StateHash, Events, Actions, ActionState, VerificationKeyHash, ReceiptChainHash, }; let { signableFromLayout, toJSONEssential, empty } = SignableFromLayout< TypeMap, Json.TypeMap >(TypeMap, customTypes); type ZkappCommand = { feePayer: { body: { publicKey: PublicKey; fee: UInt64; validUntil?: UInt32; nonce: UInt32; }; authorization: string; }; accountUpdates: { body: { publicKey: PublicKey; tokenId: TokenId; update: { appState: { isSome: Bool; value: Field }[]; delegate: { isSome: Bool; value: PublicKey }; verificationKey: { isSome: Bool; value: { data: string; hash: Field; }; }; permissions: { isSome: Bool; value: { editState: AuthRequired; access: AuthRequired; send: AuthRequired; receive: AuthRequired; setDelegate: AuthRequired; setPermissions: AuthRequired; setVerificationKey: { auth: AuthRequired; txnVersion: UInt32; }; setZkappUri: AuthRequired; editActionState: AuthRequired; setTokenSymbol: AuthRequired; incrementNonce: AuthRequired; setVotingFor: AuthRequired; setTiming: AuthRequired; }; }; zkappUri: { isSome: Bool; value: { data: string; hash: Field; }; }; tokenSymbol: { isSome: Bool; value: { symbol: string; field: Field; }; }; timing: { isSome: Bool; value: { initialMinimumBalance: UInt64; cliffTime: UInt32; cliffAmount: UInt64; vestingPeriod: UInt32; vestingIncrement: UInt64; }; }; votingFor: { isSome: Bool; value: Field }; }; balanceChange: { magnitude: UInt64; sgn: Sign; }; incrementNonce: Bool; events: { data: Field[][]; hash: Field; }; actions: { data: Field[][]; hash: Field; }; callData: Field; callDepth: number; preconditions: { network: { snarkedLedgerHash: { isSome: Bool; value: Field }; blockchainLength: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; minWindowDensity: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; totalCurrency: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; globalSlotSinceGenesis: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; stakingEpochData: { ledger: { hash: { isSome: Bool; value: Field }; totalCurrency: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; }; seed: { isSome: Bool; value: Field }; startCheckpoint: { isSome: Bool; value: Field }; lockCheckpoint: { isSome: Bool; value: Field }; epochLength: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; }; nextEpochData: { ledger: { hash: { isSome: Bool; value: Field }; totalCurrency: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; }; seed: { isSome: Bool; value: Field }; startCheckpoint: { isSome: Bool; value: Field }; lockCheckpoint: { isSome: Bool; value: Field }; epochLength: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; }; }; account: { balance: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; nonce: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; receiptChainHash: { isSome: Bool; value: Field }; delegate: { isSome: Bool; value: PublicKey }; state: { isSome: Bool; value: Field }[]; actionState: { isSome: Bool; value: Field }; provedState: { isSome: Bool; value: Bool }; isNew: { isSome: Bool; value: Bool }; }; validWhile: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; }; useFullCommitment: Bool; implicitAccountCreationFee: Bool; mayUseToken: { parentsOwnToken: Bool; inheritFromParent: Bool; }; authorizationKind: { isSigned: Bool; isProved: Bool; verificationKeyHash: Field; }; }; authorization: { proof?: string; signature?: string; }; }[]; memo: string; }; let ZkappCommand = signableFromLayout<ZkappCommand, Json.ZkappCommand>( jsLayout.ZkappCommand as any ); type AccountUpdate = { body: { publicKey: PublicKey; tokenId: TokenId; update: { appState: { isSome: Bool; value: Field }[]; delegate: { isSome: Bool; value: PublicKey }; verificationKey: { isSome: Bool; value: { data: string; hash: Field; }; }; permissions: { isSome: Bool; value: { editState: AuthRequired; access: AuthRequired; send: AuthRequired; receive: AuthRequired; setDelegate: AuthRequired; setPermissions: AuthRequired; setVerificationKey: { auth: AuthRequired; txnVersion: UInt32; }; setZkappUri: AuthRequired; editActionState: AuthRequired; setTokenSymbol: AuthRequired; incrementNonce: AuthRequired; setVotingFor: AuthRequired; setTiming: AuthRequired; }; }; zkappUri: { isSome: Bool; value: { data: string; hash: Field; }; }; tokenSymbol: { isSome: Bool; value: { symbol: string; field: Field; }; }; timing: { isSome: Bool; value: { initialMinimumBalance: UInt64; cliffTime: UInt32; cliffAmount: UInt64; vestingPeriod: UInt32; vestingIncrement: UInt64; }; }; votingFor: { isSome: Bool; value: Field }; }; balanceChange: { magnitude: UInt64; sgn: Sign; }; incrementNonce: Bool; events: { data: Field[][]; hash: Field; }; actions: { data: Field[][]; hash: Field; }; callData: Field; callDepth: number; preconditions: { network: { snarkedLedgerHash: { isSome: Bool; value: Field }; blockchainLength: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; minWindowDensity: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; totalCurrency: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; globalSlotSinceGenesis: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; stakingEpochData: { ledger: { hash: { isSome: Bool; value: Field }; totalCurrency: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; }; seed: { isSome: Bool; value: Field }; startCheckpoint: { isSome: Bool; value: Field }; lockCheckpoint: { isSome: Bool; value: Field }; epochLength: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; }; nextEpochData: { ledger: { hash: { isSome: Bool; value: Field }; totalCurrency: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; }; seed: { isSome: Bool; value: Field }; startCheckpoint: { isSome: Bool; value: Field }; lockCheckpoint: { isSome: Bool; value: Field }; epochLength: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; }; }; account: { balance: { isSome: Bool; value: { lower: UInt64; upper: UInt64; }; }; nonce: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; receiptChainHash: { isSome: Bool; value: Field }; delegate: { isSome: Bool; value: PublicKey }; state: { isSome: Bool; value: Field }[]; actionState: { isSome: Bool; value: Field }; provedState: { isSome: Bool; value: Bool }; isNew: { isSome: Bool; value: Bool }; }; validWhile: { isSome: Bool; value: { lower: UInt32; upper: UInt32; }; }; }; useFullCommitment: Bool; implicitAccountCreationFee: Bool; mayUseToken: { parentsOwnToken: Bool; inheritFromParent: Bool; }; authorizationKind: { isSigned: Bool; isProved: Bool; verificationKeyHash: Field; }; }; authorization: { proof?: string; signature?: string; }; }; let AccountUpdate = signableFromLayout<AccountUpdate, Json.AccountUpdate>( jsLayout.AccountUpdate as any ); type Account = { publicKey: PublicKey; tokenId: TokenId; tokenSymbol: string; balance: UInt64; nonce: UInt32; receiptChainHash: Field; delegate?: PublicKey; votingFor: Field; timing: { isTimed: Bool; initialMinimumBalance: UInt64; cliffTime: UInt32; cliffAmount: UInt64; vestingPeriod: UInt32; vestingIncrement: UInt64; }; permissions: { editState: AuthRequired; access: AuthRequired; send: AuthRequired; receive: AuthRequired; setDelegate: AuthRequired; setPermissions: AuthRequired; setVerificationKey: { auth: AuthRequired; txnVersion: UInt32; }; setZkappUri: AuthRequired; editActionState: AuthRequired; setTokenSymbol: AuthRequired; incrementNonce: AuthRequired; setVotingFor: AuthRequired; setTiming: AuthRequired; }; zkapp?: { appState: Field[]; verificationKey?: { data: string; hash: Field; }; zkappVersion: UInt32; actionState: Field[]; lastActionSlot: UInt32; provedState: Bool; zkappUri: string; }; }; let Account = signableFromLayout<Account, Json.Account>( jsLayout.Account as any );