Zeko Bridge SDK
This package is developed in the private zeko-ui monorepo and mirrored here for public releases. The docs site reuses this README so package docs and website docs stay aligned.
TypeScript SDK for interacting with the Zeko bridge and coordinating deposits and withdrawals between Mina (L1) and Zeko (L2).
Installation
Install with npm:
npm install @zeko-labs/bridge-sdkOr with pnpm:
pnpm add @zeko-labs/bridge-sdkQuick Start
Initialize a bridge client with the network GraphQL endpoints you want to target.
import { Bridge } from "@zeko-labs/bridge-sdk"
const bridge = await Bridge.init({
l1Url: "https://gateway.mina.devnet.zeko.io",
l1ArchiveUrl: "https://gateway.mina.archive.devnet.zeko.io",
zekoUrl: "https://testnet.zeko.io/graphql",
zekoArchiveUrl: "https://archive.testnet.zeko.io/graphql",
actionsApi: "https://api.actions.zeko.io/graphql",
l1Network: "testnet",
l2Network: "testnet"
})The endpoints above are testnet examples. Use the matching mainnet endpoints for production traffic.
Usage
Submit a Deposit
import { PrivateKey, UInt32, UInt64 } from "o1js"
const signer = PrivateKey.fromBase58(process.env.MINA_PRIVATE_KEY!)
const recipient = signer.toPublicKey()
const transaction = await bridge.submitDeposit(
{ sender: recipient, fee: 0.1 * 10e8 },
{
recipient,
amount: UInt64.from(10 * 10e8),
timeout: UInt32.MAXINT(),
holderAccountL1: bridge.outerHolders[0]
}
)
await transaction.sign([signer]).send()Submit a Withdrawal
const transaction = await bridge.submitWithdrawal(
{ sender: recipient, fee: 0.1 * 10e8 },
{
recipient,
amount: UInt64.from(5 * 10e8)
}
)
await transaction.sign([signer]).send()Finalize Operations
await bridge.finalizeDeposit(recipient)
await bridge.finalizeWithdrawal(
recipient,
{ sender: recipient, fee: 0.1 * 10e8 },
bridge.outerHolders[0]
)Finalization time depends on the size of the witness data the bridge must prove. Longer gaps between submission and finalization generally mean more proof work and slower completion.
Development
These commands are maintainer workflows and only run from the private zeko-ui monorepo.
These commands are maintainer workflows and only run from the private zeko-ui monorepo.
These commands are maintainer workflows and only run from the private zeko-ui monorepo.
Run all commands from the monorepo root with Moon:
moon run bridge-sdk:build
moon run bridge-sdk:typecheckThis schema refresh command is not available in the standalone bridge-sdk mirror.
This schema refresh command is not available in the standalone bridge-sdk mirror.
This schema refresh command is not available in the standalone bridge-sdk mirror.
To refresh the generated GraphQL schema types used by the package:
moon run graphql:schema-getLocal Examples
The repository includes example scripts in packages/bridge-sdk/examples. From the monorepo root:
moon run bridge-sdk:submitDeposit
moon run bridge-sdk:finalizeDeposit
moon run bridge-sdk:submitWithdrawal
moon run bridge-sdk:finalizeWithdrawal
moon run bridge-sdk:fetchOuterActions
moon run bridge-sdk:fetchInnerActionsLicense
MIT