Skip to content

Latest commit

 

History

History
115 lines (86 loc) · 5.71 KB

README.md

File metadata and controls

115 lines (86 loc) · 5.71 KB

Build Status

Deploy a Serverless Multilingual Conference Room

In this code pattern, we will create the workings for a multilingual chat room using OpenWhisk, Watson text-to-speech and Watson Language Translator. The MQTT messaging protocol is also leveraged, which allows for each client to publish and subscribe to one or more channels. This repository contains a series of serverless functions are called in sequence determinded by the channel to which a message is submitted.

When the reader has completed this Code Pattern, they will understand how to:

  • Deploy Cloud Function actions and triggers
  • Interact with the Watson IoT platform
  • Set up a CloudFoundry application

Architecture

Flow

  1. Message received from a client, which can be a web browser, CLI, Openwhisk action, SMS text, etc.
  2. If message payload contains an audio file, it is transcribed to text.
  3. Transcribed text is translated to other supported languages.
  4. If message sent via SMS, sender phone number is added to an etcd key/value store. etcd is used here to maintain a list of subscriber’s phone numbers, as well as their respective languages. An adjustable TTL value is used here to remove numbers from the store if the subscriber does not participate in the conversation for 300 seconds.
  5. Translated messages/audio streams are published to various channels on the MQTT broker, which then distributes the messages amongst subscribing clients.

Included components

  • OpenWhisk: Execute code on demand in a highly scalable, serverless environment.
  • Watson Text to Speech: Converts written text into natural sounding audio in a variety of languages and voices.

Featured technologies

  • Messaging: Messaging is a key technology for modern applications using loosely decoupled architecture patterns such as microservices.
  • Node.js: An open-source JavaScript run-time environment for executing server-side JavaScript code.
  • Serverless: An event-action platform that allows you to execute code in response to an event.

Watch the Video

Steps

Prerequisites:

Install the MQTT package/feed found in this repository. This will allow actions to be invoked in response to incoming MQTT messages.

  1. Upload Actions
  2. Create Triggers
  3. Create Rules
  4. Deploy UI

1. Upload Actions

Upload each "Action" to the Cloud Functions codebase using the following commands

wsk action create translateText translateText.js
wsk action create sendSMS sendSMS.js
wsk action create iotPub iotPub.py
wsk action create handleIncomingSMS handleIncomingSMS.py

After each action is created, set default credentials for the corresponding services

wsk action update getTTSToken --param TTS_PASSWD <passwd> --param TTS_USERNAME <username>
wsk action update translateText --param language_translation_username ${language_translation_username} --param language_translation_password ${language_translation_password}
...

2. Create Triggers

Create Triggers to represent events

wsk trigger create audioMsgReceived
wsk trigger create txtMsgReceived
wsk trigger create SMSMsgReceived
wsk trigger create msgTranslated

3. Create Rules

Create Rules to bind triggers and actions

# wsk rule create RULE_NAME TRIGGER_NAME ACTION_NAME
wsk rule create handleTxtMessage txtMsgReceived translateText
wsk rule create handleSMSMessage SMSMsgReceived translateText
wsk rule create publishtoIOT msgTranslated iotPub
wsk rule create publishtoSMS msgTranslated sendSMS

Flow: MQTT message received as JSON object to topic iot-2/type/${deviceType}/id/${orgId}/evt/${eventName}/fmt/json

{
  client: "client_1234",
  message: "hello",
  language: "en"
}

Trigger associated with topic forwards object containing message payload/language to translation action. Translation action passes message payload through a loop, where each item is a language that the original message will be translated to. After translation is complete, another trigger will be fired, which kicks off two more "publish" actions simultaneously

  • one action publishes result to all MQTT clients
  • the other action looks up SMS subscriber numbers/language in ETCD and sends them result via Twilio

Restrictions: Watson IOT provides an MQTT broker, but has restrictions on how MQTT topics can be structured. So, only one section of the topic is customizable, the "event name". This limitation prevents us from using self described topics like fromClient/text/en, which would allow clients to subscribe only to the language of their choice. Therefore they'll need to receive all messages and discard the unneeded ones.

MQTT package/feed requires a CF app, which technically means this implementation is not serverless

4. Deploy UI

If all you need is the server side logic, you can stop here. But optionally, you can delpoy the UI provided by https://github.com/IBM/language-translation-ui

TODO: Create script to create wsk actions, populate credentials using .env files

Port all issues from Taiga kanban to this repository

Links

License

Apache 2.0