Skip to content

Demo showcasing how existing business processes and rules can be augmented with Web RTC and cognitive services to drive customer engagement and help make smarter business decisions.

License

Notifications You must be signed in to change notification settings

stschmitt/assistant-shop.r

 
 

Repository files navigation

Assistant Shop.r Overview

What if customer feedback automatically drove business decisions?

Customer feedback contains invaluable insight into client satisfaction. Assistant Shop.r enables a department store to analyze aggregated customer feedback and consumer behavior in order to enable their buyers to make smarter purchasing decisions.

In this demo, a video call (using the new [Twilio video API] twilio_video_url) is held between a customer and a customer service agent. As the video call is happening [IBM Watson Speech to Text] speech_to_text_url service is transcribing the audio in real time. After the video call completes, [AlchemyLanguage API] alchemy_api_url is used to automatically determine which product the customer was giving feedback on and then determines the sentiment of that feedback. The corresponding product's feedback score, a number between 0 and 100, fluctuates based on this feedback. After the score is updated, Business Rules are invoked to determine if the product has crossed a threshold to automatically suggest a review of investment in the product. If the rules suggest a review, a process instance for a change in product investment is then started and managed by the Bluemix Workflow service. This creates a task for a buyer at the company. The buyer can then decide whether to ignore or go through with the review, thus completing the process.

Video Walkthrough - https://www.youtube.com/watch?v=EcOryuaGYCI

Deploy to Bluemix

Bluemix Deployments

Note: If deploying by this method, the app will fail on first deploy. After this initial failure, you must complete steps 12-16 as described in the section 'Running the app on Bluemix', as well as configure your business rules and workflow. Only then will your app start successfully.

Application Requirements

This application requires two machines to run through the demo. The users need to be running either the Firefox or Chrome browser for the demo to function properly.

How it Works

  1. Have the first person open a web browser and go to [https://assistant-shop-r.mybluemix.net/agent] demo_agent_url. They will play the role of the agent.

  2. Click "Go Online" at the top.

  3. Have the second person open a web browser on another machine and go to https://assistant-shop-r.mybluemix.net/. They will play the role of the customer.

  4. Click the camera icon for one of the products, you will get an alert asking for permission to use your microphone and camera. Allow permission.

  5. The agent will then get an alert asking for permission to their microphone and camer. Allow permission as well.

  6. The customer should speak some text and it will be transcribed in real time for the second person (the agent).

  7. One of the two people click "End call".

  8. The agent will see keywords extracted from the conversation transcript and overall sentiment, determined by the AlchemyLanguage API

  9. Behind the scenes, business rules and a workflow are invoked to automatically determine whether an investment review needs to be triggered.

  10. Open a web browser and go to https://assistant-shop-r.mybluemix.net/tasks. If a review was triggered by your conversation, you will see a new task as a result of the customer's feedback.

Check out the app

Customer View - https://assistant-shop-r.mybluemix.net

Customer Service View - https://assistant-shop-r.mybluemix.net/agent

Buyer View - https://assistant-shop-r.mybluemix.net/tasks

Architecture Diagram


This an architectural overview of the systems that make this app run.

Running the app on Bluemix

  1. # for Bluemix or use your existing account.

  2. Download and install the Cloud-foundry CLI tool

  3. Clone the app to your local environment from your terminal using the following command

git clone https://github.com/IBM-Bluemix/assistant-shop.r.git
  1. cd into this newly created directory

  2. Edit the manifest.yml file and change the <application-name> and <application-host> to something unique.

    applications:
    -  name: assistant-shop-r
    	host: assistant-shop-r
       command: node app.js
       runtime: node12
       memory: 512M
       instances: 1
    

The host you use will determinate your application url initially, e.g. <application-host>.mybluemix.net.

  1. Connect to Bluemix in the command line tool and follow the prompts to log in.

    $ cf api https://api.ng.bluemix.net
    $ cf login
    

    Note: Several of the services in the following steps may produce warnings when you create them, alerting you that they are not entirely free. Creating and demoing this app leaves you well within the limits of your free quota, however, always remain cognizant of your monthly service usage.

  2. Create the Speech to Text service in Bluemix.

$ cf create-service speech_to_text standard assistant-shop-r-speech-to-text
  1. Create the Cloudant service in Bluemix.
$ cf create-service cloudantNoSQLDB Shared assistant-shop-r-db
  1. Create the Business Rules service in Bluemix.
$ cf create-service businessrules standard assistant-shop-r-rules
  1. Create the Workflow service in Bluemix.
$ cf create-service Workflow standard assistant-shop-r-workflow
  1. Create the AlchemyAPI service in Bluemix.
$ cf create-service alchemy_api free assistant-shop-r-alchemy
  1. Next, you need to # for a Twilio developer account if you do not have one already. You can do this [here] twilio_#_url.

  2. Once you have created an account, navigate to your account page. Take note of your Live Account SID and AuthToken on this page, as you will need it to plug in as your credentials for accessing Twilio's API from within Bluemix.

  3. Go to the Bluemix catalog, select the Twilio service, choose to leave it unbound, name it assistant-shop-r-twilio, populate Account SID and Auth Token using your credentials from step 13, and finally click Create.

  4. Currently, Twilio Video is in beta, so you will need to request access to the beta program, designating that you would like access to the JavaScript SDK.

  5. Push your app to Bluemix

$ cf push

And voila! You now have your very own instance of Assistant Shop.r running on Bluemix.

Before you get too excited, we are not done just yet! We still need to define what the business rules and process for our application are going to look like. In the next few sections we will look at configuring these services.

Configuring Business Rules

  1. If you don't have it already, download the [Eclipse Juno IDE for Java EE Developers] eclipse_download_url.

  2. Start Eclipse and install IBM Rule Designer by completing the following steps:

    • Go to the menu Help > Install New Software
    • In the install dialog, click Add
    • In the Add Repository dialog, enter the following details:
    • Select the package Business rules and events
      • Click Next and then Next again
      • Accept the license terms
      • Click Finish and then OK
    • Restart Eclipse to complete the installation
  3. Open Eclipse back up and switch to the Rules perspective by going to the menu and selecting Window > Open Perspective > other > Rule > OK

  4. Import the product rules Java project into your workspace

    • Click File > Import > General > Existing Projects into Workspace and then Next
    • In the Import projects window, select the Select Archive file: radio button and click Browse. Choose the projectRules.zip file from your cloned GitHub repo.
    • Select all three projects and click Finish

    ####Projects

    • products - Contains the Java file that holds the product object. A product is composed of an ID, feedback score, and indicators for investment/divestment review.
    • products-RuleProject - Contains the three business rules that leverage the product object. These rules define the lower and upper feedback score thresholds that dictate investment reviews. You can view the rules [here] project_gists_url as well.
    • products-RuleApp - The app to be deployed to your business rules service instance.
  5. Navigate to your application in the Bluemix dashboard. Click on the business rules service and go to the Connection Settings tab to find your instance credentials.

  6. Using the credentials found in step 5, we will now create a deployment target in Rule Designer:

    • Click File > New > Project > Rule Designer > Rule Execution Server Configuration Project and then Next
    • Name your project 'Product Rule Execution Server Configuration' and then click Next
    • Select IBM WebSphere AS 8.5 as your applications server and click Next
    • Set URL, Login, and Password to their corresponding values from the Business Rules service console.
    • Click Test Connection and you should get the message Connection successful. Click Next.
    • Keep the default RuleApp deployment option selected and click Finish to close the wizard.
  7. Deploy the Rule App to your business rules service instance by taking the following steps:

    • Right-click products-RuleApp > RuleApp > Deploy
    • Select the Increment RuleApp major version deployment type and then click Next.
    • Keep the default selected target server radio button, select IBM WebSphere AS 8.5, and then click Finish.

Your RuleApp should now be successfully deployed to your business rules service instance! To confirm this, first check your Eclipse console which should indicate a successful deployment. Then, return to your business rules service console and go to the Decision Services tab. You should see your recently deployed RuleApp as one of the available decision services. If not, be sure to hit the Refresh button to perform a fresh check.

Configuring Workflow

  1. Install the [Workflow for Bluemix plugin] workflow_plugin_url.

  2. Navigate to your application in the Bluemix dashboard. Click on the workflow service and copy the configuration information at the bottom of the page. Then go [here] workflow_settings_url, ensure 'Workflow service 1' is chosen in the dropdown, and paste the configuration info into the corresponding textbox. A notification stating Workflow settings successfully updated should appear at the top of the screen.

  3. Go to [IBM Bluemix DevOps Services] jazzhub_url and create a new project. Name it 'assistant-shop-r-workflow', select 'Create a new repository', select 'Create a Git repo on Bluemix', and click Create.

  4. Once the project has been created, click Edit Code in the top-right. In the edit code perspective, click File > New > File and name it productsWorkflow.jsflow.

  5. Copy the following gist to this new file, change appname on line 13 to your app's host name and save.

    <script src="https://gist.github.com/JakePeyser/9527612cf9b5d13e0400.js?file=productsWorkflow.jsflow"></script>
  6. To deploy this workflow to your service, click Tools > Deploy to Workflow service. A notification stating Workflow deployment successful should appear at the top of the screen.

Your workflow should now be successfully deployed to your workflow service instance! To confirm this, navigate to your workflow service and click Launch Admin Console. You can find your deployed workflows and corresponding process instances here.

Troubleshooting

The primary source of debugging information for your Bluemix app is the logs. To see them, run the following command using the Cloud Foundry CLI:

$ cf logs assistant-shop-r --recent

For more detailed information on troubleshooting your application, see the Troubleshooting section in the Bluemix documentation.

Privacy Notice

The Assistant Shop.r sample web application includes code to track deployments to Bluemix and other Cloud Foundry platforms. The following information is sent to a Deployment Tracker service on each deployment:

  • Application Name (application_name)
  • Space ID (space_id)
  • Application Version (application_version)
  • Application URIs (application_uris)

This data is collected from the VCAP_APPLICATION environment variable in IBM Bluemix and other Cloud Foundry platforms. This data is used by IBM to track metrics around deployments of sample applications to IBM Bluemix. Only deployments of sample applications that include code to ping the Deployment Tracker service will be tracked.

Disabling Deployment Tracking

Deployment tracking can be disabled by removing require("cf-deployment-tracker-client").track(); from the beginning of the app.js file.

About

Demo showcasing how existing business processes and rules can be augmented with Web RTC and cognitive services to drive customer engagement and help make smarter business decisions.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 98.3%
  • CSS 1.7%