> ## 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.

# Multiple Sources

> Move money to one balance from two or more balances.

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

<Info>**Important tip:** To apply multiple sources, Blnk uses the `sources` array instead of the conventional `source` parameter in [Record transaction](/reference/create-transaction).</Info>

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

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

<ParamField body="amount" type="integer | float">
  The transaction amount as a float. Blnk multiplies `amount` by `precision` to store `precise_amount`.
</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. Also see: [Precision](/transactions/precision).
</ParamField>

<ParamField body="reference" type="string" required>
  The unique transaction reference number for the transaction. If empty, Blnk auto-creates one.
</ParamField>

<ParamField body="sources" type="array" required>
  Lists the sources for the transaction. Each source includes:

  <Expandable>
    <ParamField body="identifier" type="string" required>
      The transaction id of the source.
    </ParamField>

    <ParamField body="distribution" type="string" required>
      Specifies how much should be deducted from the source. It can either be:

      * a fixed amount (`"240.23"`),
      * a percentage (`"20%"`) or
      * the remaining amount (`"left"`).
    </ParamField>

    <ParamField body="precise_distribution" type="string">
      When a transaction uses `precise_amount`, use `precise_distribution` in place of `distribution` only for sources that specify an exact value.  (e.g., `"37841507139655800"`).

      <Note>Accepts only integers values in the string</Note>
    </ParamField>
  </Expandable>
</ParamField>

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

<ParamField body="scheduled_for" type="string">
  Indicates the date and time of a scheduled transaction, e.g., `"2024-02-20 05:28:03"`.
</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.
</ParamField>

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

<ParamField body="atomic" type="boolean" default="false">
  When false, Blnk processes each destination independently.

  Valid destinations are `APPLIED`, while invalid ones are `REJECTED`. When true, all destinations must succeed for the split to be processed. If any destination fails, no credits are `APPLIED`, and succesful inflights are set to `VOID`.

  See [Atomic split processing](/transactions/multiple-sources#atomic-split-processing).
</ParamField>

<ParamField body="meta_data" type="object">
  Additional metadata of the transaction.
</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. 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>
  ```json theme={"system"}
  curl -X POST "http://localhost:5001/transactions" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "precise_amount": 1905034,
      "currency": "USD",
      "precision": 100,
      "reference": "ref_2ye281ewiu-1e17-dh17-eh18728hd245",
      "sources": [
        {
          "identifier": "bln_f2073f6b-905a-4e3e-b5a2-8d1b3dc2fb7f",
          "distribution": "10%"
        },
        {
          "identifier": "bln_64c50fb5-32d5-4f78-9f4a-e8b01aaf025d",
          "precise_distribution": "500000"
        },
        {
          "identifier": "bln_7d98dfe9-5c3e-4c9b-b96a-65f6d9f7b89b",
          "distribution": "left"
        }
      ],
      "destination": "@WorldUSD",
      "meta_data": {}
    }'
  ```
</RequestExample>

<ResponseExample>
  ```json 201 theme={"system"}
  {
      "amount": 19050.34,
      "precision": 100,
      "precise_amount": 1905034,
      "transaction_id": "txn_c4e70eb8-e4d6-4e04-a2e2-92a43b969e0c",
      "parent_transaction": "",
      "sources": [
        {
          "identifier": "bln_f2073f6b-905a-4e3e-b5a2-8d1b3dc2fb7f",
          "distribution": "10%"
        },
        {
          "identifier": "bln_64c50fb5-32d5-4f78-9f4a-e8b01aaf025d",
          "distribution": "5000"
        },
        {
          "identifier": "bln_7d98dfe9-5c3e-4c9b-b96a-65f6d9f7b89b",
          "distribution": "left"
        }
      ],
      "destination": "@WorldUSD",
      "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 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": {}
    }
  }
  ```
</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>
