@hazbase/simplicity is a Node.js / TypeScript SDK for building and validating Simplicity-based flows on Liquid.
Today, the SDK is best understood as a permissioned settlement / lineage / finality toolkit. It helps developers compile and fund Simplicity contracts, execute constrained payouts, verify off-chain definitions and state documents, and export evidence or finality payloads for higher-level review.
It is intentionally narrower than a full market stack. It does not try to be a full investor registry, KYC/AML system, fund-admin platform, market-ops layer, or open retail trading protocol.
This SDK is designed to help Node developers get productive quickly, but it is still opinionated, early-stage, and best suited today to permissioned settlement pilots on Liquid.
With the current public SDK you can build and test:
- constrained transfers with explicit next-hop rules
- output binding with public support/fallback reporting
- bond redemption / settlement / close-out flows
- LP fund capital call / distribution / close-out flows
- receivable repayment-first funding / partial repayment / closing flows
- evidence, trust summary, lineage, and finality exports
The public SDK is organized into five layers:
sdk.outputBinding: shared output-binding support, evaluation, and fallback behaviorsdk.policies: generic constrained transfer and recursive policy enginesdk.bonds: private bond / credit settlement business layersdk.funds: LP fund settlement business layersdk.receivables: repayment-first receivable business layer
A useful mental model is:
sdk.outputBinding+sdk.policiesprovide the shared settlement kernelsdk.bonds,sdk.funds, andsdk.receivablesbuild domain flows on top of that kernel
Install the package:
npm install @hazbase/simplicityCreate a client:
import { createSimplicityClient } from "@hazbase/simplicity";
const sdk = createSimplicityClient({
network: "liquidtestnet",
rpc: {
url: process.env.ELEMENTS_RPC_URL ?? "http://127.0.0.1:18884",
username: process.env.ELEMENTS_RPC_USER ?? "<rpc-user>",
password: process.env.ELEMENTS_RPC_PASSWORD ?? "<rpc-password>",
wallet: process.env.ELEMENTS_RPC_WALLET ?? "simplicity-test",
},
toolchain: {
simcPath: process.env.SIMC_PATH ?? "simc",
halSimplicityPath: process.env.HAL_SIMPLICITY_PATH ?? "hal-simplicity",
elementsCliPath: process.env.ELEMENTS_CLI_PATH ?? "eltc",
},
});
console.log(sdk.policies.listTemplates());
console.log(sdk.outputBinding.describeSupport());Quick CLI checks:
npx simplicity-cli presets list
npx simplicity-cli binding describe-support
npx simplicity-cli --helpFor richer walkthroughs and sample JSON / .simf files, use docs/definitions/README.md.
Use sdk.policies when you want constrained transfers, recursive next-hop rules, or restricted OTC-style settlement kernels.
Main entrypoints:
sdk.policies.listTemplates(...)sdk.policies.describeTemplate(...)sdk.policies.issue(...)sdk.policies.prepareTransfer(...)sdk.policies.inspectTransfer(...)sdk.policies.executeTransfer(...)sdk.policies.verifyTransfer(...)sdk.policies.exportEvidence(...)
Representative example:
Use sdk.bonds for permissioned private bond or private credit flows where definition, issuance, settlement, closing, and lineage all matter.
Main entrypoints:
sdk.bonds.define(...)sdk.bonds.verify(...)sdk.bonds.verifyIssuanceHistory(...)sdk.bonds.prepareRedemption(...)sdk.bonds.buildSettlement(...)sdk.bonds.prepareClosing(...)sdk.bonds.verifyClosing(...)sdk.bonds.exportFinalityPayload(...)
Representative example:
Use sdk.funds for LP fund settlement flows such as capital calls, rollover into refund-only, distributions, receipt reconciliation, and close-out.
Main entrypoints:
sdk.funds.define(...)sdk.funds.prepareCapitalCall(...)sdk.funds.executeCapitalCallClaim(...)sdk.funds.executeCapitalCallRollover(...)sdk.funds.executeCapitalCallRefund(...)sdk.funds.prepareDistribution(...)sdk.funds.verifyPositionReceiptChain(...)sdk.funds.exportFinalityPayload(...)
Representative example:
Operational note:
Use sdk.receivables for repayment-first receivable or invoice-style pilots where you want canonical state transitions, role-aware runtime claim descriptors, partial repayment handling, lineage verification, and terminal closing.
By default, funding claims resolve against the originator claimant key and repayment claims resolve against the current holder claimant key, while controllerXonly remains the fallback for simpler pilots.
Main entrypoints:
sdk.receivables.define(...)sdk.receivables.prepareFunding(...)sdk.receivables.prepareFundingClaim(...)sdk.receivables.prepareRepayment(...)sdk.receivables.prepareRepaymentClaim(...)sdk.receivables.prepareClosing(...)sdk.receivables.verifyStateHistory(...)sdk.receivables.exportFinalityPayload(...)
Representative example:
The public package is exercised through:
- unit / integration tests
- packaged consumer smoke runs
- public local / testnet e2e commands
Core confidence commands:
npm test
npm run e2e:policy-consumer
npm run e2e:bond-consumer
npm run e2e:fund-consumer
npm run e2e:receivable-consumerPublic runtime confidence commands:
npm run e2e:policy-local
npm run e2e:policy-restricted-otc-local
npm run e2e:policy-restricted-otc-testnet
POLICY_OUTPUT_BINDING_MODE=script-bound npm run e2e:policy-testnet
POLICY_OUTPUT_BINDING_MODE=descriptor-bound npm run e2e:policy-testnet
BOND_OUTPUT_BINDING_MODE=script-bound npm run e2e:bond-testnet
BOND_OUTPUT_BINDING_MODE=descriptor-bound npm run e2e:bond-testnet
npm run e2e:fund-local
FUND_OUTPUT_BINDING_MODE=script-bound npm run e2e:fund-testnet
FUND_OUTPUT_BINDING_MODE=descriptor-bound npm run e2e:fund-testnet
FUND_FLOW_MODE=refund FUND_OUTPUT_BINDING_MODE=script-bound npm run e2e:fund-testnet
npm run e2e:receivable-local
RECEIVABLE_OUTPUT_BINDING_MODE=script-bound npm run e2e:receivable-testnet
RECEIVABLE_OUTPUT_BINDING_MODE=descriptor-bound npm run e2e:receivable-testnetThese commands are useful both as reproducible checks and as examples of the SDK's current validated surface.
If you want to go deeper, use these entrypoints:
docs/definitions/README.mdfor the public domain deep-dive and sample JSON /.simfassetsexamples/for runnable code samples across policy, bond, fund, and receivable flowsnpx simplicity-cli --helpfor the full CLI surface
A good next path is:
- read the architecture and flow notes in
docs/definitions/README.md - run one representative example from
examples/ - run one consumer smoke or local/testnet e2e command that matches your target domain
In the Simplicity-on-Liquid model, “deploy” means compile a contract, derive its contract address, and fund that address with a UTXO. There is no separate EVM-style bytecode deployment transaction.
An artifact is the SDK's durable compile output plus the metadata needed to reload, inspect, verify, and execute a contract later. It is the bridge between contract definition time and spend time.
For practical usage you typically need:
- Node.js 20+
- the npm package itself
- a local Simplicity toolchain (
simc,hal-simplicity, and usuallyeltc) - a reachable Elements / Liquid RPC endpoint
Some commands are SDK-only and work without live spends. Local and testnet e2e flows need the toolchain and, for broadcasted flows, an RPC environment.
The dedicated restricted OTC testnet runner clean-skips when RPC credentials are missing so it can stay in public CI and local verification scripts without turning missing env into a hard failure.