NLPearl.AI allows your Pearl to interact with external systems by making API calls in real-time during a conversation. This powerful feature enables your AI agent to fetch, post, or update information dynamically, providing a seamless and personalized experience for your customers.

Configuring API Actions in a Pearl

To set up an API call within your Pearl, follow these steps:

  1. Navigate to the Action Section: While creating or editing a Pearl, go to the Action section.
  2. Add a New API Action: Click on “API” and then “Add New” to start configuring your API request.

Fields to Configure

  • Description:

    • Purpose: Write a brief description explaining what this API endpoint is supposed to do. This helps you keep track of the various API calls you might configure within the Pearl.
  • When to Trigger the Action:

    • Trigger Condition: Define the conditions under which this API call should be made. For example, “Call this API when the customer requests their account balance,” or “Send this API request after the prospect agrees to sign up.”
  • URL:

    • Endpoint: Enter the URL of the API endpoint you want to call. You can use variables (while clicking on + ) in the URL to customize the request for each conversation.
  • Headers:

    • Header Information: Add any necessary headers, such as Content-Type, Authorization, etc. This is where you would include any authorization tokens if required.
  • Body (for POST and PUT requests):

    • JSON Body: Enter the request body in JSON format. You can insert variables into the JSON to ensure the data sent is tailored to the specific conversation.

      The variables will be collected during the call. For more information about variables, visit our Variables page.

Example Use Cases

Here are a few scenarios where you might use an API call within a Pearl:

  • Fetch Customer Data: You can set up an API call to retrieve customer details based on their account number. This information can then be used to personalize the conversation.

  • Update CRM Records: After confirming an order with a customer, Pearl can call an API to update the customer’s information in your CRM system.

  • Post Data: Pearl can send collected information, such as a lead’s contact details or preferences, directly to your backend systems via an API.

Multiple API Calls

You can add several API actions to a single Pearl, allowing for complex interactions where multiple pieces of information are fetched, posted, or updated in real-time, depending on the conversation flow.


Using Nested Objects in API Actions

When creating API Action, you can map variables to nested keys in the JSON body of the API request. This allows you to structure your API calls with nested objects, providing more organized and readable data when integrating with external systems.

Mapping Variables to Nested API Keys

  • API Keys: Can include nested keys using dot notation and array indices using square brackets (e.g., customer.address.street, order.items[0].productId).
  • Variables: Map each nested API key to the appropriate variable collected during the conversation.

Steps to Map Variables to Nested Keys

  1. Add an API Action Node to your conversation flow.
  2. Configure the API Request:
    • Method: Choose the HTTP method (e.g., POST, PUT).
    • URL: Enter the endpoint URL.
  3. Define the Request Body:
    • Use JSON format for the body.
    • In the keys of your JSON object, use dot notation to represent nested structures.
  4. Map Variables to Nested Keys:
    • For each API key, specify the path using dot notation.
    • Assign the corresponding variable to each key.

Example

Variables Collected:

  • customerName (String)
  • customerEmail (String)
  • street (String)
  • city (String)
  • productId (String)
  • quantity (Number)

API Request Configuration:

  • Method: POST
  • URL: https://api.example.com/orders
  • Body:
{
  "customer": {
    "name": "{{customerName}}",
    "email": "{{customerEmail}}",
    "address": {
      "street": "{{street}}",
      "city": "{{city}}"
    }
  },
  "order": {
    "items": [
      {
        "productId": "{{productId}}",
        "quantity": "{{quantity}}"
      }
    ]
  }
}

Mapping Variables:

  • customer.namecustomerName
  • customer.emailcustomerEmail
  • customer.address.streetstreet
  • customer.address.citycity
  • order.items[0].productIdproductId
  • order.items[0].quantityquantity