Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 75 Next »

Overview

The Vicidial Lead Archive API is designed to facilitate the archiving of leads within the Vicidial system. This API allows users to manage leads efficiently, ensuring streamlined operations and improved lead data management practices.

API will be set by TForge to operate outside of office hours only.

Endpoint

Server address will be provided by TForge.

Use the following endpoint to initiate your request:

Method

Endpoint

Description

POST

https://server/vicidial/lead/archive/

Lead archive endpoint

Authentication

API key will be provided by TForge.

To access the Lead Archive API, you must authenticate using an API key.

Include the following headers in your request:

Authorization: Key=YOUR_API_KEY
Content-Type: application/json

Request

The API consistently executes operations in the following sequential order:

  1. insert_leads

  2. update_leads

  3. delete_leads

When making a request, you must post the following JSON object.

{
  "insert_leads": true,
  "update_leads": true,
  "delete_leads": true,
  "lead_ids": [
    0,
    1
  ]
}

Field

Datatype

Description

insert_leads

true | false

This feature enables the insertion of specified lead IDs into the vicidial_list_archive table. Lead IDs that are already present in the vicidial_list_archive table will not be inserted again.

Use update_leads to ensure the specified lead IDs data is synchronized for lead IDs that were not inserted into vicidial_list_archive table.

It is recommended to always set this feature to true.

update_leads

true | false

This feature enables the updation of specified lead IDs. If a lead ID is already present in the vicidial_list_archive table, the API will update the lead ID data with the most recent matching lead ID information retrieved from the vicidial_list table.

It is recommended to always set this feature to true for lead ID data synchronization.

delete_leads

true | false

This feature enables the deletion of specified lead IDs from the vicidial_list table in a safe manner. Before deleting, the API checks if the matching lead ID exists in the vicidial_list_archive table and the column data matches the vicidial_list table lead ID data.

Setting this feature to false will result in lead IDs remaining in the vicidial_list table.

lead_ids

Integer values

Specify the lead IDs that you wish to archive. Ensure that the number of lead ID values does not exceed 500.

CURL request example:

Disable SSL verification upon sending the request.

For testing, create a dummy list and load 500 leads into that list. Use created lead IDs.

  1. Insert lead IDs into the vicidial_list_archive table. Ignore lead IDs that exist in the vicidial_list_archive table.

  2. Update lead ID in the vicidial_list_archive table with lead ID data from the vicidial_list table.

  3. Delete lead IDs from the vicidial_list table. Performs safe delete by checking if the lead ID exists in the vicidial_list_archive table and if the column data matches the vicidial_list table lead ID.

curl -k -X POST https://server/vicidial/lead/archive/ \
-H "Authorization: Key=YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
      "insert_leads": true,
      "update_leads": true,
      "delete_leads": true,
      "lead_ids": [
        0,
        1
      ]
    }'

Response

The API follows general HTTP response status codes. In addition to the status code included in the JSON response, you can also rely on the HTTP status code returned by the response.

HTTP status code - 200

Returns the following successful response If there are no errors with the request or the specified lead IDs. The data will be processed based on the option values specified in the request JSON object.

{
  "success": "lead_ids batch was successfully processed",
  "select_count": 1,
  "insert_count": 1,
  "update_count": 0,
  "delete_count": 1,
  "status_code": 200
}

HTTP status code - 441

Returns the following error response if the API was executed during office hours.

{
  "error": "api cannot be executed during office hours time condition",
  "status_code": 441
}

HTTP status code - 442

Returns the following error response if the value passed for insert_leads is not a bool value or no value was provided.

{
  "error": "insert_leads must be a boolean value",
  "status_code": 442
}

HTTP status code - 443

Returns the following error response if the value passed for update_leads is not a bool value or no value was provided.

{
  "error": "update_leads must be a boolean value",
  "status_code": 443
}

HTTP status code - 444

Returns the following error response if the value passed for delete_leads is not a bool value or no value was provided.

{
  "error": "delete_leads must be a boolean value",
  "status_code": 444
}

HTTP status code - 445

Returns the following error response if the value passed for lead_ids is not an integer value or was passed with double quotes.

{
  "error": "lead_ids must only contain integer values",
  "lead_count": 1,
  "lead_ids": [
    "0"
  ],
  "status_code": 445
}

HTTP status code - 446

Returns the following error response if no value was passed for lead_ids.

{
  "error": "lead_ids must contain atleast 1 value",
  "status_code": 446
}

HTTP status code - 447

Returns the following error response if the values passed for lead_ids exceed 500 values.

{
  "error": "lead_ids cannot exceed 500 values",
  "status_code": 447
}

HTTP status code - 448

Returns the following error response if the values passed for lead_ids contain duplicate values.

{
  "error": "lead_ids cannot contain duplicate values",
  "lead_count": 1,
  "lead_ids": [
    0
  ],
  "status_code": 448
}

HTTP status code - 449

Returns the following error response if the values passed for lead_ids do not exist in the vicidial_list table.

{
  "error": "lead_ids does not exist",
  "lead_count": 1,
  "values": [
    0
  ],
  "status_code": 449
}

HTTP status code - 450

Returns the following error response for any other errors not mentioned above.

{
  "error": "Unexpected character encountered while parsing number: s. Path 'lead_ids[97]', line 104, position 5.",
  "status_code": 450
}

Conclusion

If you encounter any issues with the API, please log a ticket with our support department. You can also contact us at 010-035-0909 or email our dedicated Customer Experience team at cex@teleforge.co.za. Please ensure to include your ticket number for reference and expedited support.

  • No labels