handleInput
function in the Endpoint settings or via CLI.
Restrictions
-
The return value is validated against a set of rules. If these rules aren’t met, the transformer throws an error. The following rules apply:
userId
is a string with up to 256 characters.sessionId
is a string with up to 256 characters.text
is a string with up to 10,000 characters.data
is an object.
Transformer Function Arguments
Depending on the Endpoint type in which you want to use the transformer, the function arguments vary:- Webhook- and REST-based Endpoints
- Socket-based Endpoints
Argument | Description |
---|---|
endpoint | The configuration object for the Endpoint. |
request | The Express request object with a JSON-parsed body. |
response | The Express response object. |
Endpoint Configuration Object
endpoint Object Properties
endpoint Object Properties
Property | Type | Description |
---|---|---|
_id | string | The Endpoint’s Reference ID. |
channel | string | The Endpoint’s channel. |
URLToken | string | The URL Token, found in the Input object. |
name | string | The Endpoint’s name. |
flowId | string | The Reference ID of the specified Flow to which the Endpoint points to. |
entrypoint | string | The Entrypoint of the Endpoint. |
active | boolean | The flag to activate or deactivate the Endpoint. |
nluConnectorId | string | ID of the selected NLU connector for the Endpoint. |
useAnalytics | boolean | The flag to collect analytics data for the Endpoint. |
storeDataPayload | boolean | The flag to store data payloads into analytics for the Endpoint. |
useConversations | boolean | The flag to collect conversations history for the Endpoint. |
maskIPAddress | boolean | The flag to mask sensitive IP addresses in input object and analytics data. |
maskAnalytics | boolean | The flag to mask sensitive data in analytics for the Endpoint. |
maskLogging | boolean | The flag to mask sensitive data in logs for the Endpoint. |
useContactProfiles | boolean | The flag to use Contact Profiles for the Endpoint. |
useDashbotAnalytics | boolean | The flag to use Dashbot for collecting analytics data. |
dashbotApikey | string | The API key of the Dashbot bot for analytics collection. |
dashbotPlatform | string | The selected platform of the Dashbot bot for analytics collection. |
settings | object | Optional Endpoint-specific settings. For example, Facebook Page token. |
handoverSettings | object | Settings to configure a handover provider. |
createdAt | number | Unix timestamp when the Endpoint was created. |
lastChanged | number | Unix timestamp when the Endpoint was last modified. |
createdBy | string | Email of the user who created the Endpoint. |
lastChangedBy | string | Email of the user who last modified the Endpoint. |
Return Values
The input transformer returns the user ID, session ID, text, and data, which are subsequently sent to the Flow. These values are extracted from the Endpoint payload. The payload format is specific to the Endpoint type you use, for example, Alexa or Facebook (Meta) Messenger. Read the documentation of the specific Endpoint to know how to format the payload.Example of Transformer Return Values
Example of Transformer Return Values
Undefined Return Values
If the transformer returnsundefined
for userId
, sessionId
, text
, or data
, this means that the transformer uses the value from the Endpoint.
Example of Undefined Return Values
Example of Undefined Return Values
The following example overwrites
text
and data
, but uses the userId
and sessionId
from the Endpoint:Endpoints Event Messages
The Webchat and the Socket.IO Endpoints output event messages that indicate user activity, such as whether the user is connected (user-connected
) or disconnected (user-disconnected
). These event messages neither trigger Flows nor are counted. The event messages inform handover providers about user activity, allowing human agents to determine if the user is still engaged in the conversation. You can access the event messages with the data._cognigy.event
property in the return value of the input transformer.
Example of Return Values with Event Messages
Example of Return Values with Event Messages
Example of Input Transformer with Event Messages
Example of Input Transformer with Event Messages