How can we help?
{{docApp.searchError}}
                                    
                                                    {{product.name}} 
                                                
 
                                                Searching in {{docApp.searchFilterBySpecificBookTitle}}
                                                    {{docApp.searchResultFilteredItems.length}} results for: {{docApp.currentResultsSearchText}} 
                                                    in {{docApp.searchFilterBySpecificBookTitle}}
                                                    Search results have been limited. There are a total of {{docApp.searchResponse.totalResultsAvailable}} matches. 
                                                
                                                You have an odd number of " characters in your search terms - each one needs closing with a matching " character!
                                            - 
                                                    {{resultItem.title}}{{resultItem.url}}
{{docApp.libraryHomeViewProduct.title || docApp.libraryHomeViewProduct.id}}
{{docApp.libraryHomeViewProduct.description}}
{{group.title || group.id}}
{{group.description}}
Operation Information
- Application Reference: com.hornbill.servicemanager
- Scope: Global
- Class: Application
- Required Privilege Level: user
- Required Rights: Group H - executeSystemAPIs
Description
This operation returns published bulletins for services that teh user specified has access to. For use with chatbot integrations.
Request Parameters
The chatbotGetServiceBulletins API takes the following input parameters.
Note
When sending a JSON request payload to the API, the order of parameters is not significant. However, for XML request payloads, parameters must be provided in the exact order specified in this documentation to comply with input validation requirements.
| Name | Type | Required | Description | 
|---|---|---|---|
| userId | xs:string | Yes | The chatbot session user ID | 
Response Parameters
| Name | Type | Description | 
|---|---|---|
| totalRecordCount | xs:integer | The total number of service bulletins that match the search criteria. | 
| serviceBulletinsData | xs:string | This parameter returns the service bulletins data as a JSON object | 
| error | xs:string | This parameter is set with validation errors. | 
Code Examples
      curl -X POST 'https://api.hornbill.com/yourinstanceid/xmlmc/apps/com.hornbill.servicemanager' \
   -H 'Authorization: ESP-APIKEY yourHornbillAPIKey' \
   -H 'Content-Type: application/json' \
   -d '{"@service":"apps/com.hornbill.servicemanager","@method":"chatbotGetServiceBulletins","params":{"userId":"xs:string"}}'
    
        package main
import (
    "fmt"
    apiLib "github.com/hornbill/goApiLib"
)
func main() {
	hornbillAPI := apiLib.NewXmlmcInstance("yourinstanceid")
	hornbillAPI.SetAPIKey("yourHornbillAPIKey")
	hornbillAPI.SetJSONResponse(true)
	hornbillAPI.SetParam("userId", "xs:string")
	responseBody, apiError := hornbillAPI.Invoke("apps/com.hornbill.servicemanager", "chatbotGetServiceBulletins")
	if apiError != nil {
		fmt.Println(apiError)
		return
	}
	fmt.Println(responseBody)
}
    
        const endpoint = "https://api.hornbill.com/yourinstanceid/xmlmc/apps/com.hornbill.servicemanager";
const payload = {
  "@service": "apps/com.hornbill.servicemanager",
  "@method": "chatbotGetServiceBulletins",
  "params": {
    "userId": "xs:string"
  }
};
fetch(endpoint, {
  method: 'POST',
  headers: {
    "Authorization": "ESP-APIKEY yourHornbillAPIKey"
  },
  body: JSON.stringify(payload)
}).then(res => res.json())
  .then(res => console.log(res));
    
        const axios = require('axios');
const endpoint = "https://api.hornbill.com/yourinstanceid/xmlmc/apps/com.hornbill.servicemanager";
const payload = {
  "@service": "apps/com.hornbill.servicemanager",
  "@method": "chatbotGetServiceBulletins",
  "params": {
    "userId": "xs:string"
  }
};
const axiosConfig = {
  headers: {
    "Authorization": "ESP-APIKEY yourHornbillAPIKey"
  }
};
axios.post(endpoint, payload, axiosConfig)
.then((res) => {
    console.log("RESPONSE RECEIVED: ", res);
})
.catch((err) => {
    console.log("AXIOS ERROR: ", err);
})
    
        $endpoint = "https://api.hornbill.com/yourinstanceid/xmlmc/apps/com.hornbill.servicemanager";
$payload = (object) [
    '@service' => 'apps/com.hornbill.servicemanager',
    '@method' => 'chatbotGetServiceBulletins',
    'params' => (object) [
        'userId' => 'xs:string',
    ]
];
$headers = [
    'Authorization: ESP-APIKEY yourHornbillAPIKey',
    'Content-Type: application/json'
];
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_URL, $endpoint);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($payload));
curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
$resp = curl_exec($curl);
curl_close($curl);
echo $resp;
    
        $Endpoint = "https://api.hornbill.com/yourinstanceid/xmlmc/apps/com.hornbill.servicemanager"
$Body = @{
	"@service" = "apps/com.hornbill.servicemanager"
	"@method" = "chatbotGetServiceBulletins"
	params = @{
		userId = "xs:string"
	}
}
$Header = @{
	"Authorization" = "ESP-APIKEY yourHornbillAPIKey"
}
$Parameters = @{
	Method      = "POST"
	Uri         = $Endpoint
	Headers     = $Header
	Body        = ($Body | ConvertTo-Json)
	ContentType = "application/json"
}
Invoke-RestMethod @Parameters
    
        import requests
import json
endpoint = "https://api.hornbill.com/yourinstanceid/xmlmc/apps/com.hornbill.servicemanager"
headers = {   
    "Authorization": "ESP-APIKEY yourHornbillAPIKey"
}
payload={
        "@service":"apps/com.hornbill.servicemanager",
        "@method":"chatbotGetServiceBulletins",
        "params":{
            "userId":"xs:string",
        },
}
response = requests.request("POST", endpoint, json=payload, headers=headers)
print(response.text)
    
  - Version {{docApp.book.version}}
- Node {{docApp.node}} / {{docApp.build}}
                                            
                                                 
                                            
                                            In This Document