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

# Search via Typesense

> Learn how to retrieve any data in your Ledger using Typesense.

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>;
};

<Info>Available in version 0.6.1 and later.</Info>

The Blnk Search API enables you to retrieve one or more records from your ledger. You can search across ledgers, balances, transactions, and identities using its filtering, sorting, faceting, and full-text search capabilities.

Unlike the standard GET endpoints that return either all records or a single specific record, the Search API gives you more control over your results. Use it when you need to:

* Filter large datasets efficiently
* Perform full-text searches across your data
* Aggregate and count values with faceting
* Sort and paginate results for better performance
* Combine multiple search conditions in a single request

***

## Searchable collections

The Search API works with four main collections in your Blnk ledger:

| Collection   | Endpoint               | Description                                 |
| :----------- | :--------------------- | :------------------------------------------ |
| Transactions | `/search/transactions` | Search through all transaction records      |
| Balances     | `/search/balances`     | Find balance records across all ledgers     |
| Ledgers      | `/search/ledgers`      | Locate specific ledgers by name or metadata |
| Identities   | `/search/identities`   | Search customer identity records            |

***

## Quick start

To get started with the Search API, use the endpoint: `/search/{collection}` where collection can be `ledgers`, `balances`, `identities`, or `transactions`.

Here's how a full search request looks:

<CodeGroup>
  ```bash cURL wrap theme={"system"}
  curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
    -H "X-Blnk-Key: YOUR_API_KEY" \
    -H "Content-Type: application/json" \
    -d '{
      "q": "bulk_baaea495-148a-4b16-b171-68c92fb911a6",
      "query_by": "parent_transaction",
      "filter_by": "status:=APPLIED && currency:=USD",
      "sort_by": "created_at:desc",
      "page": 1,
      "per_page": 10
    }'
  ```

  ```typescript TypeScript wrap theme={"system"}
  const response = await blnk.Search.search(
    {
      q: 'bulk_baaea495-148a-4b16-b171-68c92fb911a6',
      query_by: 'parent_transaction',
      filter_by: 'status:=APPLIED && currency:=USD',
      sort_by: 'created_at:desc',
      page: 1,
      per_page: 10,
    },
    'transactions',
  );
  ```

  ```go Go wrap theme={"system"}
  results, resp, err := client.Search.SearchDocument(
    blnkgo.SearchParams{
      Q:        "bulk_baaea495-148a-4b16-b171-68c92fb911a6",
      QueryBy:  "parent_transaction",
      FilterBy: "status:=APPLIED && currency:=USD",
      SortBy:   "created_at:desc",
      Page:     1,
      PerPage:  10,
    },
    blnkgo.Transactions,
  )
  ```
</CodeGroup>

```json Response expandable theme={"system"}
{
  "facet_counts": [],
  "found": 2,
  "hits": [
    {
      "document": {
        "amount": 532,
        "amount_string": "532",
        "atomic": false,
        "created_at": 1758116489,
        "currency": "USD",
        "description": "Test bulk",
        "destination": "bln_20666087-1355-4736-ba04-3ba92a7542b9",
        "effective_date": 1758116489,
        "id": "txn_cd728825-a6e1-4fae-9277-c3235a045ea5",
        "parent_transaction": "bulk_baaea495-148a-4b16-b171-68c92fb911a6",
        "precise_amount": 53200,
        "precision": 100,
        "reference": "bulk-search-1d2",
        "source": "bln_93fb50c2-969e-49c2-bb61-ef5ed245516e",
        "status": "APPLIED",
        "transaction_id": "txn_cd728825-a6e1-4fae-9277-c3235a045ea5"
      },
      "highlights": [
        {
          "field": "parent_transaction",
          "matched_tokens": ["bulk_baaea495-148a-4b16-b171-68c92fb911a6"],
          "snippet": "<mark>bulk_baaea495-148a-4b16-b171-68c92fb911a6</mark>"
        }
      ],
      "text_match": 578730123365711993
    },
    {
      "document": {
        "amount": 100,
        "amount_string": "100",
        "atomic": false,
        "created_at": 1758116489,
        "currency": "USD",
        "description": "Test bulk",
        "destination": "bln_d298f2b8-fdd6-4d0e-ade7-3cddcea90a8d",
        "effective_date": 1758116489,
        "id": "txn_0ae624a5-7fbc-4c67-831d-f888e928d4bc",
        "parent_transaction": "bulk_baaea495-148a-4b16-b171-68c92fb911a6",
        "precise_amount": 10000,
        "precision": 100,
        "reference": "bulk-search-2d3",
        "source": "bln_6592f225-f8fe-48cd-8974-51974dc83a3a",
        "status": "APPLIED",
        "transaction_id": "txn_0ae624a5-7fbc-4c67-831d-f888e928d4bc"
      },
      "highlights": [
        {
          "field": "parent_transaction",
          "matched_tokens": ["bulk_baaea495-148a-4b16-b171-68c92fb911a6"],
          "snippet": "<mark>bulk_baaea495-148a-4b16-b171-68c92fb911a6</mark>"
        }
      ],
      "text_match": 578730123365711993
    }
  ],
  "out_of": 232,
  "page": 1,
  "request_params": {
    "collection_name": "transactions",
    "per_page": 10,
    "q": "bulk_baaea495-148a-4b16-b171-68c92fb911a6"
  },
  "search_cutoff": false,
  "search_time_ms": 2
}
```

### Request parameters

| Parameter   | Description                                                                                     | Required | Type      |
| :---------- | :---------------------------------------------------------------------------------------------- | :------- | :-------- |
| `q`         | The search query text. Use `*` to return all records. [Learn more](/search/typesense/querying)  | Yes      | `string`  |
| `query_by`  | Comma-separated list of fields to search in. [Learn more](/search/typesense/querying)           | No       | `string`  |
| `filter_by` | Filter conditions to refine results. [Learn more](/search/typesense/filtering)                  | No       | `string`  |
| `facet_by`  | Comma-separated list of fields to aggregate and count. [Learn more](/search/typesense/faceting) | No       | `string`  |
| `sort_by`   | Sorting conditions for ordering results. [Learn more](/search/typesense/sorting)                | No       | `string`  |
| `page`      | Page number for pagination. Starts at 1. [Learn more](/search/typesense/pagination)             | No       | `integer` |
| `per_page`  | Number of results per page. Maximum 250, default 10. [Learn more](/search/typesense/pagination) | No       | `integer` |

### Response structure

| Field            | Description                                                                                                        | Type      |
| :--------------- | :----------------------------------------------------------------------------------------------------------------- | :-------- |
| `found`          | Total number of matching records.                                                                                  | `integer` |
| `hits`           | Array of search results, each containing a `document` with the record data.                                        | `array`   |
| `out_of`         | Total number of records in the collection.                                                                         | `integer` |
| `page`           | Current page number.                                                                                               | `integer` |
| `search_time_ms` | Time taken to execute the search in milliseconds.                                                                  | `integer` |
| `facet_counts`   | Aggregated counts for faceted fields. Only present when using `facet_by`. [Learn more](/search/typesense/faceting) | `array`   |
| `highlights`     | Search term highlighting information for matched fields.                                                           | `array`   |

***

## Common use cases

### 1. Transaction analysis

<Steps>
  <Step title="Find all transactions for a specific account">
    Get a complete transaction history by searching for all transactions where a particular balance ID appears as either source or destination.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "bln_28f25ef6-2e0d-4fa6-891c-37fc409d654e",
          "query_by": "source,destination",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "bln_28f25ef6-2e0d-4fa6-891c-37fc409d654e",
          query_by: "source,destination",
          sort_by: "created_at:desc",
        },
        'transactions',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "bln_28f25ef6-2e0d-4fa6-891c-37fc409d654e", QueryBy: "source,destination", SortBy: "created_at:desc"},
        blnkgo.Transactions,
      )
      ```
    </CodeGroup>
  </Step>

  <Step title="Get recent high-value transactions">
    Find transactions above a certain amount threshold to monitor large money movements or flag suspicious activity.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "*",
          "filter_by": "amount:>10000",
          "sort_by": "created_at:desc",
          "per_page": 50
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "*",
          filter_by: "amount:>10000",
          sort_by: "created_at:desc",
          per_page: 50,
        },
        'transactions',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "*", FilterBy: "amount:>10000", SortBy: "created_at:desc", PerPage: 50},
        blnkgo.Transactions,
      )
      ```
    </CodeGroup>
  </Step>

  <Step title="Search transactions by date range">
    Retrieve all transactions that occurred within a specific time period for reporting or audit purposes. Use Unix timestamps for date filtering.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "*",
          "filter_by": "created_at:[1704067200..1706745599]",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "*",
          filter_by: "created_at:[1704067200..1706745599]",
          sort_by: "created_at:desc",
        },
        'transactions',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "*", FilterBy: "created_at:[1704067200..1706745599]", SortBy: "created_at:desc"},
        blnkgo.Transactions,
      )
      ```
    </CodeGroup>

    <Info>
      Learn more about date filtering and Unix timestamps in our [Filtering documentation](/search/typesense/filtering).
    </Info>
  </Step>

  <Step title="Find rejected transactions">
    Filter transactions by status to identify failed payments that were rejected due to insufficient funds or validation errors.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "*",
          "filter_by": "status:=REJECTED",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "*",
          filter_by: "status:=REJECTED",
          sort_by: "created_at:desc",
        },
        'transactions',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "*", FilterBy: "status:=REJECTED", SortBy: "created_at:desc"},
        blnkgo.Transactions,
      )
      ```
    </CodeGroup>

    <Tip>
      For advanced filtering with operators like `:=`, `&&`, and ranges, see our detailed [Filtering guide](/search/typesense/filtering).
    </Tip>
  </Step>

  <Step title="Search by transaction type or description">
    Use full-text search to find transactions based on transaction type in metadata or descriptions for customer support.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "payment",
          "query_by": "meta_data.transaction_type,description",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "payment",
          query_by: "meta_data.transaction_type,description",
          sort_by: "created_at:desc",
        },
        'transactions',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "payment", QueryBy: "meta_data.transaction_type,description", SortBy: "created_at:desc"},
        blnkgo.Transactions,
      )
      ```
    </CodeGroup>

    <Info>
      Learn more about full-text search and field-specific queries in our [Querying documentation](/search/typesense/querying).
    </Info>
  </Step>

  <Step title="Find transactions between specific accounts">
    Search for transactions that occurred between two particular balance IDs to track money flow or analyze trading patterns.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/transactions" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "*",
          "filter_by": "source:=bln_28f25ef6-2e0d-4fa6-891c-37fc409d654e && destination:=bln_86ba7976-499d-4282-955e-a7c2abf5db12",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "*",
          filter_by: "source:=bln_28f25ef6-2e0d-4fa6-891c-37fc409d654e && destination:=bln_86ba7976-499d-4282-955e-a7c2abf5db12",
          sort_by: "created_at:desc",
        },
        'transactions',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "*", FilterBy: "source:=bln_28f25ef6-2e0d-4fa6-891c-37fc409d654e && destination:=bln_86ba7976-499d-4282-955e-a7c2abf5db12", SortBy: "created_at:desc"},
        blnkgo.Transactions,
      )
      ```
    </CodeGroup>
  </Step>
</Steps>

### 2. Account management

<Steps>
  <Step title="Get balances above/below a threshold">
    Find all balances with amounts greater than or less than specific values for risk management or account monitoring.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/balances" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "*",
          "filter_by": "balance:>100000",
          "sort_by": "balance:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "*",
          filter_by: "balance:>100000",
          sort_by: "balance:desc",
        },
        'balances',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "*", FilterBy: "balance:>100000", SortBy: "balance:desc"},
        blnkgo.Balances,
      )
      ```
    </CodeGroup>
  </Step>

  <Step title="Fetch all balances belonging to an identity">
    Retrieve all balances associated with a specific identity ID to get a complete view of a user's accounts and wallets.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/balances" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "*",
          "filter_by": "identity_id:=idt_28f25ef6-2e0d-4fa6-891c-37fc409d654e",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "*",
          filter_by: "identity_id:=idt_28f25ef6-2e0d-4fa6-891c-37fc409d654e",
          sort_by: "created_at:desc",
        },
        'balances',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "*", FilterBy: "identity_id:=idt_28f25ef6-2e0d-4fa6-891c-37fc409d654e", SortBy: "created_at:desc"},
        blnkgo.Balances,
      )
      ```
    </CodeGroup>
  </Step>

  <Step title="Search ledgers by name or metadata">
    Find specific ledgers using partial name matching or metadata filters to locate the right ledger for operations.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/ledgers" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "customer savings",
          "query_by": "name",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "customer savings",
          query_by: "name",
          sort_by: "created_at:desc",
        },
        'ledgers',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "customer savings", QueryBy: "name", SortBy: "created_at:desc"},
        blnkgo.Ledgers,
      )
      ```
    </CodeGroup>
  </Step>
</Steps>

### 3. Customer support

<Steps>
  <Step title="Search identities by name or email">
    Find specific customer identities using partial name matching or email addresses for customer support and account verification.

    <CodeGroup>
      ```bash cURL wrap theme={"system"}
      curl -X POST "http://YOUR_BLNK_INSTANCE_URL/search/identities" \
        -H "X-Blnk-Key: YOUR_API_KEY" \
        -H "Content-Type: application/json" \
        -d '{
          "q": "john doe",
          "query_by": "first_name,last_name,email",
          "sort_by": "created_at:desc"
        }'
      ```

      ```typescript TypeScript wrap theme={"system"}
      const response = await blnk.Search.search(
        {
          q: "john doe",
          query_by: "first_name,last_name,email",
          sort_by: "created_at:desc",
        },
        'identities',
      );
      ```

      ```go Go wrap theme={"system"}
      results, resp, err := client.Search.SearchDocument(
        blnkgo.SearchParams{Q: "john doe", QueryBy: "first_name,last_name,email", SortBy: "created_at:desc"},
        blnkgo.Identities,
      )
      ```
    </CodeGroup>
  </Step>
</Steps>

***

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