Creating a transaction means assembling a transfer or contract call, submitting
it for policy checks, and collecting the required signatures. The SDK helps you propose
the transaction, tracks approvals, and executes once thresholds are met.This quickstart walks through getting accounts, selecting a policy, and
creating a transaction proposal using the SDK.
We firmly recommend using the SDK instead of calling the API directly. The SDK performs
local policy validation, which adds an additional layer of security to every account transaction.
Initialize the SDK client and the signer that will submit approvals. You’ll need an API key created by an admin in the Den dashboard, and your signer wallet must be added to the organization as a member to propose, sign, and execute transactions.See Setting up an API member for the full setup process.
import { DenClient } from "@onchainden/mls-sdk-ts";import { privateKeyToAccount } from "viem/accounts";const signer = privateKeyToAccount("0xYOUR_PRIVATE_KEY");const client = new DenClient({ apiKey: process.env.DEN_API_KEY!, baseUrl: process.env.DEN_API_BASE_URL!,});
The initial response includes a signatureData object with the initiator
signing payload. After the initiator signs, transaction responses use the same
signatureData object to expose the approve and reject payloads.
Once the approval threshold is met, the transaction is submitted on-chain. The
returned transaction’s executionStatus reflects its current state (for
example, "processing" while the on-chain submission is pending).
The privateKeyToAccount example in this guide is for local development. Here are some example patterns you can use in production See Signing keys to learn more.