V 2.0
Directory
Overview
The Directory API provides functionality to manage contact information. With this API, you can create, update, and retrieve contacts, as well as manage sticky agents, account managers, and other related operations.
Authentication
Authentication is required for all endpoints. You can use either:
- 
SSID (Session ID) 
- 
User ID and Token 
These must be included in the request body for each API call.
Base URL
The base URL for all API endpoints is: deepcall/api/v2/Directory
Error Codes
The following table shows specific error codes for the Directory API, extracted from SarvErrors.js:
| Error Code | Description | 
|---|---|
| 1501 | Sticky agent error | 
| 1502 | Type is not valid | 
| 1503 | Account manager error | 
| 1504 | Failed to create directory | 
| 1505 | CLI does not exist | 
| 1506 | Group ID does not exist | 
| 1507 | Agent does not exist in the given group ID | 
| 1508 | Expiry must be greater than or equal to -1 | 
| 1509 | Expiry must be integer value | 
| 1510 | DNC error | 
In addition to these specific error codes, there may also be general error codes such as:
| Error Code | Description | 
|---|---|
| 1000 | Invalid parameter | 
| 1005 | Invalid contact number | 
| 1012 | No data found | 
These error codes will help developers better understand and troubleshoot API responses.
Sticky Get
Endpoint
- 
Method: POST 
- 
Path: deepcall/api/v2/Directory/getSticky
Description: This endpoint allows you to retrieve the sticky agent information set for a specific contact. It can return multiple sticky agent settings if they exist.
Use Case: Checking which agent is assigned to handle a specific customer's interactions.
Parameters:
| Name | Type | Required | Description | 
|---|---|---|---|
| contact | String | Yes | The contact number | 
| type | String | No | Filter by sticky type (all, cli, cli_group) | 
| agentId | String | No | Filter by agent ID | 
| groupid | String | No | Filter by group ID | 
| cli | String | No | Filter by CLI (Caller Line Identification) | 
| expiry | String | No | Filter by expiry time (Unix timestamp) | 
| ssid | String | Conditional | Session ID (required if userId and token not provided) | 
| userId | String | Conditional | User ID (required if ssid not provided) | 
| token | String | Conditional | Authentication token (required if ssid not provided) | 
Notes:
- 
Ensure that the contact number is valid and in the correct format. 
- 
The response may contain multiple sticky agent settings if they exist for the contact. 
- 
If no sticky agent is set, an empty data array will be returned. 
- 
You can use various filters to narrow down the sticky agent information: - 
type: Filter by the type of sticky agent setting (all, cli, cli_group)
- 
agentId: Filter by a specific agent
- 
groupid: Filter by a specific group (relevant for cli_group type)
- 
cli: Filter by a specific CLI (relevant for cli and cli_group types)
- 
expiry: Filter by expiry time
 
- 
- 
If filters are used, only the sticky agent settings that match ALL provided filters will be returned. 
- 
The expiryfield in the response is a Unix timestamp. A value of -1 indicates no expiry.
- 
The typefield in the response indicates the scope of the sticky agent setting:- 
"all": The agent is sticky for all interactions with this contact. 
- 
"cli": The agent is sticky only for interactions involving the specified CLI. 
- 
"cli_group": The agent is sticky for interactions involving the specified CLI and group. 
 
- 
- 
If a cli_grouptype sticky agent is set, the response will include bothcliandgroupfields.
- 
The API will return appropriate error codes and messages for invalid inputs or server-side issues. 
- 
This endpoint is useful for understanding the current sticky agent assignments for a contact, which can be helpful in troubleshooting call routing issues or reviewing agent-customer pairings. 
Sticky Get     
     
        
                    
                    
                  
     
    
    
    var axios = require('axios');
var data = '{"ssid":"{{ssid}}","contact": "{{callernumber}}","agentId": "18"}';
var config = {
 method: 'post',
 url: '{{brand}}/api/v2/Directory/getSticky',
 headers: { 
'Content-Length': ''
 },
 data : data
};
axios(config)
.then(function (response) {
 console.log(JSON.stringify(response.data));
})
.catch(function (error) {
 console.log(error);
});
setUrl('{{brand}}/api/v2/Directory/getSticky');
$request->setMethod(HTTP_Request2::METHOD_POST);
$request->setConfig(array(
 'follow_redirects' => TRUE
));
$request->setHeader(array(
 'Content-Length' => ''
));
$request->setBody('{"ssid":"{{ssid}}","contact": "{{callernumber}}","agentId": "18"}');
try {
 $response = $request->send();
 if ($response->getStatus() == 200) {
echo $response->getBody();
 }
 else {
echo 'Unexpected HTTP status: ' . $response->getStatus() . ' ' .
$response->getReasonPhrase();
 }
}
catch(HTTP_Request2_Exception $e) {
 echo 'Error: ' . $e->getMessage();
}import http.client
conn = http.client.HTTPSConnection("{{brand}}")
payload = "{\"ssid\":\"{{ssid}}\",\"contact\": \"{{callernumber}}\",\"agentId\": \"18\"}"
headers = {
 'Content-Length': ''
}
conn.request("POST", "/api/v2/Directory/getSticky", payload, headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))var client = new RestClient("{{brand}}/api/v2/Directory/getSticky");
client.Timeout = -1;
var request = new RestRequest(Method.POST);
var body = @"{" + "\n" +
@"    ""ssid"":""{{ssid}}""," + "\n" +
@"    ""contact"": ""{{callernumber}}""," + "\n" +
@"    ""agentId"": ""18""" + "\n" +
@"" + "\n" +
@"}";
request.AddParameter("text/plain", body,  ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
Console.WriteLine(response.Content);curl --location -g --request POST '{{brand}}/api/v2/Directory/getSticky' \
--data-raw '{
    "ssid":"{{ssid}}",
    "contact": "{{callernumber}}",
    "agentId": "18"
}'var request = http.Request('POST', Uri.parse('{{brand}}/api/v2/Directory/getSticky'));
request.body = '''{\n    "ssid":"{{ssid}}",\n    "contact": "{{callernumber}}",\n    "agentId": "18"\n\n}''';
http.StreamedResponse response = await request.send();
if (response.statusCode == 200) {
   print(await response.stream.bytesToString());
}
else {
   print(response.reasonPhrase);
}
package main
import (
   "fmt"
   "strings"
   "net/http"
   "io/ioutil"
)
func main() {
   url := "%7B%7Bbrand%7D%7D/api/v2/Directory/getSticky"
   method := "POST"
   payload := strings.NewReader(`{
    "ssid":"{{ssid}}",
    "contact": "{{callernumber}}",
    "agentId": "18"
}`)
   client := &http.Client {
   }
   req, err := http.NewRequest(method, url, payload)
   if err != nil {
      fmt.Println(err)
      return
   }
   res, err := client.Do(req)
   if err != nil {
      fmt.Println(err)
      return
   }
   defer res.Body.Close()
   body, err := ioutil.ReadAll(res.Body)
   if err != nil {
      fmt.Println(err)
      return
   }
   fmt.Println(string(body))
}POST /api/v2/Directory/getSticky HTTP/1.1
Host: {{brand}}
Content-Length: 82
{
    "ssid":"{{ssid}}",
    "contact": "{{callernumber}}",
    "agentId": "18"
}OkHttpClient client = new OkHttpClient().newBuilder()
   .build();
MediaType mediaType = MediaType.parse("text/plain");
RequestBody body = RequestBody.create(mediaType, "{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}");
Request request = new Request.Builder()
   .url("{{brand}}/api/v2/Directory/getSticky")
   .method("POST", body)
   .addHeader("Content-Length", "")
   .build();
Response response = client.newCall(request).execute();var myHeaders = new Headers();
myHeaders.append("Content-Length", "");
var raw = "{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}";
var requestOptions = {
   method: 'POST',
   headers: myHeaders,
   body: raw,
   redirect: 'follow'
};
fetch("{{brand}}/api/v2/Directory/getSticky", requestOptions)
   .then(response => response.text())
   .then(result => console.log(result))
   .catch(error => console.log('error', error));CURL *curl;
CURLcode res;
curl = curl_easy_init();
if(curl) {
   curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "POST");
   curl_easy_setopt(curl, CURLOPT_URL, "%7B%7Bbrand%7D%7D/api/v2/Directory/getSticky");
   curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
   curl_easy_setopt(curl, CURLOPT_DEFAULT_PROTOCOL, "https");
   struct curl_slist *headers = NULL;
   headers = curl_slist_append(headers, "Content-Length: ");
   curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
   const char *data = "{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}";
   curl_easy_setopt(curl, CURLOPT_POSTFIELDS, data);
   res = curl_easy_perform(curl);
}
curl_easy_cleanup(curl);
#import 
dispatch_semaphore_t sema = dispatch_semaphore_create(0);
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:@"%7B%7Bbrand%7D%7D/api/v2/Directory/getSticky"]
   cachePolicy:NSURLRequestUseProtocolCachePolicy
   timeoutInterval:10.0];
NSDictionary *headers = @{
   @"Content-Length": @""
};
[request setAllHTTPHeaderFields:headers];
NSData *postData = [[NSData alloc] initWithData:[@"{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}" dataUsingEncoding:NSUTF8StringEncoding]];
[request setHTTPBody:postData];
[request setHTTPMethod:@"POST"];
NSURLSession *session = [NSURLSession sharedSession];
NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request
completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
   if (error) {
      NSLog(@"%@", error);
      dispatch_semaphore_signal(sema);
   } else {
      NSHTTPURLResponse *httpResponse = (NSHTTPURLResponse *) response;
      NSError *parseError = nil;
      NSDictionary *responseDictionary = [NSJSONSerialization JSONObjectWithData:data options:0 error:&parseError];
      NSLog(@"%@",responseDictionary);
      dispatch_semaphore_signal(sema);
   }
}];
[dataTask resume];
dispatch_semaphore_wait(sema, DISPATCH_TIME_FOREVER); open Lwt
open Cohttp
open Cohttp_lwt_unix
let postData = ref "{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}";;
let reqBody = 
   let uri = Uri.of_string "%7B%7Bbrand%7D%7D/api/v2/Directory/getSticky" in
   let headers = Header.init ()
      |> fun h -> Header.add h "Content-Length" ""
   in
   let body = Cohttp_lwt.Body.of_string !postData in
   Client.call ~headers ~body `POST uri >>= fun (_resp, body) ->
   body |> Cohttp_lwt.Body.to_string >|= fun body -> body
let () =
   let respBody = Lwt_main.run reqBody in
   print_endline (respBody)$headers = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
$headers.Add("Content-Length", "")
$body = "{`n    `"ssid`":`"{{ssid}}`",`n    `"contact`": `"{{callernumber}}`",`n    `"agentId`": `"18`"`n`n}"
$response = Invoke-RestMethod '{{brand}}/api/v2/Directory/getSticky' -Method 'POST' -Headers $headers -Body $body
$response | ConvertTo-Jsonrequire "uri"
require "net/http"
url = URI("{{brand}}/api/v2/Directory/getSticky")
http = Net::HTTP.new(url.host, url.port);
request = Net::HTTP::Post.new(url)
request["Content-Length"] = ""
request.body = "{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}"
response = http.request(request)
puts response.read_body
printf '{
    "ssid":"{{ssid}}",
    "contact": "{{callernumber}}",
    "agentId": "18"
}'| http  --follow --timeout 3600 POST '{{brand}}/api/v2/Directory/getSticky' \
 Content-Length:import Foundation
#if canImport(FoundationNetworking)
import FoundationNetworking
#endif
var semaphore = DispatchSemaphore (value: 0)
let parameters = "{\n    \"ssid\":\"{{ssid}}\",\n    \"contact\": \"{{callernumber}}\",\n    \"agentId\": \"18\"\n\n}"
let postData = parameters.data(using: .utf8)
var request = URLRequest(url: URL(string: "{{brand}}/api/v2/Directory/getSticky")!,timeoutInterval: Double.infinity)
request.addValue("", forHTTPHeaderField: "Content-Length")
request.httpMethod = "POST"
request.httpBody = postData
let task = URLSession.shared.dataTask(with: request) { data, response, error in 
   guard let data = data else {
      print(String(describing: error))
      semaphore.signal()
      return
   }
   print(String(data: data, encoding: .utf8)!)
   semaphore.signal()
}
task.resume()
semaphore.wait()
Example Response
 [{"key":"Date"
"value":"Thu
 28 Nov 2024 08:40:48 GMT"}
{"key":"Content-Type"
"value":"application\/json; charset=utf-8"}
{"key":"Content-Length"
"value":"73"}
{"key":"Connection"
"value":"keep-alive"}
{"key":"Access-Control-Allow-Origin"
"value":"*"}
{"key":"Access-Control-Allow-Methods"
"value":"POST
 GET
 OPTIONS
 PATCH
 DELETE"}
{"key":"Access-Control-Allow-Headers"
"value":"X-Requested-With
content-type"}
{"key":"Access-Control-Allow-Credentials"
"value":"true"}
{"key":"Vary"
"value":"Origin"}
{"key":"ETag"
"value":"W\/\"49-vLLE7ZNVvo3U5fBbUqMVJFOTK20\""}
{"key":"Strict-Transport-Security"
"value":"max-age=31536000; includeSubDomains"}] {
    "data": [
        {
            "agent": 18,
            "expiry": 3418356527,
            "type": "*"
        }
    ],
    "status": "success"
}