Common errors in Virtual Agent API
Summarize
Summary of Common errors in Virtual Agent API
This guide highlights frequent errors encountered when using the Virtual Agent API in ServiceNow Zurich release and provides practical resolutions. It focuses on the required request structure, file upload methods, and user linking challenges to help ensure smooth API integrations and effective Virtual Agent interactions.
Show less
Virtual Agent API Request Structure
The API expects a JSON request with specific fields. Of these, userId and message.text are mandatory to process requests correctly. Other fields such as requestId, clientSessionId, emailId, and various context or client variables are optional but help enrich the conversation context and user identification.
File Upload Handling
The Virtual Agent API supports two modes of file upload:
- Synchronous Mode: Upload files first through the Media API, which returns a media URL. Use this URL in your Virtual Agent API request to attach the file.
- Asynchronous Mode: Use an accessible file URL directly in the API request. This can be a public URL or a protected URL that includes authentication headers for secure access.
Key file upload parameters include contentType (MIME type), fileName, url for file access, and optionally clientAttachmentId and headers for authentication when needed.
User Linking Requirements and Troubleshooting
Automatic user linking is enabled by default but requires proper configuration and data consistency:
- Authentication: Message authentication must be correctly configured and active for linking to work.
- Required Request Fields: Both a unique userId and a valid emailId must be provided.
- User Records: The emailId must match exactly one active, unlocked user record in the sysuser table.
- Provider Configuration: The "VA Bot to Bot Provider" in syscsprovider must have automatic linking enabled with correct linkage scripts assigned.
- Provider User Map: Ensure no inactive records exist for the userId in the providerusermap table, as these block auto-linking.
- Customizations: Review any custom scripts affecting auto-link logic to prevent conflicts or additional validation errors.
Following these steps ensures reliable user identification and linking, avoiding common pitfalls like multiple users sharing the same email or inactive mapping records blocking linkage.
This section describes some common errors in Virtual Agent API and how they can be resolved.
Virtual Agent API structure validation
Request structure:
{
"requestId": "any-unique-request-id",
"clientSessionId": "any-unique-session-id",
"userId": "any-unique-user-id",
"emailId": "user@example.com",
"action": "",
"message": {
"text": "User message text",
"typed": true
},
"contextVariables": {},
"history": [
{
"isBotMessage": true,
"value": "How can I help you?",
"displayName": "Bot",
"type": "text"
}
],
"clientVariables": {
"id": "va-bot-12345",
"timestamp": "1687527831786"
}
}| Field | Required | Description |
|---|---|---|
requestId |
No | Pass-through variable returned in responses |
clientSessionId |
No | Pass-through session identifier |
userId |
Yes | Unique user identifier (mandatory) |
emailId |
No* | User email for linking (*required for user linking) |
action |
No | Optional action parameter |
message.text |
Yes | User message content (mandatory) |
message.typed |
No | true for search text, false for value selection |
contextVariables |
No | Optional context data |
history |
No | Bot conversation history (first request only) |
clientVariables |
No | Pass-through client variables |
File upload issues
Virtual Agent API supports two file upload modes, such as Synchronous and Asynchronous.
File upload request structure:
{
"userId": "{{user_id}}",
"message": {
"attachment": {
"clientAttachmentId": "{{request_id}}",
"contentType": "video/mp4",
"fileName": "sample.mp4",
"url": "https://sample-videos.com/video123/mp4/720/big_buck_bunny_720p_1mb.mp4",
"headers": {
"header 1": "value 1"
}
},
"text": "along with text",
"typed": true
}
}
| Field | Required | Description |
|---|---|---|
contentType |
Yes | MIME type (e.g., video/mp4, image/png) |
fileName |
Yes | Name of the file with extension |
url |
Yes | Accessible URL to download the file |
clientAttachmentId |
No | Unique identifier for tracking |
headers |
No | Authentication headers for file download |
File upload in synchronous mode:
- Upload the file by using Media API. For more information, see CCCIF Media Resource API.Media API returns a url. An example of the response is:
{ "result": { "mediaUrl": "<instance>/api/now/v1/cs/media/JOBBfkqSq6kDiFzxyinvHhke73O4TZ0j", "name": "image.png", "state": "available", "attachmentId": "e8671b9193209210a755b8e86cba104b" } } - Use the media url in Virtual Agent API request. A JSON example is:
{ "userId": "user123", "message": { "attachment": { "contentType": "image/png", "fileName": "image.png", "url": "<instance>/api/now/v1/cs/media/JOBBfkqSq6kDiFzxyinvHhke73O4TZ0j" }, "text": "Here is the image", "typed": true } }
File upload in asynchronous mode:
- Use the file url in the Virtual Agent API request.
- Direct file url:
{ "userId": "user123", "message": { "attachment": { "contentType": "application/pdf", "fileName": "report.pdf", "url": "https://publicserver.com/files/report.pdf" }, "text": "Document attached", "typed": true } } - Protected file url:
{ "userId": "user123", "message": { "attachment": { "contentType": "application/pdf", "fileName": "confidential.pdf", "url": "https://secureserver.com/files/confidential.pdf", "headers": { "Authorization": "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...", "X-Custom-Header": "custom-value" } }, "text": "Secure document attached", "typed": true } }
- Direct file url:
- Using the Media API (as followed in synchronous mode).
User linking issues
Virtual Agent API supports automatic user linking by default. Manual linking is not enabled by default in Virtual Agent API.
- Message Auth is mandatory.
- Without message auth in
sys_cs_provider_application, user linking doesn't work. - You must configure Message auth properly. (See the authentication section.)
- Without message auth in
- Required request fields.
userIdmust be present and unique.emailIdmust be present and valid.
User record requirements:
emailId must match a sys_user record that meets all of the following conditions:- Record exists in the
sys_usertable. - Email field matches exactly.
- User is active. (
active=true) - User is not locked out. (
locked_out=false) - Only one user record matches these conditions.
- Verify the provider configuration.
- Navigate to the
sys_cs_providertable and open the "VA Bot to Bot Provider" record. -
Table 3. Required setting Field Expected Value automatic_link_enabledtrueautomatic_link_actionsn_va_as_service.virtual_agent__bot_to_bot_auto_link_accountlink_account_enabledtrue
- Navigate to the
- Check the provider user map.
- Navigate to the
provider_user_maptable. - Filter by:
active=falseANDchannel_user_id={userId from request}. - Issue: If record exists with
active=false, the user cannot be linked automatically. - Solution: User who has the admin role must manually delete the inactive record and retry the linking request.
- Navigate to the
- Check for customizations.
- Review customizations by running the
sn_va_as_service.virtual_agent__bot_to_bot_auto_link_accountscript. - Check for the common customization issues:
- Logic preventing automatic linking
- Additional validation checks
- Modified field mappings
- Review customizations by running the
Checklist for user linking troubleshooting
- Configuration:
- Message auth exists and is active.
userIdis present in request.emailIdis present in request.automatic_link_enabled = trueautomatic_link_actionpoints to correct script.link_account_enabled = true
- User record:
- User exists in
sys_user. - Email matches exactly (case-sensitive).
- User is active.
- User is not locked out.
- Only one user matches the email.
- User exists in
- Provider user map:
- No inactive records for this
userId. - Check for duplicate mappings.
- No inactive records for this
- Customizations:
- Review auto-link script for modifications.
- Test with default script if customized.