@zeko-labs/bridge-sdk
v0.1.0
Published
Public TypeScript SDK for interacting with the Zeko bridge.
Downloads
271
Readme
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.
Operational Notes
- Archive action history is most reliable when queried in recent
10_000-block windows. Giant full-history scans starting from block0are a poor fit for manual diagnostics. - Withdrawal finalization depends on the L2 archive/indexer/actions-api path catching up to the live sequencer action. A live withdrawal may appear on the sequencer before it is witnessable through the archive-backed path.
- Sequencer proof requests currently live in memory for about 20 minutes. If a prove/finalize request sits longer than that, later polling may return
Invalid key. That case is currently terminal and not yet automatically recoverable. - Deposits obey two important protocol rules:
- a cancellable deposit can never later be finalized
- cancellable deposits are skippable, but finalizable deposits must never be skipped
- Deposit queue progression depends on protocol state:
lastFinalizedDepositon L2lastCancelledDepositon L1- only deposit indices strictly above those state values may be claimed
- The bridge-cli is expected to satisfy an unattended contract on top of this SDK: one command starts the bridge, the process may wait a long time, and the same operation should later be found completed without manual babysitting.
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
