Skip to content

Latest commit

 

History

History
80 lines (47 loc) · 3.86 KB

README.md

File metadata and controls

80 lines (47 loc) · 3.86 KB

BotFlow - a platform for creating contents for Rasa chatbots

About the project

BotFlow is a platform developed by LAPPIS - Advanced laboratory of production, research and innovation in Software (FGA/UnB) to facilitate the creation and editing of content inserted in chatbots developed through the Implementation of the Rasa framework for development of chatbot.

This platform is part of a project done by a partnership with Brazil's Ministry of Citizenship, it is used to create the content for Tais, a chatbot for the culture incentive law.

The Architecture

The BotFlow is developed using React JS and Redux for the frontend layer. The backend is developed with Django REST, in the BotFlow API repository.

The frontend is divided in Pages, Components and Ducks:

  • Ducks - The ducks folder contains the actions and reducers for Intents, Uttters and Stories. It configures the store and have all the functions needed for data manipulation and API connection.
  • Components - The application pages are componentized, and this folder contain all its separate compontents.
  • Pages - Contain the website pages.

In Tais architecture, this platform generates the training data.

image

How does it work?

Botflow is a framework for editing Rasa bots contents. Therefore it is used to add and edit intents, utters and stories without managing markdown and yaml files.

Intents

To add the intents, just go to the Questions page and add examples of user's inputs to that intent. You can also edit or delete a intent by selecting it on the sidebar.

Utters

To add utters, just go to the Answers page and add your bot's answer. You can edit or delete a existing utter as well, just select it on the sidebar. The utters may be displayed as sequence or chosed between alternatives.

Stories

A Story is a sequence of intents and utters. To create one, go to Dialogs page and select an existing story or create a new one. You can drag the elements to place it in the correct order. See an example of conversation on the right side of the screen.

Save Content

After all content is ready, click on the Export Content button on the Navbar and it will download the created content.

Running the application

To run application properly you'll have to run the API as well. To do so, clone the API repository and run docker-compose up.

To run the BotFlow on your computer, you'll have to change the API url on Botflow's frontend to where your API is being hosted. If your API is in localhost, open the Dockerfile and change the REACT_APP_URL_API env line to:

ENV REACT_APP_URL_API https://localhost:8000/

If you API is running on another server just place the correct DNS or IP address.

After all API configuration is done, to run the application just run the docker-compose up command.

Run the tests

  • To run the tests use the command on the app/ folder:

    npm test
  • To run the tests and see the final coverage run:

    npm test -- --coverage --watchAll=false

License

The entire BotFlow platform is developed under the license GPL3

View all the license dependencies here.