Unirep procotol package
Client library for protocol related functions which are used in unirep protocol.
🛠 Install
npm or yarn
Install the @unirep/core
package with npm:
npm i @unirep/core
or yarn:
yarn add @unirep/core
📔 Usage
⏲
Synchronizer Construct a synchronizer
import { Synchronizer, schema } from '@unirep/core'
import { getUnirepContract, Unirep } from '@unirep/contracts'
import { DB, SQLiteConnector } from 'anondb/node'
// connect a unirep contract with the address and a provider
const unirepContract: Unirep = getUnirepContract(address, provider)
// initialize a database
const db: DB = await SQLiteConnector.create(schema, ':memory:')
// 1. initialize a synchronizer
const synchronizer = new Synchronizer(db, provider, unirepContract)
// 2. start listening to unriep contract events
await synchronizer.start()
// 3. wait until the latest block is processed
await synchronizer.waitForSync()
Example: use the synchronizer to generate unirep state
const epoch = 1
const stateTree = await synchronizer.genStateTree(epoch)
👤
UserState Construct a user state
import { ZkIdentity } from '@unirep/utils'
import { Synchronizer, schema } from '@unirep/core'
import { getUnirepContract, Unirep } from '@unirep/contracts'
import { DB, SQLiteConnector } from 'anondb/node'
// random generate a user identity
const identity = new Identity()
// connect a unirep contract with the address and a provider
const unirepContract: Unirep = getUnirepContract(address, provider)
// initialize a database
const db: DB = await SQLiteConnector.create(schema, ':memory:')
// 1. initialize a user state object
const userState = new UserState(
db,
provider,
unirepContract,
identity
)
// 2. start listening to unriep contract events
await userState.start()
// 3. wait until the latest block is processed
await userState.waitForSync()
Example: use the user state to generate proofs
const nonce = 1
const epochKeyProof = await userState.genVerifyEpochKeyProof(nonce)
// 1. submit the epoch key proof to smart contract
const tx = await unirepContract.submitEpochKeyProof(
epochKeyProof.publicSignals,
epochKeyProof.proof
)
// 2. get the index of the epoch key proof
const proofHash = epochKeyProof.hash()
const index = await unirepContract.getProofIndex(proofHash)
// Then the attester can call `submitAttestation` on Unirep contract
// to send attestation to the epoch key with a proof index
🧳
Utils Example: Compute an epoch key
import { ZkIdentity, genEpochKey } from '@unirep/utils'
import { genEpochKey } from '@unirep/core'
const identity = new Identity()
const epoch = 1
const nonce = 0
const epochTreeDepth = 64
const epk = genEpochKey(
identity.secret,
epoch,
nonce,
epochTreeDepth
)