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

# Building a Lending Management System

> Learn how to manage & track loans and repayments with the 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>;
};

This tutorial provides a step-by-step guide to building a simple loan management system using Blnk Finance. You'll learn how to:

1. Disburse loans to customers.
2. Calculate and apply interest.
3. Process repayments.
4. Monitor loan status effectively.

For this tutorial, we'll use the [Blnk TypeScript SDK](/sdks/typescript) and [Blnk Go SDK](/sdks/go) for the implementation. If you prefer, you can also refer to the [API reference](/reference/create-ledger) for details on the available endpoints.

***

## Designing your map

Before writing code, it's crucial to design a [money movement map](/ledgers/money-movement-map) that outlines how money moves in your system. This serves as the blueprint for your implementation.

<img src="https://mintcdn.com/blnk/jKiGmb7nTD9y-R5a/images/tutorials/lending-map.png?fit=max&auto=format&n=jKiGmb7nTD9y-R5a&q=85&s=720b12416d15295c98d9f9597c5a8175" alt="Lending map" width="946" height="530" data-path="images/tutorials/lending-map.png" />

[Explore the map yourself here](https://map.blnkfinance.xyz/9I4HuNl54p)

This map shows three key aspects our lending fund flow:

* The `Customer Loan Wallet` tracks the amount owed by the customer. All loans disbursed to the customer are debited from their loan wallet. A zero balance indicates that all debt has been fully repaid.

* The `@InterestRevenue` records all interest earned from loan customers.

***

## Prerequisites

Before starting, ensure you have:

1. A running Blnk Core instance (e.g. at `http://localhost:5001`).
2. An API key for Blnk (replace `YOUR_API_KEY` in the code examples). Required for authenticated requests.
3. Optionally, you can connect your Blnk Core to your [Blnk Cloud](https://cloud.blnkfinance.com/?utm_source=blnk_docs\&utm_medium=documentation\&utm_campaign=tutorials%2Fdigital-banking%2Flending) workspace to view your ledger data.

To prepare for the rest of this tutorial, read our [Building a Wallet with Blnk](/tutorials/quick-start/wallet-management) tutorial if you haven't already.

***

## Create your ledgers

First, we create 2 ledgers.

* `Customer Accounts` to organize all customers' main accounts.
* `Loan Accounts` to organize all loan accounts.

<CodeGroup>
  ```bash cURL wrap expandable theme={"system"}
  # Create main wallet ledger (Customer Accounts)
  curl -X POST "http://localhost:5001/ledgers" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
    "name": "Customer Accounts",
    "meta_data": {
      "description": "Contains all customer main balances"
    }
  }'

  # Create loan wallet ledger (Loan Accounts)
  curl -X POST "http://localhost:5001/ledgers" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
    "name": "Loan Accounts",
    "meta_data": {
      "description": "Contains all customer loan balances"
    }
  }'
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function createCustomerLedger() {
    
    
    const customerLedger = await blnk.Ledgers.create({
      name: "Customer Accounts",
      meta_data: {
        description: "Contains all customer main balances"
      }
    });
    
    console.log("Customer Ledger created:", customerLedger.data);
    return customerLedger.data.ledger_id;
  }

  async function createLoanLedger() {
    
    
    const loanLedger = await blnk.Ledgers.create({
      name: "Loan Accounts",
      meta_data: {
        description: "Contains all customer loan balances"
      }
    });
    
    console.log("Loan Ledger created:", loanLedger.data);
    return loanLedger.data.ledger_id;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func createCustomerLedger() (string, error) {
      client := getClient()
      ledger, _, err := client.Ledger.Create(blnkgo.CreateLedgerRequest{
          Name: "Customer Accounts",
          MetaData: map[string]interface{}{
              "description": "Contains all customer main balances",
          },
      })
      if err != nil {
          return "", err
      }
      fmt.Println("Customer Ledger created:", ledger.LedgerID)
      return ledger.LedgerID, nil
  }

  func createLoanLedger() (string, error) {
      client := getClient()
      ledger, _, err := client.Ledger.Create(blnkgo.CreateLedgerRequest{
          Name: "Loan Accounts",
          MetaData: map[string]interface{}{
              "description": "Contains all customer loan balances",
          },
      })
      if err != nil {
          return "", err
      }
      fmt.Println("Loan Ledger created:", ledger.LedgerID)
      return ledger.LedgerID, nil
  }
  ```
</CodeGroup>

***

## Create customer balances

First, we create the customer's balance:

<CodeGroup>
  ```bash cURL wrap theme={"system"}
  curl -X POST "http://localhost:5001/balances" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "ledger_id": "ldg_CUSTOMER_LEDGER_ID",
      "currency": "USD",
      "meta_data": {
          "customer_id": "12345",
          "customer_name": "John Doe",
          "account_type": "main",
          "account_status": "active"
      }
    }'
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function createCustomerMainBalance(customerLedgerId, customerDetails) {
    
    
    const mainBalance = await blnk.LedgerBalances.create({
      ledger_id: customerLedgerId,
      currency: "USD",
      meta_data: {
        customer_id: customerDetails.id,
        customer_name: customerDetails.name,
        account_type: "main",
        account_status: "active"
      }
    });
    
    console.log("Customer Main Balance created:", mainBalance.data);
    return mainBalance.data.balance_id;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func createCustomerMainBalance(customerLedgerID string, customerDetails CustomerDetails) (string, error) {
      client := getClient()
      balance, _, err := client.LedgerBalance.Create(blnkgo.CreateLedgerBalanceRequest{
          LedgerID: customerLedgerID,
          Currency: "USD",
          MetaData: map[string]interface{}{
              "customer_id":    customerDetails.ID,
              "customer_name":  customerDetails.Name,
              "account_type":   "main",
              "account_status": "active",
          },
      })
      if err != nil {
          return "", err
      }
      fmt.Println("Customer Main Balance created:", balance.BalanceID)
      return balance.BalanceID, nil
  }
  ```
</CodeGroup>

Next, we create the loan balance:

<CodeGroup>
  ```bash cURL wrap theme={"system"}
  curl -X POST "http://localhost:5001/balances" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "ledger_id": "ldg_LOAN_LEDGER_ID",
      "currency": "USD",
      "meta_data": {
          "customer_id": "12345",
          "customer_name": "John Doe"
      }
    }'
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function createLoanBalance(loanLedgerId, customerDetails, loanDetails) {
    
    
    const loanBalance = await blnk.LedgerBalances.create({
      ledger_id: loanLedgerId,
      currency: "USD",
      meta_data: {
        customer_id: customerDetails.id,
        customer_name: customerDetails.name
      }
    });
    
    console.log("Loan Balance created:", loanBalance.data);
    return loanBalance.data.balance_id;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func createLoanBalance(loanLedgerID string, customerDetails CustomerDetails) (string, error) {
      client := getClient()
      balance, _, err := client.LedgerBalance.Create(blnkgo.CreateLedgerBalanceRequest{
          LedgerID: loanLedgerID,
          Currency: "USD",
          MetaData: map[string]interface{}{
              "customer_id":   customerDetails.ID,
              "customer_name": customerDetails.Name,
          },
      })
      if err != nil {
          return "", err
      }
      fmt.Println("Loan Balance created:", balance.BalanceID)
      return balance.BalanceID, nil
  }
  ```
</CodeGroup>

***

## Disbursing a loan

When the loan is disbursed, money is deducted from the `Loan Balance` to the `Main Balance`.

```txt Example scenario wrap theme={"system"}
* Starting Scenario
Alice Loan Balance: 0.00 USD
Alice Main Balance: 0.00 USD

* Loan Request Scenario:
Alice borrows 500.00 USD

* After Loan Disbursement:
Alice Loan Balance: - 500.00 USD (debt owed)
Alice Main Balance: + 500.00 USD (funds received by customer)
```

Initiate this transaction in your ledger:

<CodeGroup>
  ```bash cURL wrap expandable theme={"system"}
  curl -X POST "http://localhost:5001/transactions" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "precise_amount": 50000,
      "precision": 100,
      "reference": "LOAN-DISBURSE-1709741652384",
      "currency": "USD",
      "source": "bln_LOAN_BALANCE_ID",
      "destination": "bln_CUSTOMER_BALANCE_ID",
      "description": "Loan disbursement",
      "allow_overdraft": true,
      "meta_data": {
          "transaction_type": "loan_disbursement"
      }
    }'
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function disburseLoan(loanBalanceId, customerBalanceId, loanAmount) {
    
    
    // Generate a unique reference for this transaction
    const reference = `LOAN-DISBURSE-${Date.now()}`;
    
    const disbursement = await blnk.Transactions.create({
      precise_amount: loanAmount * 100,
      precision: 100,
      reference: reference,
      currency: "USD",
      source: loanBalanceId,
      destination: customerBalanceId,
      description: "Loan disbursement",
      allow_overdraft: true, // This allows the loan balance to go negative
      meta_data: {
        transaction_type: "loan_disbursement",
      }
    });
    
    console.log("Loan disbursed:", disbursement.data);
    
    const baseUrl = process.env.BLNK_BASE_URL ?? 'http://localhost:5001';
    const apiKey = process.env.BLNK_API_KEY ?? '';
    const metaRes = await fetch(`${baseUrl}/${loanBalanceId}/metadata`, {
      method: 'POST',
      headers: {
        'X-Blnk-Key': apiKey,
        'Content-Type': 'application/json',
      },
      body: JSON.stringify({
        meta_data: { loan_status: 'active' },
      }),
    });
    if (!metaRes.ok) throw new Error(await metaRes.text());
    
    return disbursement.data.transaction_id;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func disburseLoan(loanBalanceID, customerBalanceID string, loanAmount float64) (string, error) {
      client := getClient()
      reference := fmt.Sprintf("LOAN-DISBURSE-%d", time.Now().Unix())

      disbursement, _, err := client.Transaction.Create(blnkgo.CreateTransactionRequest{
          ParentTransaction: blnkgo.ParentTransaction{
              PreciseAmount: loanAmount * 100,
              Precision:   100,
              Reference:   reference,
              Currency:    "USD",
              Source:      loanBalanceID,
              Destination: customerBalanceID,
              Description: "Loan disbursement",
              MetaData: map[string]interface{}{
                  "transaction_type": "loan_disbursement",
              },
          },
          AllowOverdraft: true,
      })
      if err != nil {
          return "", err
      }

      _, _, err = client.Metadata.UpdateMetadata(loanBalanceID, blnkgo.UpdateMetaDataRequest{
          MetaData: map[string]interface{}{
              "loan_status": "active",
          },
      })
      if err != nil {
          return "", err
      }

      fmt.Println("Loan disbursed:", disbursement.TransactionID)
      return disbursement.TransactionID, nil
  }
  ```
</CodeGroup>

***

## Calculate and charge daily interest

Next, we need to calculate daily interest based on the formula $P * R * T$, where:

* P is the principal (loan amount or remaining balance)
* R is the daily interest rate
* T is time (1 day for daily interest)

According to our map, interest is transferred from the `Loan Balance` to the `@InterestRevenue`.

```txt Example scenario (cont'd) wrap theme={"system"}
* After 1 day, with 1% daily interest
+5 USD added to @InterestRevenue
-5 USD deducted from Loan Balance

* Final Balances
Alice Loan Balance: - 505.00 USD (debt owed, including interest)
Alice Main Balance: 500.00 USD (funds received by customer)
@InterestRevenue: + 5.00 USD (interest earned)
```

Record the daily interest charge on the loan balance:

<CodeGroup>
  ```bash cURL wrap expandable theme={"system"}
  curl -X POST "http://localhost:5001/transactions" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "precise_amount": 500,
      "precision": 100,
      "reference": "INTEREST-1709741780214",
      "currency": "USD",
      "source": "bln_LOAN_BALANCE_ID",
      "destination": "@InterestRevenue",
      "description": "Daily interest charge",
      "allow_overdraft": true,
      "meta_data": {
          "transaction_type": "interest_charge",
          "interest_rate": 0.01,
          "principal_amount": 500
      }
    }'
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function calculateAndChargeInterest(loanBalanceId, interestRate) {
    
    
    // Get current loan balance
    const loanBalance = await blnk.LedgerBalances.get(loanBalanceId);
    
    // Get the principal amount (convert negative balance to positive)
    const principal = Math.abs(loanBalance.data.balance);
    
    // Calculate daily interest amount
    const dailyRate = interestRate / 365; // Convert annual rate to daily
    const interestAmount = principal * dailyRate;
    
    // Round to 2 decimal places and convert to cents
    const roundedInterest = Math.round(interestAmount * 100) / 100;
    
    // Generate a unique reference
    const reference = `INTEREST-${Date.now()}`;
    
    // Transfer interest from loan balance to interest revenue balance
    const interestTransaction = await blnk.Transactions.create({
      precise_amount: roundedInterest * 100,
      precision: 100,
      reference: reference,
      currency: "USD",
      source: loanBalanceId,
      destination: "@InterestRevenue",
      description: "Daily interest charge",
      allow_overdraft: true, // Allow loan balance to go further negative
      meta_data: {
        transaction_type: "interest_charge",
        interest_rate: interestRate,
        principal_amount: principal / 100, // Convert back to dollars for readability
      }
    });
    
    console.log("Interest charged:", interestTransaction.data);
    
    return interestTransaction.data.transaction_id;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func calculateAndChargeInterest(loanBalanceID string, interestRate float64) (string, error) {
      client := getClient()
      loanBalance, _, err := client.LedgerBalance.Get(loanBalanceID)
      if err != nil {
          return "", err
      }

      balanceFloat, _ := loanBalance.Balance.Float64()
      principal := math.Abs(balanceFloat)
      dailyRate := interestRate / 365
      interestAmount := principal * dailyRate
      roundedInterest := math.Round(interestAmount*100) / 100
      reference := fmt.Sprintf("INTEREST-%d", time.Now().Unix())

      interestTransaction, _, err := client.Transaction.Create(blnkgo.CreateTransactionRequest{
          ParentTransaction: blnkgo.ParentTransaction{
              PreciseAmount: roundedInterest * 100,
              Precision:   100,
              Reference:   reference,
              Currency:    "USD",
              Source:      loanBalanceID,
              Destination: "@InterestRevenue",
              Description: "Daily interest charge",
              MetaData: map[string]interface{}{
                  "transaction_type": "interest_charge",
                  "interest_rate":    interestRate,
                  "principal_amount": principal / 100,
              },
          },
          AllowOverdraft: true,
      })
      if err != nil {
          return "", err
      }

      fmt.Println("Interest charged:", interestTransaction.TransactionID)
      return interestTransaction.TransactionID, nil
  }
  ```
</CodeGroup>

***

## Loan repayments

When a customer makes a loan repayment, the money moves from their main balance to the loan balance.

<CodeGroup>
  ```bash cURL wrap expandable theme={"system"}
  curl -X POST "http://localhost:5001/transactions" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json" \
    -d '{
      "precise_amount": 20000,
      "precision": 100,
      "reference": "LOAN-REPAY-1709741952867",
      "currency": "USD",
      "source": "bln_CUSTOMER_BALANCE_ID",
      "destination": "bln_LOAN_BALANCE_ID",
      "description": "Loan repayment",
      "meta_data": {
          "transaction_type": "loan_repayment",
          "payment_method": "bank_transfer"
      }
    }'
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function processLoanRepayment(customerBalanceId, loanBalanceId, repaymentAmount) {
    
    
    // Generate a unique reference
    const reference = `LOAN-REPAY-${Date.now()}`;
    
    // Transfer from customer's balance to loan balance
    const repayment = await blnk.Transactions.create({
      precise_amount: repaymentAmount * 100,
      precision: 100,
      reference: reference,
      currency: "USD",
      source: customerBalanceId,
      destination: loanBalanceId,
      description: "Loan repayment",
      meta_data: {
        transaction_type: "loan_repayment",
        payment_method: "bank_transfer"
      }
    });
    
    console.log("Loan repayment processed:", repayment.data);
    
    // Check if loan is fully repaid
    const updatedLoanBalance = await blnk.LedgerBalances.get(loanBalanceId);
    
    if (updatedLoanBalance.data.balance >= 0) {
      // Loan is fully repaid, update status
      const baseUrl = process.env.BLNK_BASE_URL ?? 'http://localhost:5001';
      const apiKey = process.env.BLNK_API_KEY ?? '';
      const metaRes = await fetch(`${baseUrl}/${loanBalanceId}/metadata`, {
        method: 'POST',
        headers: {
          'X-Blnk-Key': apiKey,
          'Content-Type': 'application/json',
        },
        body: JSON.stringify({
          meta_data: {
            loan_status: 'fully_repaid',
            repayment_completed_date: new Date().toISOString(),
          },
        }),
      });
      if (!metaRes.ok) throw new Error(await metaRes.text());
      console.log("Loan fully repaid!");
    }
    
    return repayment.data.transaction_id;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func processLoanRepayment(customerBalanceID, loanBalanceID string, repaymentAmount float64) (string, error) {
      client := getClient()
      reference := fmt.Sprintf("LOAN-REPAY-%d", time.Now().Unix())

      repayment, _, err := client.Transaction.Create(blnkgo.CreateTransactionRequest{
          ParentTransaction: blnkgo.ParentTransaction{
              PreciseAmount: repaymentAmount * 100,
              Precision:   100,
              Reference:   reference,
              Currency:    "USD",
              Source:      customerBalanceID,
              Destination: loanBalanceID,
              Description: "Loan repayment",
              MetaData: map[string]interface{}{
                  "transaction_type": "loan_repayment",
                  "payment_method":     "bank_transfer",
              },
          },
      })
      if err != nil {
          return "", err
      }

      updatedLoanBalance, _, err := client.LedgerBalance.Get(loanBalanceID)
      if err != nil {
          return "", err
      }

      repaidBalance, _ := updatedLoanBalance.Balance.Float64()
      if repaidBalance >= 0 {
          _, _, err = client.Metadata.UpdateMetadata(loanBalanceID, blnkgo.UpdateMetaDataRequest{
              MetaData: map[string]interface{}{
                  "loan_status":                "fully_repaid",
                  "repayment_completed_date": time.Now().UTC().Format(time.RFC3339),
              },
          })
          if err != nil {
              return "", err
          }
          fmt.Println("Loan fully repaid!")
      }

      fmt.Println("Loan repayment processed:", repayment.TransactionID)
      return repayment.TransactionID, nil
  }
  ```
</CodeGroup>

***

## Check loan status

We can check if a loan is fully repaid by verifying if the loan balance is zero or positive:

<CodeGroup>
  ```bash cURL wrap theme={"system"}
  curl -X GET "http://localhost:5001/balances/bln_LOAN_BALANCE_ID" \
    -H "X-blnk-key: <api-key>" \
    -H "Content-Type: application/json"
  ```

  ```typescript TypeScript wrap expandable theme={"system"}
  async function checkLoanStatus(loanBalanceId) {
    
    
    const loanBalance = await blnk.LedgerBalances.get(loanBalanceId);
    
    const status = {
      balance_id: loanBalanceId,
      current_balance: loanBalance.data.balance / 100, // Convert cents to dollars
      is_fully_repaid: loanBalance.data.balance >= 0,
      loan_status: loanBalance.data.meta_data.loan_status,
      loan_details: loanBalance.data.meta_data
    };
    
    console.log("Loan status:", status);
    return status;
  }
  ```

  ```go Go wrap expandable theme={"system"}
  func checkLoanStatus(loanBalanceID string) (map[string]interface{}, error) {
      client := getClient()
      loanBalance, _, err := client.LedgerBalance.Get(loanBalanceID)
      if err != nil {
          return nil, err
      }

      balanceFloat, _ := loanBalance.Balance.Float64()
      status := map[string]interface{}{
          "balance_id":      loanBalanceID,
          "current_balance": balanceFloat / 100,
          "is_fully_repaid": balanceFloat >= 0,
          "loan_status":     loanBalance.MetaData["loan_status"],
          "loan_details":    loanBalance.MetaData,
      }

      fmt.Println("Loan status:", status)
      return status, nil
  }
  ```
</CodeGroup>

***

## Conclusion

You now have a fully functional loan management system built with Blnk Finance. This system can:

* Create and manage loan accounts
* Disburse loans
* Calculate and charge daily interest
* Process loan repayments
* Track loan status

You can also:

1. **Track due dates:** Enhance the loan metadata to include payment schedules and due dates to monitor late payments.

2. **Audit trail:** Use detailed metadata for all transactions to maintain a comprehensive audit trail.

3. **Schedule interest charges:** Set up a cron job or scheduled task to automatically calculate and charge interest daily.

***

<CtaCallout title="Need help with your use case?" href="https://blnkfinance.com/contact/us?utm_source=blnk_docs&utm_medium=documentation&utm_campaign=home%2Finstall" buttonLabel="Speak with us" trackingEvent="clicked_pro_support">
  Get dedicated support for architecture reviews, integration planning, ledger workflows, and production deployment.
</CtaCallout>
