Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Below are is the web services service to call up to interact with the bot.

Asking a question

To ask a question (any type of text sent by the customer) to the Bot specify the standard "RFAQ" node in the request and pass the text of the question in the "hda_sematic_question" parameter.

Syntax:

HTTP GET https://{brain-host}:{port}/brain/autojson/{brain-service{brainURL}/RFAQ?hda_semantic_question={question}

headers = {
cookie: <BRAINSID_SessionCookie>
};

Example:

https://engagent-demo4.h-care.eu/brain/old/autojson/enghouse-brain-bot/1/RFAQ?hda_semantic_question=test node

Text Response:

...

languagejson

...

where “brainURL” is the url configured in the bot configuration stored in “botconfigurations” collection in mongoDB

Query string parameters:

Name

Description

hda_semantic_question

Text that will be passed to the bot to be interpreted

To trace the session, the "cookie" header must be set with the value of the session cookie.

The first request will not present the session cookie, but its response will contain the "set-cookie" header with the value of the session cookie. This cookie must be used for all subsequent requests of the same session:

headers = {
cookie: <BRAINSID_SessionCookie>
};

Example:

https://engagent-demo4.h-care.eu/brain/old/autojson/enghouse-brain-bot/1/RFAQ?hda_semantic_question=hello

Text Response:

Type: JSON

The “node” object must contain the “contents” object. This object must contain the “content” array. This array of objects must contain the text response sent back to the customer. The “contentType” property identifies the content of the text response and can assume one of the following values:

  • “TEXT_CONTENT_RICH” for formatted text

  • “READABLE_PLAIN” for only plain text

The “text” property must contain the response sent back to the customer.

In “web” chat, the “TEXT_CONTENT_RICH” response (if present) will be considered, if not present the “READABLE_PLAIN” response will be considered.

In other chat types (whatsapp, messenger, instagram channel), the “READABLE_PLAIN” response will be considered.

Code Block
languagejson
{
   "node":{
      "brain_id":"n_22367",
      "brain_version":"5.10.0-SNAPSHOT",
        "id":"cn_22367_1_1782882512725744298",
      "key":"TEST_NODE_MSG",
        "usePreviousTextserviceName":"falseenghouse-brain-bot",
      "serviceVersion":"1",
     },
 "contents":{
         "content":[
            {
               "bargein":"true",
               "brain_id":"c_22367_3",
               "contentType":"TEXT_CONTENT_RICH",
               "id":"c_22367_3_41735189",
               "usePreviousText":"false",
               "text":"Questo è un contenuto di <b>test</b>."
            },
            {
               "bargein":"true",
               "brain_id":"c_22367_2",
               "contentType":"READABLE_PLAIN",
               "id":"c_22367_2_1418502948",
               "usePreviousText":"false",
               "text":"Questo è un contenuto di *test*."
            }
         ]
      }
   }
}

Menu Response:

...

languagejson

...

Type: JSON

The “node” object must contain the “actions” object. This object must conatin the “action” object. The “command” property of this object must be set to “menu” and the “actions” object must contain the “action” array with the menu options.

In the example the menu has 3 child actions, each action has a command : "load-item" or "open-url".
For each menu item are specified : a label ( "content" ) and a target /target url.

  • “targetUrl”: url to call when the user selects the item. Relative url where the base is stored in the "brainUrl" parameter of the connector configuration saved in the database

  • “open-url”:( e.g. "https://www.google.com" ) : url to open ( browser/client side) when the user selects the item. Use the array of object “param” in the “param” property to specify the object with the properties “name”: “where” and “text”:”_blank” to indicate where to open the link

Code Block
languagejson
{
   "node":{
      "serviceNamebrain_id":"enghouse-brain-botn_22369",
      "serviceVersionbrain_version":"15.10.0-SNAPSHOT",
      "contentsid":{
  "n_22369_698945808",
      "contentkey":["TEST_MENU",
      "serviceName":"enghouse-brain-bot",
      {"serviceVersion":"1",
      "contents":{
         "content":[
            {
               "bargein":"true",
               "brain_id":"c_22369_13",
               "contentType":"VIDEOTEXT_CONTENT_RICH",
               "id":"c_22369_13_4947627501619889357",
               "usePreviousText":"false",
            },   "text":"Choose an option"
       {     }
          "bargein":"true",]
      },
         "brain_id":"c_22369_3",
 "actions":{
             "contentTypeaction":"TEXT_CONTENT_RICH",
  {
            "brain_id":"c_22369_3_1619889357a_34423",
               "usePreviousTextcommand":"falsemenu",

              "textcontent":"Choose an option",
            }
  "id":"a_34423_1259541208",
      ]       }"order":"1",
      "actions":{          "actionrunAt":{"-1",
            "brain_idtarget":"a_34423",
            "commandactions":"menu",{
               "contentaction":"",[
            "id":"a_34423_1259541208",      {
      "order":"1",               "runAtbrain_id":"-1a_34424",
            "target":"",             "actionscommand":{"load-item",
               "action":[                   {"content":"OPTION 1",
                      "brain_id":"a_34424_1211377995",
                     "commandorder":"load-item1",
                     "contentrunAt":"OPTION -1",
                     "idtarget":"aTEST_34424M_12113779951",
                     "ordernode_ref":"1",{
                        "runAtkey":"-TEST_M_1",
                        "targettargetUrl":"/enghouse-brain-bot/1/TEST_M_1",?referrerActionId=34424"
                     }
  "node_ref":{                },
         "key":"TEST_M_1",         {
                     "targetUrlbrain_id":"/enghouse-brain-bot/1/TEST_M_1?referrerActionId=34424"a_34425",
                     }"command":"load-item",
                  },     "content":"OPTION 2",
             {                      "brain_id":""id":"a_34425_308197190",
                     "commandorder":"load-item2",
                     "contentrunAt":"OPTION 2-1",
                     "idtarget":"aTEST_34425MENU_3081971902",
                     "ordernode_ref":"2",{
                        "runAtkey":"-1TEST_MENU_2",
                        "targettargetUrl":"TEST_/enghouse-brain-bot/1/TEST_MENU_2",?referrerActionId=34425"
                     }
        "node_ref":{          },
               "key":"TEST_MENU_2",   {
                     "targetUrlbrain_id":"/enghouse-brain-bot/1/TEST_MENU_2?referrerActionId=34425"a_34426",
                     }"command":"open-url",
                  },                   {"content":"PAT WEBSITE",
                     "brain_id":"a_34426_1665019718",
                     "commandorder":"open-url3",
                     "contentrunAt":"PAT WEBSITE-1",
                     "idtarget":"a_34426_1665019718https://www.pat.eu",
                     "orderparams":"3",{
                        "runAtparam":"-1",[
                       "target":"https://www.pat.eu",    {
                 "params":{             "name":"method",
           "param":[                   "text":"GET"
        {                   },
           "name":"method",                {
              "text":"GET"                            }"name":"where",
                           {   "text":"_blank"
                           "name":"where",}
                              "text":"_blank"
    ]
                      }
                        ]
                     }
                  }
               ]
            },
            "params":{
               "param":{
                  "name":"display",
                  "text":"v"
               }
            }
         }
      }
   }
}

Calling a specific node

Syntax:
HTTP GET http://{brain-host}:{port}/brain/autojson/{brain-service}/{node}

headers = {
cookie: <BRAINSID_SessionCookie>
};

Example

https://engagent-demo4.h-care.eu/brain/old/autojson/enghouse-brain-bot/1/TEST_M_1?referrerActionId=34424

Response:

Code Block
languagejson

{
   "node":{  }
               ]
          "brain_id":"n_22370",  },
    "brain_version":"5.10.0-SNAPSHOT",        "idparams":"n_22370_1287493518",{
        "key":"TEST_M_1",       "serviceNameparam":"enghouse-brain-bot",{
           "serviceVersion":"1",       "contentsname":{"display",
         "content":[         "text":"v"
   {            }
   "bargein":"true",         }
      "brain_id":"c_22370_3",   }
      }
     "contentType":"TEXT_CONTENT_RICH",
               "id":"c_22370_3_266538648",
               "usePreviousText":"false",
       }
}

Calling a specific node

This service must be called whenever it is specified by a previous response. For example, in the case of a menu, one of the options can specify a node url to be called in the "targetUrl" parameter if the option is chosen by the user.

Syntax:
HTTP GET {brainURL}/targetURL

headers = {
cookie: <BRAINSID_SessionCookie>
};

Example

https://engagent-demo4.h-care.eu/brain/old/autojson/enghouse-brain-bot/1/TEST_M_1?referrerActionId=34424

Response:

Code Block
languagejson

{
   "node":{
       "textbrain_id":"n_22370"Option,
1 selected"     "brain_version":"5.10.0-SNAPSHOT",
       }"id":"n_22370_1287493518",
      "key":"TEST_M_1",
     {
      "serviceName":"enghouse-brain-bot",
         "bargeinserviceVersion":"true1",
      "contents":{
         "brain_idcontent":"c_22370_1",[
               "contentType":"VIDEO",{
               "idbargein":"c_22370_1_962092860true",
               "usePreviousTextbrain_id":"false"
            }c_22370_3",
          ]       }"contentType":"TEXT_CONTENT_RICH",
    }
}

Redirect to operator

The human escalation is triggered by a redirect-to-operator action. It is possible to specify the target queue, the requested service level and skills.

Example

Code Block
languagejson
{    "node":{       "brain_id":"n_22357",c_22370_3_266538648",
               "brain_versionusePreviousText":"5.10.0-SNAPSHOTfalse",
               "idtext":"n_22357_1488672544",Option 1 selected"
             "key":"REDIRECT_TO_OPERATOR",}
       "serviceName":"enghouse-brain-bot",  ]
    "serviceVersion":"1",  }
    "contents":}
}

Redirect to operator

The human escalation is triggered by a redirect-to-operator action. It is possible to specify the target queue, the requested service level and skills.

Example

Code Block
languagejson
{
         "content":[
            {
    "node":{
          "bargein"brain_id":"truen_22357",
     
         "brain_idversion":"c_22357_2",
        5.10.0-SNAPSHOT",
      "contentTypeid":"READABLEn_22357_PLAIN1488672544",
      "key":"REDIRECT_TO_OPERATOR",
        "idserviceName":"c_22357_2_942788559enghouse-brain-bot",
        "serviceVersion":"1",
      "usePreviousTextcontents":"false"{
         "content":[
  },             {
               "bargein":"true",
               "brain_id":"c_22357_12",
               "contentType":"VIDEOREADABLE_PLAIN",
               "id":"c_22357_12_506882387942788559",
               "usePreviousText":"false"
            },
            {
               "bargein":"true",
               "brain_id":"c_22357_3",
               "contentType":"TEXT_CONTENT_RICH",
               "id":"c_22357_3_1607223715",
               "usePreviousText":"false",
               "text":"<div><b>Ti sto mettendo in contatto con un operatore, un attimo di pazienza...</b></div><div><br></div>"
            }
         ]
      },
      "params":{
         "param":{
            "name":"isPlayerVisible",
            "text":"true"
         }
      },
      "actions":{
         "action":{
            "brain_id":"a_34422",
            "command":"redirect-to-operator",
            "content":"",
            "id":"a_34422_891966757",
            "order":"1",
            "runAt":"-1",
            "target":"",
            "params":{
               "param":[
                  {
                     "name":"skills",
                     "text":"ENGLISH,ITALIAN"
                  },
                  {
                     "name":"serviceLevel",
                     "text":"GOLD"
                  },
                  {
                     "name":"queue",
                     "text":"QUEUE1"
                  }
               ]
            }
         }
      }
   }
}