> ## Documentation Index
> Fetch the complete documentation index at: https://docs.blnkfinance.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Create new transaction

> Post a transaction in your Blnk Ledger.

export const CtaCallout = props => {
  const {title, buttonLabel, href, trackingEvent, buttonTarget, rel = "noopener noreferrer", children} = props;
  const handleCtaClick = () => {
    if (typeof window === "undefined" || !trackingEvent) {
      return;
    }
    try {
      window.dispatchEvent(new CustomEvent("blnk:docs-cta", {
        detail: {
          name: trackingEvent,
          href
        }
      }));
    } catch {}
    try {
      window.posthog?.capture?.(trackingEvent, {
        href
      });
    } catch {}
    const gaPayload = {
      cta_href: href
    };
    try {
      window.gtag?.("event", trackingEvent, gaPayload);
    } catch {}
    try {
      window.dataLayer = window.dataLayer || [];
      window.dataLayer.push({
        event: trackingEvent,
        ...gaPayload
      });
    } catch {}
  };
  const isExternal = typeof href === "string" && (/^https?:\/\//i).test(href);
  const target = buttonTarget ?? (isExternal ? "_blank" : undefined);
  const linkRel = isExternal ? rel : undefined;
  return <section className="cta-callout not-prose relative my-8 w-full min-w-0 overflow-hidden rounded-xl border border-zinc-200 p-5 dark:border-white/10">
      <div className="cta-callout-noise" aria-hidden="true" />
      <div className="cta-callout-layout">
        {title ? <div className="cta-callout-title-row">
            <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 28 28" width="14" height="14" className="cta-callout-icon shrink-0 text-zinc-800 dark:text-zinc-200" aria-hidden="true">
              <g fill="none" fillRule="nonzero">
                <path d="M28 0v28H0V0h28ZM14.691833333333335 27.134333333333334l-0.012833333333333334 0.0023333333333333335 -0.08283333333333333 0.04083333333333334 -0.023333333333333334 0.004666666666666667 -0.016333333333333335 -0.004666666666666667 -0.08283333333333333 -0.04083333333333334c-0.011666666666666667 -0.004666666666666667 -0.022166666666666668 -0.0011666666666666668 -0.028000000000000004 0.005833333333333334l-0.004666666666666667 0.011666666666666667 -0.019833333333333335 0.49933333333333335 0.005833333333333334 0.023333333333333334 0.011666666666666667 0.015166666666666667 0.12133333333333333 0.08633333333333333 0.0175 0.004666666666666667 0.014000000000000002 -0.004666666666666667 0.12133333333333333 -0.08633333333333333 0.014000000000000002 -0.018666666666666668 0.004666666666666667 -0.019833333333333335 -0.019833333333333335 -0.4981666666666667c-0.0023333333333333335 -0.011666666666666667 -0.0105 -0.019833333333333335 -0.019833333333333335 -0.021Zm0.3091666666666667 -0.13183333333333336 -0.015166666666666667 0.0023333333333333335 -0.21583333333333335 0.1085 -0.011666666666666667 0.011666666666666667 -0.0035000000000000005 0.012833333333333334 0.021 0.5016666666666667 0.005833333333333334 0.014000000000000002 0.009333333333333334 0.008166666666666668 0.23450000000000004 0.1085c0.014000000000000002 0.004666666666666667 0.026833333333333334 0 0.03383333333333334 -0.009333333333333334l0.004666666666666667 -0.016333333333333335 -0.03966666666666667 -0.7163333333333334c-0.0035000000000000005 -0.014000000000000002 -0.011666666666666667 -0.023333333333333334 -0.023333333333333334 -0.025666666666666667Zm-0.8341666666666667 0.0023333333333333335a0.026833333333333334 0.026833333333334334 0 0 0 -0.0315 0.007000000000000001l-0.007000000000000001 0.016333333333333335 -0.03966666666666667 0.7163333333333334c0 0.014000000000000002 0.008166666666666668 0.023333333333333334 0.019833333333333335 0.028000000000000004l0.0175 -0.0023333333333333335 0.23450000000000004 -0.1085 0.011666666666666667 -0.009333333333333334 0.004666666666666667 -0.012833333333333334 0.019833333333333335 -0.5016666666666667 -0.0035000000000000005 -0.014000000000000002 -0.011666666666666667 -0.011666666666666667 -0.21466666666666667 -0.10733333333333334Z" strokeWidth="1.1667" />
                <path fill="currentColor" d="M14 2.916666666666667A1.75 1.75 0 0 1 15.750000000000002 4.666666666666667v6.302333333333334L21.207666666666668 7.816666666666667a1.75 1.75 0 0 1 1.75 3.031L17.5 14l5.457666666666667 3.151166666666667a1.75 1.75 0 0 1 -1.75 3.031l-5.457666666666667 -3.1500000000000004V23.333333333333336a1.75 1.75 0 0 1 -3.5 0v-6.302333333333334L6.792333333333334 20.183333333333337a1.75 1.75 0 1 1 -1.75 -3.031L10.5 14 5.042333333333334 10.848833333333333a1.75 1.75 0 0 1 1.75 -3.031l5.457666666666667 3.1500000000000004V4.666666666666667A1.75 1.75 0 0 1 14 2.916666666666667Z" strokeWidth="1.1667" />
              </g>
            </svg>
            <p className="cta-callout-title min-w-0 font-semibold text-zinc-800 dark:text-zinc-200">
              {title}
            </p>
          </div> : null}
        <div className={`cta-callout-body text-sm leading-normal text-zinc-800 dark:text-zinc-200${title ? " cta-callout-body--indented" : ""}`}>
          {children}
        </div>
        <a href={href} target={target} rel={linkRel} onClick={handleCtaClick} data-docs-cta={trackingEvent || undefined} className="cta-callout-button inline-flex items-center justify-center gap-1 rounded-full bg-white px-3 py-1.5 text-sm font-semibold transition hover:bg-zinc-100 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-white/50 dark:bg-white dark:hover:bg-zinc-200">
          {buttonLabel}
          <span className="cta-callout-button-arrow" aria-hidden="true">
            →
          </span>
        </a>
      </div>
    </section>;
};

<Note>
  If you're using the auto-provisioned `Enterprise Core` instance included with your Production License deployment, set the base URL to: `https://ENTERPRISE_PUBLIC_URL/core`.

  If you're connecting to a different Core instance, use the publicly accessible base URL for that instance instead.
</Note>

### Authorization

If set, the API uses an API key for authentication. Include the following header in your requests: `X-blnk-key: <api-key>`.

Replace `<api-key>` with your secret API key. Ensure the key is kept secure and not exposed in public repositories or client-side code.

See also: [Scoped API keys](/api-keys/overview) and [Secure your Blnk server](/advanced/secure-blnk).

### Body

<ParamField body="precise_amount" type="integer">
  The transaction amount in its smallest unit (recommended). Include the corresponding `precision` value. See [Precision](/transactions/precision).

  <Warning>
    Either `precise_amount` or `amount` should be provided, not both.
  </Warning>
</ParamField>

<ParamField body="amount" type="float">
  The transaction amount as a float. Blnk multiplies `amount` by `precision` to store `precise_amount`. The `amount` field supports up to 15 digits; use `precise_amount` for larger values. See also: [Precision](/transactions/precision).
</ParamField>

<ParamField body="currency" type="string" required>
  The currency of the transaction amount is in.
</ParamField>

<ParamField body="precision" type="integer" default="1" required>
  Precision for the transaction's currency. See also: [Precision](/transactions/precision).
</ParamField>

<ParamField body="reference" type="string" required>
  The unique transaction reference number for the transaction.
</ParamField>

<ParamField body="source" type="string" required>
  The unique id of the balance sending the amount. `@` prefix indicates that the balance is an [internal balance](/balances/internal-balances).
</ParamField>

<ParamField body="destination" type="string" required>
  The unique id of the balance receiving the amount. `@` prefix indicates that the balance is an [internal balance](/balances/internal-balances).
</ParamField>

<ParamField body="description" type="string" required>
  Narration of the transaction.
</ParamField>

<ParamField body="scheduled_for" type="string">
  Indicates the date and time of a scheduled transaction.

  Always format the date input as 'YYYY-MM-DDTHH:MM:SS+00:00' (e.g., 2024-04-22T15:28:03+00:00), where `+00:00` specifies the timezone. It is UTC by default.
</ParamField>

<ParamField body="allow_overdraft" type="boolean" default="false">
  Specifies whether the transaction should proceed even if the source’s balance is insufficient. If enabled and the source has less than the required amount, the balance will become negative. See also: [Overdrafts](/transactions/overdrafts)
</ParamField>

<ParamField body="inflight" type="boolean" default="false">
  Specifies that the transaction should be held until certain conditions are met. See also: [Create inflight](/transactions/inflight/creating-inflight).
</ParamField>

<ParamField body="inflight_expiry_date" type="string">
  Specifies the date and time when an inflight transaction should expire. Once expired, the transaction is voided and the amount is rolled back.

  Always format the date input as 'YYYY-MM-DDTHH:MM:SS+00:00' (e.g., 2024-04-22T15:28:03+00:00), where `+00:00` specifies the timezone. It is UTC by default.
</ParamField>

<ParamField body="inflight_commit_date" type="string">
  When **`inflight`** is true, the date and time when Blnk should **automatically commit** the inflight transaction (same ledger outcome as [Update Inflight](/reference/update-inflight) with **`commit`**). See [Schedule inflight commits](/transactions/inflight/updating-inflight#schedule-inflight-commits).

  Always format the date input as 'YYYY-MM-DDTHH:MM:SS+00:00' (e.g., 2024-04-22T15:28:03+00:00), where `+00:00` specifies the timezone. It is UTC by default.
</ParamField>

<ParamField body="effective_date" type="string">
  Specifies the actual date the transaction occurred. Learn more: [Backdated transactions](/transactions/backdated-transactions).
</ParamField>

<ParamField body="skip_queue" type="boolean">
  When `true`, it bypasses the default transaction queuing system and processes transactions directly. See also: [Skip transaction queue](/transactions/introduction#skip-transaction-queue).
</ParamField>

<ParamField body="atomic" type="boolean" default="false">
  Controls how Blnk processes split transactions when you use `sources` or `destinations`. When `false` (default), Blnk applies each leg that can succeed and rejects legs that fail. When `true`, every leg succeeds together or the entire split fails with no partial application. See [Multiple sources](/transactions/multiple-sources#atomic-split-processing) and [Multiple destinations](/transactions/multiple-destinations#atomic-split-processing).
</ParamField>

<ParamField body="meta_data" type="object">
  Additional metadata of the transaction.

  <Expandable title="Lineage metadata (optional)">
    If the **destination** balance has `track_fund_lineage: true`, you can tag incoming funds by setting a provider in metadata. Learn more: [Fund lineage](/transactions/lineage).

    <ParamField body="BLNK_LINEAGE_PROVIDER" type="string">
      Provider tag used to classify incoming funds (for example: `"stripe"`, `"paypal"`, `"treasury"`).
    </ParamField>
  </Expandable>
</ParamField>

### Response

<Info>All parameters from the request body also mean the same in the corresponding response JSON.</Info>

<ResponseField name="precise_amount" type="integer">
  The amount stored in the ledger in its smallest unit. When you pass `amount`, Blnk computes this as `amount` x `precision`. See [Precision](/transactions/precision).
</ResponseField>

<ResponseField name="transaction_id" type="string">
  Unique id of the transaction.
</ResponseField>

<ResponseField name="parent_transaction" type="string">
  The transaction ID of the parent transaction. A parent transaction is one that impacts the creation of a new transaction, such as an inflight transaction, a scheduled transaction, or similar.

  For instance, refunding a sample transaction A creates a new transaction B; therefore A is the parent transaction of B.
</ResponseField>

<ResponseField name="status" type="string">
  The status of the transaction. See the following: [Transaction statuses](/transactions/transaction-lifecycle#statuses).
</ResponseField>

<ResponseField name="hash" type="string">
  Per-row SHA-256 fingerprint of the transaction's core details. The optional global hash chain is separate and not returned in API responses. Learn more: [Transaction hashing](/transactions/hash)
</ResponseField>

<ResponseField name="created_at" type="string">
  Indicates the date & time the transaction was created.
</ResponseField>

<ResponseField name="meta_data" type="User Object">
  Additional metadata of the transaction.
</ResponseField>

<RequestExample>
  ```bash theme={"system"}
  curl -X POST "http://localhost:5001/transactions" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "precise_amount": 125034,
      "currency": "USD",
      "precision": 100,
      "reference": "ref_2ye281ewiu-1e17-dh17-eh18728hd245",
      "source": "@WorldUSD",
      "destination": "@MyBalance",
      "description": "Fund with starting balance amount",
      "meta_data": {}
    }'
  ```
</RequestExample>

<ResponseExample>
  ```json 201 theme={"system"}
  {
      "amount": 1250.34,
      "precision": 100,
      "precise_amount": 125034,
      "transaction_id": "txn_c4e70eb8-e4d6-4e04-a2e2-92a43b969e0c",
      "parent_transaction": "",
      "source": "bln_f344b673-e855-4bda-b769-3e94a02c1941",
      "destination": "bln_d5cbde84-d20a-485b-8ce8-6677d782c3a1",
      "reference": "ref_2ye281ewiu-1e17-dh17-eh18728hd245",
      "currency": "USD",
      "description": "Card payment on Stripe",
      "status": "QUEUED",
      "hash": "0b9c25fb5b00d6c71cb4ca87026bf6dc316e63353d3330deb588bd0b3d74dcc0",
      "allow_overdraft": false,
      "inflight": false,
      "created_at": "2024-11-26T09:33:35.265582042Z",
      "scheduled_for": "0001-01-01T00:00:00Z",
      "inflight_expiry_date": "0001-01-01T00:00:00Z",
      "inflight_commit_date": "0001-01-01T00:00:00Z"
  }
  ```

  ```json 400 theme={"system"}
  {
    "errors": "amount: either amount or precise_amount is required.",
    "error_detail": {
      "code": "TXN_VALIDATION_ERROR",
      "message": "amount: either amount or precise_amount is required."
    }
  }
  ```

  ```json 400 theme={"system"}
  {
    "error": "failed to apply transaction to balances: insufficient funds in source balance",
    "error_detail": {
      "code": "TXN_INSUFFICIENT_FUNDS",
      "message": "failed to apply transaction to balances: insufficient funds in source balance"
    }
  }
  ```

  ```json 404 theme={"system"}
  {
    "error": "Balance with ID 'bln_00000000-0000-0000-0000-000000000000' not found",
    "error_detail": {
      "code": "TXN_NOT_FOUND",
      "message": "Balance with ID 'bln_00000000-0000-0000-0000-000000000000' not found",
      "details": {}
    }
  }
  ```

  ```json 409 theme={"system"}
  {
    "error": "transaction validation failed: reference errcompat-dup-4075 has already been used",
    "error_detail": {
      "code": "TXN_DUPLICATE_REFERENCE",
      "message": "transaction validation failed: reference errcompat-dup-4075 has already been used"
    }
  }
  ```
</ResponseExample>

## Need help?

We are very happy to help you make the most of Blnk, regardless of whether it is your first time or you are switching from another tool.

To ask questions or discuss issues, please [contact us](mailto:support@blnkfinance.com) or [join our Discord community](https://discord.gg/7WNv94zPpx).

<CtaCallout title="Connect your ledger to Blnk Cloud" href="https://cloud.blnkfinance.com/auth/sign-up?utm_source=blnk_docs&utm_medium=documentation&utm_campaign=need-help" buttonLabel="Open Blnk Cloud" trackingEvent="clicked_cloud_signup">
  Sign up and manage your ledger with our back-office dashboard. You can invite teammates to collaborate and manage your ledger operations directly from the dashboard.
</CtaCallout>
