Agent and Engagement Events
Agent and Engagement Events 1.0.1 documentation
Contact Center Agent and Engagement events are available for the streaming needs of client applications via websockets. The Notification API facilitates subscribing to different families of events and transport protocols (Websockets and Webhooks). Agent & Engagement are one of these available families.
This following focuses on the websocket implementation of Agent and Engagement events.
Create Subscription
The example provided below will create a subscription for a WebSocket stream of Agent & Engagement events. Upon a successful response a transport endpoint URL will be provided for the WebSocket interface to connect and begin consuming events from.
  POST https://{{CCaaS_FQDN}}/api/notification/v1/accounts/{accountId}/subscriptions
  Content-Type: application/json
  Accept: application/json
  Header: Authorization: Bearer {{token}}
Request Body:
    {
      "family": "AGENT_ENGAGEMENT",
      "events": ["ALL"],
      "transport": {
        "type": "WEBSOCKET"
      }
    }
Response:
    {
      "subscriptionId": "fdbec917-e76e-4645-8120-4eac46f29487",
      "createdAt": "2020-08-01T14:25:23.162Z",
      "expiresAt": "2020-08-01T15:25:23.177Z",
      "expiresIn": 900,
      "status": "ACTIVE",
      "family": "AGENT_ENGAGEMENT",
      "events": [
        "ALL"
      ],
      "transport": {
        "type": "WEBSOCKET",
        "endpoint": "wss://uk.cc.avayacloud.com/ws/notification/v1/agent-engagement",
        "pingInterval": 300
      }
    }
As you have seen above agent and engagement events are subscribed to via the Notification API. In choosing WEBSOCKET as the transport option these events are then consumed through a WebSocket connection. The events are contained within JSON that makes up the payload of the WebSocket messages.
The following section shows how to use the Websocket interface.
Table of Contents
Servers
production Server
| URL | Protocol | Description | 
|---|---|---|
| wss://{server}:{port}/ws/notification | wss | After connection to the websocket a new session is created. | 
URL Variables
| Name | Default value | Possible values | Description | 
|---|---|---|---|
| server | HOST-REGION.avayacloud.com | Any | - | 
| port | 443 | 443 | Secure connection (TLS) is available through port 443. | 
Security Requirements
| Type | In | Name | Scheme | Format | Description | 
|---|---|---|---|---|---|
| oauth2 | - | - | - | - | - | 
Channels
/v1/agent-engagement Channel
publish Operation
publish OperationUpon creating a subscription and connecting to the WebSocket endpoint you will need to send a message to the server confirming you are authenticated before any notification events will be sent. This token must be obtained from the A&A service.
NOTE: For further details and code examples please refer to: How to Authenticate with Avaya Experience Platform™ APIs
Accepts one of the following messages:
Message authentication
authenticationThe first message the client should send to server after establishing the connection must be an authentication message.
Payload
| Name | Type | Description | Accepted values | 
|---|---|---|---|
| event (required) | string | authentication - A constant parameter. | Any | 
| subscriptionId (required) | string | The unique id of the subscription. | Any | 
| token (required) | string | The access token string as issued by the authorization server. | Any | 
Examples of payload (generated)
{
  "event": "authentication",
  "subscriptionId": "fdbec917-e76e-4645-8120-4eac46f29487",
  "token": "7e0cd42a22b451701fg29c3bde214…"
}
Tags
- Authentication
Message ping
pingClient must send ping to the server in order to determine whether connection is alive, server responds with pong.
The ping is also used to keep the websocket connection alive, by keep sending ping messages every pingInterval time to the server.
It is recommended the client send ping more frequently (every 30 seconds) to preclude any proxies from closing the connection.
Payload
| Name | Type | Description | Accepted values | 
|---|---|---|---|
| event (required) | string | ping - A constant parameter. | Any | 
| subscriptionId | string | Optional. The id of the subscription. | Any | 
Examples of payload
pingMessage
Example of an ping message to server.
{
  "event": "ping"
}
Tags
- Heartbeat
subscribe Operation
subscribe OperationNotification messages that you receive from the server
Accepts one of the following messages:
Message notification
notificationNotification event consumed over the WebSocket connection
Specification
This Async Specification details all the Agent and Engagement Events and structure
asyncapi: 2.1.0
info:
  title: Agent and Engagement Events
  version: 1.0.2
  description: >
    Contact Center Agent and Engagement events are available for the streaming needs of client applications via websockets. The Notification API facilitates subscribing to different families of events and transport protocols (Websockets and Webhooks). Agent & Engagement are one of these available families.
    This following focuses on the websocket implementation of Agent and Engagement events.
    ### Create Subscription
    The example provided below will create a subscription for a WebSocket
    stream of Agent & Engagement events. Upon a successful response a
    transport endpoint URL will be provided for the WebSocket interface to
    connect and begin consuming events from.
    ```
      POST https://{{CCaaS_FQDN}}/api/notification/v1/accounts/{accountId}/subscriptions
      Content-Type: application/json
      Accept: application/json
      Header: Authorization: Bearer {{token}}
    ```
      Request Body:
    ```json
        {
          "family": "AGENT_ENGAGEMENT",
          "events": ["ALL"],
          "transport": {
            "type": "WEBSOCKET"
          }
        }
    ```
      Response:
    ```json
        {
          "subscriptionId": "fdbec917-e76e-4645-8120-4eac46f29487",
          "createdAt": "2020-08-01T14:25:23.162Z",
          "expiresAt": "2020-08-01T15:25:23.177Z",
          "expiresIn": 900,
          "status": "ACTIVE",
          "family": "AGENT_ENGAGEMENT",
          "events": [
            "ALL"
          ],
          "transport": {
            "type": "WEBSOCKET",
            "endpoint": "wss://uk.cc.avayacloud.com/ws/notification/v1/agent-engagement/DYNNUG/fdbec917-e76e-4645-8120-4eac46f29487",
            "pingInterval": 300
          }
        }
    ```
    As you have seen above agent and engagement events are subscribed to via the
    Notification API. In choosing WEBSOCKET as the transport option these
    events are then consumed through a WebSocket connection. The events are
    contained within JSON that makes up the payload of the WebSocket messages.
    The following section shows how to use the Websocket interface.
  contact:
    name: Avaya API Team
    url: 'https://developers.avayacloud.com/onecloud-ccaas'
    email: [email protected]
  license:
    name: Avaya Software Development Kit (SDK) Software License Terms
    url: 'http://support.avaya.com/css/P8/documents/101038288'
tags:
  - name: Agent and Engagement Data
    description: >
      Realtime notification events are subscribed to via the Agent and Engagement API. The events are contained within JSON that makes up the payload of the WebSocket messages.
  - name: Heartbeat
    description: >
      Websocket messages used for heartbeat.
  - name: Authentication
    description: >
      Authentication related messages.
servers:
  production:
    url: wss://{server}:{port}/ws/notification
    protocol: wss
    description: |
      After connection to the websocket a new session is created.
    security:
      - apiKey: []
    variables:
      server:
        default: HOST-REGION.avayacloud.com
      port:
        description: Secure connection (TLS) is available through port 443.
        default: '443'
        enum:
          - '443'
defaultContentType: application/json
channels:
  /v1/agent-engagement:
    publish:
      description: >
        Upon creating a subscription and connecting to the WebSocket endpoint
        you will need to send a message to the server confirming you are
        authenticated before any notification events will be sent.  This token
        must be obtained from the A&A service.
        **NOTE:**  For further details and code examples please refer to:
        https://developers.avayacloud.com/onecloud-ccaas/docs/how-to-authenticate-with-ccaas-apis#acquiring-tokens
      operationId: authenticationMessage
      message:
        oneOf:
          - $ref: '#/components/messages/authentication'
          - $ref: '#/components/messages/ping'
    subscribe:
      description: Notification messages that you receive from the server
      operationId: notificationMessage
      message:
        oneOf:
          - $ref: '#/components/messages/notification'
          - $ref: '#/components/messages/pong'
          - $ref: '#/components/messages/authenticationResponse'
components:
  messages:
    authentication:
      name: authentication
      title: Authentication Message
      description: The first message the client should send to server after establishing the connection must be an authentication message.
      contentType: application/json
      tags:
        - name: Authentication
      payload:
        $ref: '#/components/schemas/Authentication'
      x-response:
        $ref: '#/components/schemas/AuthenticationResponse'
    notification:
      name: notification
      title: Agent and Engagement Message
      description: Notification event consumed over the WebSocket connection
      contentType: application/json
      tags:
        - name: Agent and Engagement Data
      payload:
        $ref: '#/components/schemas/Notification'
    ping:
      description: |
        Client must send ping to the server in order to determine whether connection is alive, server responds with pong.
        The ping is also used to keep the websocket connection alive, by keep sending _ping_ messages every _pingInterval_ time to the server.
        It is recommended the client send ping more frequently (every 30 seconds) to preclude any proxies from closing the connection.
      tags:
        - name: Heartbeat
      payload:
        $ref: '#/components/schemas/Ping'
      examples:
        - name: pingMessage
          summary: Example of an ping message to server.
          payload:
            event: 'ping'
    pong:
      description: Server pong response to a ping message.
      tags:
        - name: Heartbeat
      payload:
        $ref: '#/components/schemas/Pong'
      examples:
        - name: pongMessage
          summary: Example of a pong message to client.
          payload:
            event: 'pong'
    authenticationResponse:
      description: Authentication response message sent to the client after websocket authentication.
      tags:
        - name: Authentication
      payload:
        $ref: '#/components/schemas/AuthenticationResponse'
  schemas:
    Authentication:
      type: object
      additionalProperties: false
      properties:
        event:
          description:  authentication - A constant parameter.
          type: string
          const: authentication
        subscriptionId:
          type: string
          description: The unique id of the subscription.
        token:
          type: string
          description: The access token string as issued by the authorization server.
      required:
        - event
        - subscriptionId
        - token
      example:
        event: authentication
        subscriptionId: fdbec917-e76e-4645-8120-4eac46f29487
        token: 7e0cd42a22b451701fg29c3bde214…
    AuthenticationResponse:
      type: object
      additionalProperties: false
      properties:
        event:
          description:  authenticationResponse - A constant parameter.
          type: string
          const: authenticationResponse
        status:
          type: string
          enum:
            - CONNECTION_CONFIRMED
            - CONNECTION_FAILED_INVALID_TOKEN
            - CONNECTION_FAILED_UNKNOWN_SUBSCRIPTION
            - CONNECTION_FAILED_INTERNAL_SERVER_ERROR
            - CONNECTION_FAILED_CONSTRAINT_VIOLATION
          description: |
            You will then receive 1 of 5 statuses:
              - CONNECTION_CONFIRMED: Connection was confirmed
              - CONNECTION_FAILED_INVALID_TOKEN: Authentication token is invalid
              - CONNECTION_FAILED_UNKNOWN_SUBSCRIPTION: Unknown Subscription, can be for a subscription that never existed or one that is no longer active
              - CONNECTION_FAILED_INTERNAL_SERVER_ERROR: Server Error, client can retry later
              - CONNECTION_FAILED_CONSTRAINT_VIOLATION: Client issue, malformed client request, client must update payload and rerty
        subscriptionId:
          type: string
          description: The unique id of the subscription.
        pingInterval:
          type: integer
          format: int64
          description: |
            The maximum interval (seconds) at which a ping is expected to be sent by the client before websocket is closed and subscription set to INACTIVE.
            It is recommended the client send ping more frequently (every 30 seconds) to preclude any proxies from closing the connection.
        expiresInterval:
          type: integer
          format: int64
          description: Expiration interval in seconds before the subscription is set to INACTIVE.
      example:
        event: authenticationResponse
        status: CONNECTION_CONFIRMED
        subscriptionId: fdbec917-e76e-4645-8120-4eac46f29487
        pingInterval: 300
        expiresInterval: 900
    Notification:
      type: object
      additionalProperties: false
      properties:
        correlationId:
          type: string
          description: The unique ID of the notification being sent
        subscriptionId:
          type: string
          description: The unique ID of the Agent and Engagement subscription
        family:
          type: string
          description: The family of events the subscription is for
        sentAt:
          type: string
          description: Datetime (in ISO 8601 format) of when the notification event was sent
          format: datetime
        accountId:
          type: string
          description: >-
            The unique identifier for the Account.
        loginId:
          description: >
            The unique login handle for the Agent.
            *NOTE* Only present on Agent related events
          type: string
        initiatingLoginId:
          description: >
            The unique login handle for the Agent initiating a transfer.
            *NOTE* Only present on Single Step Transfer related events
          type: string
        destinationLoginId:
          description: >
            The unique login handle for the Agent the transfer is being made to.
            *NOTE* Only present on Single Step Transfer to User related events
          type: string
        observedLoginId:
          description: >
            The unique login handle for the observed Agent.
            
            *NOTE* Only present on Agent Participant Observing related events
          type: string
        observingLoginId:
          description: >
            The unique login handle for the observing Supervisor.
            
            *NOTE* Only present on Agent Participant Observing related events
          type: string
        coachedLoginId:
          description: >
            The unique login handle for the coached Agent.
            
            *NOTE* Only present on Agent Participant Coaching related events
          type: string
        coachingLoginId:
          description: >
            The unique login handle for the coaching Supervisor.
            
            *NOTE* Only present on Agent Participant Coaching related events
          type: string
        bargingLoginId:
          description: >
            The unique login handle for the barging Supervisor.
            
            *NOTE* Only present on Agent Participant Barged related events
          type: string
        body:
          $ref: '#/components/schemas/NotificationBody'
      example:
        correlationId: a425851d-5225-4b76-8ca0-4fa31ecfd5db
        subscriptionId: fdbec917-e76e-4645-8120-4eac46f29487
        family: AGENT_ENGAGEMENT
        sentAt: "2020-08-24T08:20:23.395Z"
        accountId: DYNNUG
        loginId: [email protected]
        body:
          event: AgentState
          agentId: 4a785201-73b8-4842-abf7-36f5e572d310
          profileId: HomeProfile
          state: NOT_READY
          reasonCode: 514
          cause: RONA
          id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
          timestamp: 9223372036854776000
    NotificationBody:
      type: object
      discriminator: event
      description: The raw event payload that will be different based on the event.
      properties:
        event:
          type: string
          description: The name of the specific event being sent. For instance AgentState, AgentParticipant, InboundEngagementCreated, etc...
      oneOf:
        - $ref: '#/components/schemas/AgentState'
        - $ref: '#/components/schemas/AgentParticipant'
        - $ref: '#/components/schemas/AutomationParticipant'
        - $ref: '#/components/schemas/ExternalParticipant'
        - $ref: '#/components/schemas/EngagementPrerouted'
        - $ref: '#/components/schemas/InboundEngagementCreated'
        - $ref: '#/components/schemas/MatchOffered'
        - $ref: '#/components/schemas/OutboundEngagementCreated'
        - $ref: '#/components/schemas/SingleStepTransfer'
        - $ref: '#/components/schemas/SingleStepTransferError'
        - $ref: '#/components/schemas/ChannelReady'
        - $ref: '#/components/schemas/AfterContactWorkActivated'
        - $ref: '#/components/schemas/AfterContactWorkCompleted'
    AgentState:
      type: object
      additionalProperties: false
      properties:
        agentId:
          $ref: '#/components/schemas/AgentId'
        profileId:
          type: string
          description: >-
            The profile ID used to login the agent.  The profile
            indicates what channels should be logged in.
        state:
          type: string
          description: >-
            The current state of the agent.
          enum:
            - LOGGED_IN
            - LOGGED_OUT
            - READY
            - NOT_READY
        reasonCode:
          type: string
          description: The reason code for going not ready. Only for AGENT_NOT_READY state
        cause:
          type: string
          description: The cause of the agent not being ready. Only for AGENT_NOT_READY state
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        agentId: 4a785201-73b8-4842-abf7-36f5e572d310
        profileId: HomeProfile
        state: NOT_READY
        reasonCode: 514
        cause: RONA
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    AgentParticipant:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        action:
          type: string
          description: >-
            The agent participant action
          enum:
            - ADDED
            - HELD
            - UNHELD
            - INVITED
            - REMOVED
            - MOVED
            - OBSERVING
            - COACHING
            - BARGEDIN
        agentId:
          $ref: '#/components/schemas/AgentId'
        previousDialogId:
          type: string
          description: The unique identifier for the previous dialog the agent was a part of. Only for MOVED action
        dialogId:
          $ref: '#/components/schemas/DialogId'
        extension:
          $ref: '#/components/schemas/Extension'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        providerEngagementId:
          $ref: '#/components/schemas/ProviderEngagementId'
        agentInitiatedDisconnect:
          type: boolean
          description: An indication if the agent initiated disconnect from the dialog. Only for REMOVED action
        observedAgentId:
          type: string
          description: The unique identifier for the observed agent. Only for OBSERVING action
        observingAgentId:
          type: string
          description: The unique identifier for the observing agent. Only for OBSERVING action
        observingAgentConnectionId:
          type: string
          description: The unique identifier for this appearance of the observing participant on this engagement. Only for OBSERVING action
        observedAgentConnectionId:
          type: string
          description: The unique identifier for this appearance of the participant already on this engagement. Only for OBSERVING action
        coachingAgentId:
          type: string
          description: The unique identifier for the coaching agent. Only for COACHING action
        coachedAgentId:
          type: string
          description: The unique identifier for the coached agent. Only for COACHING action
        coachingAgentConnectionId:
          type: string
          description: The unique identifier for this appearance of the coaching participant on this engagement. Only for COACHING action
        coachedAgentConnectionId:
          type: string
          description: The unique identifier for this appearance of the participant already on this engagement. Only for COACHING action
        bargingAgentId:
          type: string
          description: The unique identifier for the barging in agent. Only for BARGEDIN action
        bargingAgentConnectionId:
          type: string
          description: the unique identifier for this appearance of the participant barging in to this engagement. Only for BARGEDIN action
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        connectionId: b2bcbf1e-905b-4164-bab5-6efcde49933b
        action: ADDED
        agentId: 4a785201-73b8-4842-abf7-36f5e572d310
        dialogId: 01005000281645486013
        extension: 8010017
        channelId: Voice
        providerEngagementId: 00001084011532384922
        agentInitiatedDisconnect: false
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    AutomationParticipant:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        automationParticipantId:
          $ref: '#/components/schemas/AutomationParticipantId'
        action:
          type: string
          description: >-
            The automation participant action
          enum:
            - ADDED
            - REMOVED
        dialogId:
          $ref: '#/components/schemas/DialogId'
        automationType:
          $ref: '#/components/schemas/AutomationType'
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        providerEngagementId:
          $ref: '#/components/schemas/ProviderEngagementId'
        automationInitiatedDisconnect:
          $ref: '#/components/schemas/AutomationInitiatedDisconnect'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        automationParticipantId: AvayaVoiceIVR
        action: ADDED
        dialogId: 01005000281645486013
        automationType: SELF_SERVICE
        connectionId: d2775626-66d4-459b-8147-09ea4b98c370
        channelId: Voice
        providerEngagementId: 00001084011532384922
        automationInitiatedDisconnect: false
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    ExternalParticipant:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        externalParticipantId:
          $ref: '#/components/schemas/ExternalParticipantId'
        action:
          type: string
          description: >-
            The external participant action
          enum:
            - ADDED
            - REMOVED
            - INVITED
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        providerEngagementId:
          $ref: '#/components/schemas/ProviderEngagementId'
        externalParticipantInitiatedDisconnect:
          type: boolean
          description: An indication if the external participant (aka the Customer) initiated disconnect from the dialog
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        externalParticipantId: +35395554321
        action: ADDED
        connectionId: b2bcbf1e-905b-4164-bab5-6efcde49933b
        dialogId: 01005000281645486013
        channelId: Voice
        providerEngagementId: 00001084011532384922
        externalParticipantInitiatedDisconnect: true
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    EngagementPrerouted:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        orchestrationFlow:
          $ref: '#/components/schemas/OrchestrationFlow'
        attributes:
          $ref: '#/components/schemas/Attributes'
        attributeList:
          type: array
          description: >
            A simplified flat list of attributes
            *NOTE* this flat array of attributes will help to easily identify “System.Outbound” to represent a POM call
          items:
            type: string
        engagementParameters:
          $ref: '#/components/schemas/EngagementParameters'
        agentRoutingStrategy:
          $ref: '#/components/schemas/AgentRouting'
        adhocEmail:
          type: boolean
          description: Flag to determine if adhoc email or not (email routing only)
        autoResponse:
          type: string
          description: The auto response suggested to be used
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        channelIdentifier:
          type: string
          description: The channel identifier of the engagement
        queue:
          type: object
          additionalProperties: false
          description: The queue details
          properties:
            queueId:
              type: string
              description: The unique identifier of the queue
            queueName:
              type: string
              description: The name of the queue
            priority:
              type: integer
              description: The priority of the queue
            proficiencyRangeMin:
              type: integer
              description: The minimum proficiency of the queue
            proficiencyRangeMax:
              type: integer
              description: The maximum proficiency of the queue
        customerIdentifiers:
          $ref: '#/components/schemas/CustomerIdentifiers'
        externalParticipantId:
          $ref: '#/components/schemas/ExternalParticipantId'
        sourceAddress:
          type: string
          description: The source address of the external participant, e.g. calling number or customer email
        destinationAddress:
          $ref: '#/components/schemas/DestinationAddress'
        subject:
          type: string
          description: The subject field of the incoming email
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        dialogId: 01005000281645486013
        orchestrationFlow: OneCloud Voice Outbound
        attributes:
          category: Language
          values:
            - English
        attributeList:
          - System.Outbound
        engagementParameters:
          language: en
        adhocEmail: false
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        channelIdentifier: Voice
        queue:
          queueId: 6d1490d5-7886-417d-ac85-fb0825d53a93
          queueName: Default
          priority: 5
          proficiencyRangeMin: 1
          proficiencyRangeMax: 1
        externalParticipantId: +35395554321
        sourceAddress: +35395554321
        destinationAddress: +12125554321
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    InboundEngagementCreated:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        externalParticipantId:
          $ref: '#/components/schemas/ExternalParticipantId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        callingNumber:
          type: string
          description: The calling number of the external participant
        dialledNumber:
          type: string
          description: The original dialed number for the engagement
        channelId:
          $ref: '#/components/schemas/ChannelId'
        customerIdentifiers:
          $ref: '#/components/schemas/CustomerIdentifiers'
        providerEngagementId:
          $ref: '#/components/schemas/ProviderEngagementId'
        engagementParameters:
          $ref: '#/components/schemas/EngagementParameters'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        connectionId: d2775626-66d4-459b-8147-09ea4b98c370
        externalParticipantId: +35395554321
        dialogId: 01005000281645486013
        callingNumber: +15551235555
        dialledNumber: +18005555555
        channelId: Voice
        providerEngagementId: 00001084011532384922
        engagementParameters:
          language: en
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    MatchOffered:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        matchId:
          type: string
          description: The unique identifier for this match
        correlationId:
          type: string
          description: The correlation Id from the original match request (can be ignored)
        strategy:
          type: string
          description: >-
            The agent selection strategy used for this match (values include
            MOST_IDLE or OCCUPANCY)
          enum:
            - MOST_IDLE
            - OCCUPANCY
        offeredQueue:
          $ref: '#/components/schemas/OfferedQueue'
        offeredService:
          $ref: '#/components/schemas/OfferedService'
        offeredSpecifiedAgent:
          $ref: '#/components/schemas/OfferedSpecifiedAgent'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        matchId: 43dc4b96-dfd6-438c-867e-a0d032e1e0a6
        correlationId: 1682f876-f7b7-4347-accd-495cae95f860
        strategy: MOST_IDLE
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    OutboundEngagementCreated:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        agentId:
          $ref: '#/components/schemas/AgentId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        destinationAddress:
          $ref: '#/components/schemas/DestinationAddress'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        customerIdentifiers:
          $ref: '#/components/schemas/CustomerIdentifiers'
        engagementParameters:
          $ref: '#/components/schemas/EngagementParameters'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        agentId: zz3tDKfrQx-Mv78Q_AIpGG
        dialogId: 01005000281645486013
        destinationAddress: +12125554321
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        engagementParameters:
          language: en
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    SingleStepTransfer:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        initiatingAgentId:
          $ref: '#/components/schemas/InitiatingAgentId'
        transferTo:
          type: string
          description: >-
            The type of the transfer
          enum:
            - QUEUE
            - USER
            - AUTOMATION
            - EXTERNAL
        destination:
          type: string
          description: >-
            Contains different values accordingly to transferTo:
            - If transferTo is QUEUE, then returns the queueId
            - If transferTo is USER, then returns the destinationAgentId
            - If transferTo is AUTOMATION, then returns the ivrAddress
            - If transferTo is EXTERNAL, then returns the externalAddress
        queueId:
          $ref: '#/components/schemas/QueueId'
        queueName:
          $ref: '#/components/schemas/QueueName'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        providerDialogId:
          $ref: '#/components/schemas/ProviderDialogId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        correlationId:
          $ref: '#/components/schemas/CorrelationId'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        initiatingAgentId: ab8f46f8-fd79-4380-8d0e-ce739ca481db
        transferTo: QUEUE
        destination: 16119117-7986-426e-bd3f-6f2e1d92ee1d
        queueId: 16119117-7986-426e-bd3f-6f2e1d92ee1d
        queueName: VoiceQ
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        connectionId: d2775626-66d4-459b-8147-09ea4b98c370
        dialogId: 01005000281645486013
        providerDialogId: 00001000321636990744
        channelId: Voice
        correlationId: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    SingleStepTransferError:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        initiatingAgentId:
          $ref: '#/components/schemas/InitiatingAgentId'
        transferTo:
          type: string
          description: >-
            The type of the transfer
          enum:
            - QUEUE
            - USER
            - AUTOMATION
            - EXTERNAL
        errorType:
          type: string
          description: >-
            The type of the error
          enum:
            - CANCELLED
            - FAILED
        destination:
          type: string
          description: >-
            Contains different values accordingly to transferTo:
              - If transferTo is QUEUE, then returns the queueId
              - If transferTo is USER, then returns the destinationAgentId
              - If transferTo is AUTOMATION, then returns the ivrAddress
              - If transferTo is EXTERNAL, then returns the externalAddress
        dialogId:
          $ref: '#/components/schemas/DialogId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        correlationId:
          $ref: '#/components/schemas/CorrelationId'
        title:
          $ref: '#/components/schemas/ErrorTitle'
        detail:
          $ref: '#/components/schemas/ErrorDetail'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        initiatingAgentId: ab8f46f8-fd79-4380-8d0e-ce739ca481db
        transferTo: USER
        errorType: CANCELLED
        destination: db9c8c9b-cb3a-42c9-8078-7a347726f016
        dialogId: 01005000281645486013
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        correlationId: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        title: Engagement no longer active
        detail: The current engagement has terminated
        id: d433ef5c-7954-4b39-9d99-ab9ffeae725b
        timestamp: 9223372036854776000
    ChannelReady:
      type: object
      additionalProperties: false
      properties:
        agentId:
          $ref: '#/components/schemas/AgentId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        agentId: zz3tDKfrQx-Mv78Q_AIpGG
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    AfterContactWorkActivated:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        agentId:
          $ref: '#/components/schemas/AgentId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        agentId: zz3tDKfrQx-Mv78Q_AIpGG
        dialogId: 01005000281645486013
        connectionId: d2775626-66d4-459b-8147-09ea4b98c370
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    AfterContactWorkCompleted:
      type: object
      additionalProperties: false
      properties:
        engagementId:
          $ref: '#/components/schemas/EngagementId'
        agentId:
          $ref: '#/components/schemas/AgentId'
        dialogId:
          $ref: '#/components/schemas/DialogId'
        connectionId:
          $ref: '#/components/schemas/ConnectionId'
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        id:
          $ref: '#/components/schemas/Id'
        timestamp:
          $ref: '#/components/schemas/Timestamp'
      example:
        engagementId: 15bcf682-3edf-4c79-b083-07864fa1fb55
        agentId: zz3tDKfrQx-Mv78Q_AIpGG
        dialogId: 01005000281645486013
        connectionId: d2775626-66d4-459b-8147-09ea4b98c370
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        id: d3c8400d-c44f-4451-8316-e75c4efb8bb2
        timestamp: 9223372036854776000
    OfferedQueue:
      type: object
      additionalProperties: false
      description: The offered queue details including offered agent
      properties:
        queueId:
          type: string
          description: The unique identifier of this queue
        channelId:
          type: string
          description: The channel of this queue
        priority:
          type: integer
          description: The priority of this service
        rank:
          type: integer
          description: The rank of this service
        proficiencyRangeMin:
          type: integer
          description: The minimum proficiency of this service
        proficiencyRangeMax:
          type: integer
          description: The maximum proficiency of this service
        attributes:
          type: array
          description: >
            A simplified flat list of attributes
          items:
            type: string
        offeredAgentData:
          $ref: '#/components/schemas/OfferedAgentData'
      example:
        priority: 1
        rank: 1
        proficiencyRangeMin: 1
        proficiencyRangeMax: 1
        attributes:
          category: Language
          values:
            - English
    OfferedService:
      type: object
      additionalProperties: false
      description: Details about the service offered including the offered agent
      properties:
        priority:
          type: integer
          description: The priority of this service
        rank:
          type: integer
          description: The rank of this service
        proficiencyRangeMin:
          type: integer
          description: The minimum proficiency of this service
        proficiencyRangeMax:
          type: integer
          description: The maximum proficiency of this service
        attributes:
          $ref: '#/components/schemas/Attributes'
        offeredAgentData:
          $ref: '#/components/schemas/OfferedAgentData'
      example:
        priority: 1
        rank: 1
        proficiencyRangeMin: 1
        proficiencyRangeMax: 1
        attributes:
          category: Language
          values:
            - English
    OfferedAgentData:
      type: object
      additionalProperties: false
      description: Details about the agent
      properties:
        agentId:
          $ref: '#/components/schemas/AgentId'
        providerAgentId:
          type: string
          description: The provider agent id of the offered agent
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        channelProviderAddress:
          type: string
          description: The address of the engagement provider
        providerAgentAddress:
          type: string
          format: email
          description: The address of the agent
      example:
        agentId: 4a785201-73b8-4842-abf7-36f5e572d310
        providerAgentId: 8011001
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        channelProviderAddress: +7775550113555
        providerAgentAddress: [email protected]
    OfferedSpecifiedAgent:
      type: object
      additionalProperties: false
      description: Details about the agent specified in the match request
      properties:
        rank:
          type: integer
          description: The rank of this agent
        offeredSpecifiedAgentData:
          $ref: '#/components/schemas/OfferedSpecifiedAgentData'
    OfferedSpecifiedAgentData:
      type: object
      additionalProperties: false
      properties:
        agentId:
          $ref: '#/components/schemas/AgentId'
        providerAgentId:
          type: string
          description: The provider agent id of the offered agent
        channelProviderId:
          $ref: '#/components/schemas/ChannelProviderId'
        channelId:
          $ref: '#/components/schemas/ChannelId'
        channelProviderAddress:
          type: string
          description: The address of the engagement provider
        providerAgentAddress:
          type: string
          format: email
          description: The address of the agent
      example:
        agentId: 4a785201-73b8-4842-abf7-36f5e572d310
        providerAgentId: 8011001
        channelProviderId: 4dc53692-e25c-4e8c-a780-0b2f05008478
        channelId: Voice
        channelProviderAddress: +7775550113555
        providerAgentAddress: [email protected]
    Attribute:
      type: object
      additionalProperties: false
      description: A Category and Values identified for routing the call
      properties:
        category:
          type: string
          description: A category for routing
        values:
          type: array
          description: A list of values specific to the category
          items:
            type: string
    Attributes:
      type: array
      description: A list of Category and Values identified for routing the call
      items:
        $ref: '#/components/schemas/Attribute'
    AgentId:
      type: string
      description: The unique identifier for the Agent
    AutomationType:
      type: string
      description: The type of automation being added
    AutomationInitiatedDisconnect:
      type: boolean
      description: >-
        An indication if the automation participant initiated disconnect from
        the dialog
    AutomationParticipantId:
      type: string
      description: The unique identifier for the automation participant
    ConnectionId:
      type: string
      description: >-
        The unique identifier for this appearance of this specific participant
        on the engagement
    ChannelId:
      type: string
      description: The channel ID which represents the media type
    ChannelProviderId:
      type: string
      description: The unique identifier for this engagement provider
    CustomerIdentifiers:
      type: object
      additionalProperties: false
      description: >
        A set of attributes used to identify the customer if any are known at
        engagement creation.
        *NOTE:* the list of Customer Identifiers is configurable per account so
        expect this to be dynamic per customer.  This will include all known
        customer identifiers, but some customers may have more or less collected
        than others.'
      properties:
        phoneNumbers:
          type: array
          items:
            type: string
        emailAddresses:
          type: array
          items:
            type: string
        accountIds:
          type: array
          items:
            type: string
    DialogId:
      type: string
      description: >
        The identifier for the dialog. *NOTE* this will equate to the UCID
        created by the ASBCE for an inbound call
    EngagementId:
      type: string
      description: The unique identifier for this engagement
    Extension:
      type: string
      description: The extension/line of the agent
    ExternalParticipantId:
      type: string
      description: >
        The Channel Provider's identifier for this external participant (aka the
        Customer)
    Id:
      type: string
      description: Each event has its own unique ID
    ProviderEngagementId:
      type: string
      description: The provider-native identifier for the engagement
    Timestamp:
      type: string
      description: Timestamp (milliseconds since epoch) when the event was generated
      format: long
    Ping:
      type: object
      additionalProperties: false
      properties:
        event:
          description:  ping - A constant parameter.
          type: string
          const: ping
        subscriptionId:
          description:  Optional. The id of the subscription.
          type: string
      required:
        - event
    Pong:
      type: object
      additionalProperties: false
      properties:
        event:
          description:  pong - A constant parameter.
          type: string
          const: pong
      required:
        - event
    DestinationAddress:
      type: string
      description: >
        Destination number or uri
    EngagementParameters:
      type: object
      additionalProperties: false
      description: >
        Additional information that could be tagged on an engagement
    OrchestrationFlow:
      type: string
      description: >
        The orchestration flow name that should be used for this engagement
    AgentRouting:
      type: object
      additionalProperties: false
      description: >
        Agent routing strategy configuration
      properties:
        type:
          type: string
          description: >
            LAR: last Agent routing, PAR: preferred Agent Routing
          enum:
            - LAR
            - PAR
        waitTime:
          type: integer
          description: >
            Wait time in minutes before default routing is applied
    InitiatingAgentId:
      type: string
      description: >
        The unique identifier for the agent that initiated the transfer
    QueueId:
      type: string
      description: >
        The destination queue identifier for the transfer or the fallback queue in the event destination agent is not available
    QueueName:
      type: string
      description: >
        The destination queue name of the transfer or the fallback queue in the event destination agent is not available
    CorrelationId:
      type: string
      description: >
        The correlationId for the request. This should be referenced when notifying a related error
    DestinationAgentId:
      type: string
      description: >
        A unique identifier for the destination agent of the transfer
    ErrorTitle:
      type: string
      description: The error description
    ErrorDetail:
      type: string
      description: The cause of the error
    ExternalAddress:
      type: string
      description: >
        The number or URI of the target external party
    IvrAddress:
      type: string
      description: >
        The number used to access the required automation (typically an IVR)
    ProviderDialogId:
      type: string
      description: >
        The unique identifier of the dialog generated by provider
  securitySchemes:
    apiKey:
      type: oauth2
      flows:
        password:
          tokenUrl: https://localhost/auth/realms/ABCDEF/protocol/openid-connect/token
          scopes: {}
AsyncAPI code generator
Please use the AsyncAPI code generator to build client SDK to interface with the Avaya Experience Platform™ Notification Agent and Engagement Async API.
https://www.asyncapi.com/tools/generator
The above specification can also be loaded into the AsyncAPI Studio for a user-friendly view similar to Swagger.
Payload
Payload details
| Name | Type | Description | Accepted values | 
|---|---|---|---|
| correlationId | string | The unique ID of the notification being sent | Any | 
| subscriptionId | string | The unique ID of the Agent and Engagement subscription | Any | 
| family | string | The family of events the subscription is for | Any | 
| sentAt | string | Datetime (in ISO 8601 format) of when the notification event was sent | Any | 
| accountId | string | The unique identifier for the Account. | Any | 
| loginId | string | The unique login handle for the Agent. | |
| NOTE Only present on Agent related events | Any | ||
| initiatingLoginId | string | The unique login handle for the Agent initiating a transfer. | |
| NOTE Only present on Single Step Transfer related events | Any | ||
| destinationLoginId | string | The unique login handle for the Agent the transfer is being made to. | |
| NOTE Only present on Single Step Transfer to User related events | Any | ||
| body | objectoneOf | The raw event payload that will be different based on the event. | Any | 
| body.0 | object | - | Any | 
| body.0.agentId | string | The unique identifier for the Agent | Any | 
| body.0.profileId | string | The profile ID used to login the agent. The profile indicates what channels should be logged in. | Any | 
| body.0.state | string | The current state of the agent. | LOGGED_IN, LOGGED_OUT, READY, NOT_READY | 
| body.0.reasonCode | string | The reason code for going not ready. Only for AGENT_NOT_READY state | Any | 
| body.0.cause | string | The cause of the agent not being ready. Only for AGENT_NOT_READY state | Any | 
| body.0.id | string | Each event has its own unique ID | Any | 
| body.0.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.1 | object | - | Any | 
| body.1.engagementId | string | The unique identifier for this engagement | Any | 
| body.1.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.1.connectionId | string | The unique identifier for this appearance of this specific participant on the engagement | Any | 
| body.1.action | string | The agent participant action | ADDED, HELD, UNHELD, INVITED, REMOVED | 
| body.1.agentId | string | The unique identifier for the Agent | Any | 
| body.1.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.1.extension | string | The extension/line of the agent | Any | 
| body.1.channelId | string | The channel ID which represents the media type | Any | 
| body.1.providerEngagementId | string | The provider-native identifier for the engagement | Any | 
| body.1.agentInitiatedDisconnect | boolean | An indication if the agent initiated disconnect from the dialog. Only for REMOVED action | Any | 
| body.1.id | string | Each event has its own unique ID | Any | 
| body.1.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.2 | object | - | Any | 
| body.2.engagementId | string | The unique identifier for this engagement | Any | 
| body.2.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.2.automationParticipantId | string | The unique identifier for the automation participant | Any | 
| body.2.action | string | The automation participant action | ADDED, REMOVED | 
| body.2.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.2.automationType | string | The type of automation being added | Any | 
| body.2.connectionId | string | The unique identifier for this appearance of this specific participant on the engagement | Any | 
| body.2.channelId | string | The channel ID which represents the media type | Any | 
| body.2.providerEngagementId | string | The provider-native identifier for the engagement | Any | 
| body.2.automationInitiatedDisconnect | boolean | An indication if the automation participant initiated disconnect from the dialog | Any | 
| body.2.id | string | Each event has its own unique ID | Any | 
| body.2.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.3 | object | - | Any | 
| body.3.engagementId | string | The unique identifier for this engagement | Any | 
| body.3.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.3.externalParticipantId | string | The Channel Provider's identifier for this external participant (aka the Customer) | Any | 
| body.3.action | string | The external participant action | ADDED, REMOVED, INVITED | 
| body.3.connectionId | string | The unique identifier for this appearance of this specific participant on the engagement | Any | 
| body.3.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.3.channelId | string | The channel ID which represents the media type | Any | 
| body.3.providerEngagementId | string | The provider-native identifier for the engagement | Any | 
| body.3.externalParticipantInitiatedDisconnect | boolean | An indication if the external participant (aka the Customer) initiated disconnect from the dialog | Any | 
| body.3.id | string | Each event has its own unique ID | Any | 
| body.3.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.4 | object | - | Any | 
| body.4.engagementId | string | The unique identifier for this engagement | Any | 
| body.4.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.4.orchestrationFlow | string | The orchestration flow name that should be used for this engagement | Any | 
| body.4.attributes | arrayobject | A list of Category and Values identified for routing the call | Any | 
| body.4.attributes.category | string | A category for routing | Any | 
| body.4.attributes.values | arraystring | A list of values specific to the category | Any | 
| body.4.attributeList | arraystring | A simplified flat list of attributes | |
| NOTE this flat array of attributes will help to easily identify “System.Outbound” to represent a POM call | Any | ||
| body.4.engagementParameters | object | Additional information that could be tagged on an engagement | Any | 
| body.4.agentRoutingStrategy | object | Agent routing strategy configuration | Any | 
| body.4.agentRoutingStrategy.type | string | LAR: last Agent routing, PAR: preferred Agent Routing | LAR, PAR | 
| body.4.agentRoutingStrategy.waitTime | integer | Wait time in minutes before default routing is applied | Any | 
| body.4.adhocEmail | boolean | Flag to determine if adhoc email or not (email routing only) | Any | 
| body.4.autoResponse | string | The auto response suggested to be used | Any | 
| body.4.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.4.channelId | string | The channel ID which represents the media type | Any | 
| body.4.channelIdentifier | string | The channel identifier of the engagement | Any | 
| body.4.queue | object | The queue details | Any | 
| body.4.queue.queueId | integer | The unique identifier of the queue | Any | 
| body.4.queue.queueName | integer | The name of the queue | Any | 
| body.4.queue.priority | integer | The priority of the queue | Any | 
| body.4.queue.proficiencyRangeMin | integer | The minimum proficiency of the queue | Any | 
| body.4.queue.proficiencyRangeMax | integer | The maximum proficiency of the queue | Any | 
| body.4.customerIdentifiers | object | A set of attributes used to identify the customer if any are known at engagement creation. | |
| NOTE: the list of Customer Identifiers is configurable per account so expect this to be dynamic per customer. This will include all known customer identifiers, but some customers may have more or less collected than others.' | Any | ||
| body.4.customerIdentifiers.phoneNumbers | arraystring | - | Any | 
| body.4.customerIdentifiers.emailAddresses | arraystring | - | Any | 
| body.4.customerIdentifiers.accountIds | arraystring | - | Any | 
| body.4.externalParticipantId | string | The Channel Provider's identifier for this external participant (aka the Customer) | Any | 
| body.4.sourceAddress | string | The source address of the external participant, e.g. calling number or customer email | Any | 
| body.4.destinationAddress | string | Destination number or uri | Any | 
| body.4.subject | string | The subject field of the incoming email | Any | 
| body.4.id | string | Each event has its own unique ID | Any | 
| body.4.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.5 | object | - | Any | 
| body.5.engagementId | string | The unique identifier for this engagement | Any | 
| body.5.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.5.connectionId | string | The unique identifier for this appearance of this specific participant on the engagement | Any | 
| body.5.externalParticipantId | string | The Channel Provider's identifier for this external participant (aka the Customer) | Any | 
| body.5.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.5.callingNumber | string | The calling number of the external participant | Any | 
| body.5.dialledNumber | string | The original dialed number for the engagement | Any | 
| body.5.channelId | string | The channel ID which represents the media type | Any | 
| body.5.customerIdentifiers | object | A set of attributes used to identify the customer if any are known at engagement creation. | |
| NOTE: the list of Customer Identifiers is configurable per account so expect this to be dynamic per customer. This will include all known customer identifiers, but some customers may have more or less collected than others.' | Any | ||
| body.5.customerIdentifiers.phoneNumbers | arraystring | - | Any | 
| body.5.customerIdentifiers.emailAddresses | arraystring | - | Any | 
| body.5.customerIdentifiers.accountIds | arraystring | - | Any | 
| body.5.providerEngagementId | string | The provider-native identifier for the engagement | Any | 
| body.5.engagementParameters | object | Additional information that could be tagged on an engagement | Any | 
| body.5.id | string | Each event has its own unique ID | Any | 
| body.5.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.6 | object | - | Any | 
| body.6.engagementId | string | The unique identifier for this engagement | Any | 
| body.6.matchId | string | The unique identifier for this match | Any | 
| body.6.correlationId | string | The correlation Id from the original match request (can be ignored) | Any | 
| body.6.strategy | string | The agent selection strategy used for this match (values include MOST_IDLE or OCCUPANCY) | MOST_IDLE, OCCUPANCY | 
| body.6.offeredQueue | object | The offered queue details including offered agent | Any | 
| body.6.offeredQueue.queueId | integer | The unique identifier of this queue | Any | 
| body.6.offeredQueue.channelId | integer | The channel of this queue | Any | 
| body.6.offeredQueue.priority | integer | The priority of this service | Any | 
| body.6.offeredQueue.rank | integer | The rank of this service | Any | 
| body.6.offeredQueue.proficiencyRangeMin | integer | The minimum proficiency of this service | Any | 
| body.6.offeredQueue.proficiencyRangeMax | integer | The maximum proficiency of this service | Any | 
| body.6.offeredQueue.attributes | arrayobject | A list of Category and Values identified for routing the call | Any | 
| body.6.offeredQueue.attributes.category | string | A category for routing | Any | 
| body.6.offeredQueue.attributes.values | arraystring | A list of values specific to the category | Any | 
| body.6.offeredQueue.offeredAgentData | object | Details about the agent | Any | 
| body.6.offeredQueue.offeredAgentData.agentId | string | The unique identifier for the Agent | Any | 
| body.6.offeredQueue.offeredAgentData.providerAgentId | string | The provider agent id of the offered agent | Any | 
| body.6.offeredQueue.offeredAgentData.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.6.offeredQueue.offeredAgentData.channelId | string | The channel ID which represents the media type | Any | 
| body.6.offeredQueue.offeredAgentData.channelProviderAddress | string | The address of the engagement provider | Any | 
| body.6.offeredQueue.offeredAgentData.providerAgentAddress | string | The address of the agent | Any | 
| body.6.offeredService | object | Details about the service offered including the offered agent | Any | 
| body.6.offeredService.priority | integer | The priority of this service | Any | 
| body.6.offeredService.rank | integer | The rank of this service | Any | 
| body.6.offeredService.proficiencyRangeMin | integer | The minimum proficiency of this service | Any | 
| body.6.offeredService.proficiencyRangeMax | integer | The maximum proficiency of this service | Any | 
| body.6.offeredService.attributes | arrayobject | A list of Category and Values identified for routing the call | Any | 
| body.6.offeredService.attributes.category | string | A category for routing | Any | 
| body.6.offeredService.attributes.values | arraystring | A list of values specific to the category | Any | 
| body.6.offeredService.offeredAgentData | object | Details about the agent | Any | 
| body.6.offeredService.offeredAgentData.agentId | string | The unique identifier for the Agent | Any | 
| body.6.offeredService.offeredAgentData.providerAgentId | string | The provider agent id of the offered agent | Any | 
| body.6.offeredService.offeredAgentData.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.6.offeredService.offeredAgentData.channelId | string | The channel ID which represents the media type | Any | 
| body.6.offeredService.offeredAgentData.channelProviderAddress | string | The address of the engagement provider | Any | 
| body.6.offeredService.offeredAgentData.providerAgentAddress | string | The address of the agent | Any | 
| body.6.offeredSpecifiedAgent | object | Details about the agent specified in the match request | Any | 
| body.6.offeredSpecifiedAgent.rank | integer | The rank of this agent | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData | object | - | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData.agentId | string | The unique identifier for the Agent | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData.providerAgentId | string | The provider agent id of the offered agent | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData.channelId | string | The channel ID which represents the media type | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData.channelProviderAddress | string | The address of the engagement provider | Any | 
| body.6.offeredSpecifiedAgent.offeredSpecifiedAgentData.providerAgentAddress | string | The address of the agent | Any | 
| body.6.id | string | Each event has its own unique ID | Any | 
| body.6.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.7 | object | - | Any | 
| body.7.engagementId | string | The unique identifier for this engagement | Any | 
| body.7.agentId | string | The unique identifier for the Agent | Any | 
| body.7.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.7.destinationAddress | string | Destination number or uri | Any | 
| body.7.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.7.channelId | string | The channel ID which represents the media type | Any | 
| body.7.customerIdentifiers | object | A set of attributes used to identify the customer if any are known at engagement creation. | |
| NOTE: the list of Customer Identifiers is configurable per account so expect this to be dynamic per customer. This will include all known customer identifiers, but some customers may have more or less collected than others.' | Any | ||
| body.7.customerIdentifiers.phoneNumbers | arraystring | - | Any | 
| body.7.customerIdentifiers.emailAddresses | arraystring | - | Any | 
| body.7.customerIdentifiers.accountIds | arraystring | - | Any | 
| body.7.engagementParameters | object | Additional information that could be tagged on an engagement | Any | 
| body.7.id | string | Each event has its own unique ID | Any | 
| body.7.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.8 | object | - | Any | 
| body.8.engagementId | string | The unique identifier for this engagement | Any | 
| body.8.initiatingAgentId | string | The unique identifier for the agent that initiated the transfer | Any | 
| body.8.transferTo | string | The type of the transfer | QUEUE, USER, AUTOMATION, EXTERNAL | 
| body.8.destination | string | Contains different values accordingly to transferTo: - If transferTo is QUEUE, then returns the queueId - If transferTo is USER, then returns the destinationAgentId - If transferTo is AUTOMATION, then returns the ivrAddress - If transferTo is EXTERNAL, then returns the externalAddress | Any | 
| body.8.queueId | string | The destination queue identifier for the transfer or the fallback queue in the event destination agent is not available | Any | 
| body.8.queueName | string | The destination queue name of the transfer or the fallback queue in the event destination agent is not available | Any | 
| body.8.channelProviderId | string | The unique identifier for this engagement provider | Any | 
| body.8.connectionId | string | The unique identifier for this appearance of this specific participant on the engagement | Any | 
| body.8.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any | 
| body.8.providerDialogId | string | The unique identifier of the dialog generated by provider | Any | 
| body.8.channelId | string | The channel ID which represents the media type | Any | 
| body.8.correlationId | string | The correlationId for the request. This should be referenced when notifying a related error | Any | 
| body.8.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any | 
| body.9 | object | - | Any | 
| body.9.engagementId | string | The unique identifier for this engagement | Any | 
| body.9.initiatingAgentId | string | The unique identifier for the agent that initiated the transfer | Any | 
| body.9.transferTo | string | The type of the transfer | QUEUE, USER, AUTOMATION, EXTERNAL | 
| body.9.errorType | string | The type of the error | CANCELLED, FAILED | 
| body.9.destination | string | Contains different values accordingly to transferTo: | 
- If transferTo is QUEUE, then returns the queueId
- If transferTo is USER, then returns the destinationAgentId
- If transferTo is AUTOMATION, then returns the ivrAddress
- If transferTo is EXTERNAL, then returns the externalAddress | Any |
 | body.9.dialogId | string | The identifier for the dialog. NOTE this will equate to the UCID created by the ASBCE for an inbound call | Any |
 | body.9.channelProviderId | string | The unique identifier for this engagement provider | Any |
 | body.9.channelId | string | The channel ID which represents the media type | Any |
 | body.9.correlationId | string | The correlationId for the request. This should be referenced when notifying a related error | Any |
 | body.9.title | string | The error description | Any |
 | body.9.detail | string | The cause of the error | Any |
 | body.9.id | string | Each event has its own unique ID | Any |
 | body.9.timestamp | string | Timestamp (milliseconds since epoch) when the event was generated | Any |
 | body.event | string | The name of the specific event being sent. For instance AgentState, AgentParticipant, InboundEngagementCreated, etc... | Any |
Examples of payload (generated)
{
  "correlationId": "a425851d-5225-4b76-8ca0-4fa31ecfd5db",
  "subscriptionId": "fdbec917-e76e-4645-8120-4eac46f29487",
  "family": "AGENT_ENGAGEMENT",
  "sentAt": "2020-08-24T08:20:23.395Z",
  "accountId": "DYNNUG",
  "loginId": "[email protected]",
  "body": {
    "event": "AgentState",
    "agentId": "4a785201-73b8-4842-abf7-36f5e572d310",
    "profileId": "HomeProfile",
    "state": "NOT_READY",
    "reasonCode": 514,
    "cause": "RONA",
    "id": "d3c8400d-c44f-4451-8316-e75c4efb8bb2",
    "timestamp": 9223372036854776000
  }
}
Tags
- Agent and Engagement Data
Message pong
pongServer pong response to a ping message.
Payload
| Name | Type | Description | Accepted values | 
|---|---|---|---|
| event (required) | string | pong - A constant parameter. | Any | 
Examples of payload
pongMessage
Example of a pong message to client.
{
  "event": "pong"
}
Tags
- Heartbeat
Message authenticationResponse
authenticationResponseAuthentication response message sent to the client after websocket authentication.
Payload
| Name | Type | Description | Accepted values | 
|---|---|---|---|
| event | string | authenticationResponse - A constant parameter. | Any | 
| status | string | You will then receive 1 of 5 statuses: | 
- CONNECTION_CONFIRMED: Connection was confirmed
- CONNECTION_FAILED_INVALID_TOKEN: Authentication token is invalid
- CONNECTION_FAILED_UNKNOWN_SUBSCRIPTION: Unknown Subscription, can be for a subscription that never existed or one that is no longer active
- CONNECTION_FAILED_INTERNAL_SERVER_ERROR: Server Error, client can retry later
- CONNECTIONFAILED_CONSTRAINT_VIOLATION: Client issue, malformed client request, client must update payload and rerty | CONNECTION_CONFIRMED, CONNECTION_FAILED_INVALID_TOKEN, CONNECTION_FAILED_UNKNOWN_SUBSCRIPTION, CONNECTION_FAILED_INTERNAL_SERVER_ERROR, CONNECTION_FAILED_CONSTRAINT_VIOLATION |
 | subscriptionId | string | The unique id of the subscription. | _Any |
 | pingInterval | integer | The maximum interval (seconds) at which a ping is expected to be sent by the client before websocket is closed and subscription set to INACTIVE.
It is recommended the client send ping more frequently (every 30 seconds) to preclude any proxies from closing the connection. | Any |
| expiresInterval | integer | Expiration interval in seconds before the subscription is set to INACTIVE. | Any |
Examples of payload (generated)
{
  "event": "authenticationResponse",
  "status": "CONNECTION_CONFIRMED",
  "subscriptionId": "fdbec917-e76e-4645-8120-4eac46f29487",
  "pingInterval": 300,
  "expiresInterval": 900
}
Tags
- Authentication
Updated about 1 year ago