Booking Service Bot
Connect your bots to databases through DatabaseWorkers
Intro
In this tutorial, we'll walk through building a booking performance bot using Agent First Organization's framework. This bot will be able to handle common customer inquiries, such as find show's availabilities, booking shows, retrieve performance schedule, and modifying or cancelling existing bookings. The tutorial aims to provide a next step up from simple Q&A conversational AIs to a powerful bot that can integrate directly with databases and tools used in many workplaces.
By the end of this tutorial, you'll know how to use external tooling workers specifically integrating with a database. This tutorial demonstrates a workers served as an entry into deeper and more complex capabilities.
Setting up the Config File
Previously, we had nodes that were able to read from various files and sources to compose an answer. Here, we will take it a step further. Instead of just reading, we will also be interacting with database and writing record into database. This could be done through the built-in DatabaseWorker.
As a refresher, here is the structure for a Config JSON file:
role (Required)
: The general "role" of the chatbot you want to create. For instance, "customer service assistant", "data analyst", "shopping assistant", etc.user_objective (Required)
: The user's goal that the chatbot wants to achieve. Related to the user experience. Description in third person. For instance, "The customer service assistant helps users with customer service inquiries. It can provide information about products, services, and policies, as well as help users resolve issues and complete transactions."builder_objective (Optional)
: The additional target you want the chatbot to achieve beyond the user's goal. Can contain hidden objectives or subtle objectives which is hidden from the user. Describe in third person. For instance, "The customer service assistant helps to request customer's contact information."domain (Optional)
: The domain that you want to create the chatbot for. For instance, "robotics and automation", "Ecommerce", "Healthcare", etc.intro (Optional)
: The introduction of the above domain that you want to create the chatbot for. It should contain the information about the domain, the products, services, and policies, etc.task_docs (Optional, List[Dict])
: The documents resources for the taskgraph generation to create the chatbot. Each item in the list should contain the following fields:source (Required)
: The source url that you want the chatbot to refer todesc (Optional)
: Short description of the source and how it is usednum (Optional)
: The number of websites that you want the chatbot to refer to for the source, defaults to one (only the url page)
rag_docs (Optional, List[Dict])
: If you want to use RAGWorker, then here indicates the documents for the RAG component of chatbot when running chatbot. Each item in the list should contain the following fields:source (Required)
: The source url that you want the chatbot to refer todesc (Optional)
: Short description of the source and how it is usednum (Optional)
: The number of websites that you want the chatbot to refer to for the source, defaults to one (only the url page)
tasks (Optional, List(Dict))
: The pre-defined list of tasks that the chatbot need to handle. If empty, the system will generate the tasks and the steps to complete the tasks based on the role, objective, domain, intro and docs fields. The more information you provide in the fields, the more accurate the tasks and steps will be generated. If you provide the tasks, it should contain the following fields:task_name (Required, Str)
: The task that the chatbot need to handlesteps (Required, List(Str))
: The steps to complete the task
workers (Required, List(WorkerClassName))
: The Workers pre-defined underagentorg/workers
folder in the codebase that you want to use for the chatbot.
Now, lets see it with the Booking Assistant example. Here, we have a sample Config file of a Booking Assistant for a performance company - The Irish Repertory Theatre.
{
"role": "booking assistant",
"user_objective": "The booking assistant helps users book tickets for the show. It can provide information about events, venues, and ticket availability, as well as help users complete the booking process. It can also provide recommendations based on user preferences.",
"builder_objective": "The booking assistant ask for user feedback at the end of the conversation.",
"domain": "Theatre",
"intro": "The mission of Irish Repertory Theatre is to provide a context for understanding the contemporary Irish-American experience through evocative works of theater, music, and dance. This mission is accomplished by staging the works of Irish and Irish-American classic and contemporary playwrights, encouraging the development of new works focused on the Irish and Irish-American experience, and producing the works of other cultures interpreted through the lens of an Irish sensibility.",
"task_docs": [{
"source": "https://irishrep.org/",
"num": 10
}],
"tasks": [],
"workers": [
"MessageWorker",
"DatabaseWorker",
"DefaultWorker"
]
}
With our Config in place, the vast majority of work is surprisingly already done! The rest is simply bringing the bot to life.
Generating a TaskGraph
Now that we have a Config file, generating the graph is the easy part. All you need to do is run
python create.py --config ./examples/booking_assistant_config.json --output-dir ./examples/booking_system
It will first enter into a task planning interactive panel where you can see the generated tasks this bot will handle and the following steps to complete the specific tasks. You can also modify the tasks and steps as needed. Once you are satisfied with result, you could press s
to save the task planning file then it will further generate the final TaskGraph file.
TaskGraph provides the graph that the bot will traverse through during the conversation. It provides a guideline for the conversation to make it more controllable and reliable. The details can be viewed at here.
It will also prepare the database for the bot. The details can be viewed at DatabaseWorker.
Notice: The database content we used in this tutorial is a fake database for demonstration purposes. You can replace it with your own database content.
Running the Bot
With the TaskGraph in place, we can run the bot on the TaskGraph with
python run.py --input-dir ./examples/booking_system
It will initialize the service (e.g. NLU apis) you need to start the bot and you can start interacting with it!
Sample Conversation
ASSISTANT: Hello and welcome to our Booking Assistant! I'm here to help you find and book tickets for your favorite shows. Let me know what event you're interested in, and I'll provide you with information on venues, availability, and more!
USER: Are there any shows in Houston?
ASSISTANT: I'm here to help you with your search! Could you let me know what type of events you're interested in, or if you have any specific genres, locations, or dates in mind? That way, I can provide you with more tailored information about shows in Houston.
USER: I am looking for shows in January
ASSISTANT: In January, there's a show called "Beckett Briefs" that will be performed in Houston. It's scheduled for January 15, 2025, at 6:30 PM at the Houston Grand Opera. The show explores themes of existentialism and the human condition through Samuel Beckett's distinctive style. Tickets are priced at $65. Would you like to book tickets for this show or need more information?
USER: Sounds great, can I book 4 tickets for that?
ASSISTANT: I'd be happy to help you book 4 tickets for "Beckett Briefs" on January 15, 2025, at the Houston Grand Opera. Currently, there are several seating options available for "Beckett Briefs" at the Houston Grand Opera:
- Orchestra Level - $65 per ticket
- Mezzanine Level - $55 per ticket
- Balcony Level - $45 per ticket
Please let me know which seating option you would prefer, and I can proceed with the booking. Just to confirm, you have selected [seat details]. Is that correct?
USER: Can we have 4 Mezzanine Level tickets?
ASSISTANT: Sure, I can reserve 4 Mezzanine Level tickets for "Beckett Briefs" on January 15, 2025, at the Houston Grand Opera. The total cost will be $220. Let me know if you'd like to proceed with the booking or if you need any further assistance.
Additionally, I would love to hear your feedback on the assistance provided today. Your input is valuable and helps improve the service.
USER: Can we proceed with the booking? Thank you!
ASSISTANT: Great! I'll proceed with booking 4 Mezzanine Level tickets for "Beckett Briefs" on January 15, 2025, at the Houston Grand Opera. You will receive a confirmation shortly with all the details.
Thank you for choosing our service! Here are some events that match your interests:
- Event 1: "Irish Dance Extravaganza" on February 10, 2025, at 7:00 PM, featuring traditional Irish dance and music.
- Event 2: "Celtic Music Night" on March 5, 2025, at 8:00 PM, showcasing contemporary and classic Irish tunes.
I hope you enjoy the show, and please feel free to share any feedback on your experience with our booking service. Your input helps us improve!
Evaluation
For a task-oriented dialogue system, you could use the evaluation script to automatically generate synthetic conversations, extracting task completion metrics for evaluating the whole system. For more details, please refer to the evaluation documentation.
-
First, create an API for the Agent you built. It will start an API on the default port 8000.
python model_api.py --input-dir ./examples/booking_system
-
Then, start the evaluation process:
python eval.py \
--model_api http://127.0.0.1:8000/eval/chat \
--config ./examples/booking_assistant_config.json \
--documents_dir ./examples/booking_system \
--output-dir ./examples/booking_system
Evaluation Results
The evaluation will generate the following outputs in the specified output directory:
-
Simulated Synthetic Dataset (
simulate_data.json
)- JSON file containing simulated conversations generated based on the user's objective to evaluate the task success rate.
-
Labeled Synthetic Dataset (
labeled_data.json
)- JSON file containing labeled conversations generated based on the taskgraph to evaluate the NLU performance.
-
Goal Completion Metrics (
goal_completion.json
)- JSON file summarizing task completion statistics based on the bot's ability to achieve specified goals.