/turn-rasa-connector

A Rasa Connector for https://www.turn.io/

Primary LanguagePythonBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

Turn Rasa Connector

Currently ready and running in production

A Rasa Connector for https://www.turn.io/

Handles Turn conversation claims

Configuration

This connector has the following configuration:

url (required) - The URL of the Turn instance

token (required) - The authorization token to use when making requests to Turn

hmac_secret (optional) - If specified, validates that the HMAC signature in the webhook request is valid, returning an HTTP 401 if invalid

postgresql_url (optional) - If using PostgreSQL as a tracker store, ignores messages with message IDs that we've already processed (deduplication)

http_retries (optional) - Number of times to retry HTTP requests to Turn. Defaults to 3

Example credentials.yml:

turn_rasa_connector.turn.TurnInput:
  url: "https://whatsapp.turn.io"
  token: "xxxxxxxxxxx"
  hmac_secret: "xxxx-xxxx-xxxx"
  postgresql_url: "postgres://"
  http_retries: 3

Conversation Claims

This connector will handle receiving and extending the Turn conversation claim with every message reply.

This is controlled by the claim key on the message:

  • extend - This is the default if no claim key is supplied. Will extend the conversation claim.
  • release - Will release the conversation claim.
  • revert - Will release the conversation claim, and instead of sending the user a response, tell Turn Automation to process the last message,

Example:

utter_continue:
  - text: "What would you like to do?"
  # claim: extend
  # Is the default

utter_end:
  - text: "Thank you! Your conversation claim will now end"
    claim: release

utter_exit:
  - text: "this won't be sent"
  - claim: revert

Development

Requires PostgreSQL. PostgreSQL location controlled using the TEST_POSTGRES_URL environment variable, defaulting to postgres://

~ pip install -r requirements.txt -r requirements-dev.txt
~ black .
~ isort -rc .
~ mypy .
~ flake8
~ py.test