A django Whatsapp chatbot session manager
Project description
WhatsApp Chatbot Session Flow
Overview
This package provides a Django-based session management system for building a WhatsApp chatbot. It enables:
- Dynamic page-based navigation
- Session tracking
- Dynamic method execution for custom tasks (e.g., adding to cart)
- Middleware support
- Admin integration
Installation
Install the package via pip:
pip install chatbot_session_flow
Environment Variables
Set the following environment variables in your shell or a .env file:
export pub_key=""
export secret=""
export SECRET_KEY="xx56r_@x_jb8(rqiw5+xw^+@l#m(=%9h+!98k1o$ex3_zogx"
export MODE=dev
export DEBUG=True
export DB_NAME=<dbname>
export DB_USER=<db connection user>
export DB_PASSWORD=<database password>
export DB_HOST="<database connection host>"
export DB_PORT=<database running port>
export NGUMZO_API_KEY=<your api key if using ngumzo APIs>
export DYNAMIC_METHOD_VIEWS="<your_app.dynamic_methods>"
Django Settings
Add it to your INSTALLED_APPS:
INSTALLED_APPS = [
...,
'chatbot_session_flow',
]
Add middleware to enable session handling:
MIDDLEWARE = [
...,
'chatbot_session_flow.middleware.WhatsappSessionMiddleware',
]
Migrations
Run the migrations:
python manage.py makemigrations chatbot_session_flow
python manage.py migrate chatbot_session_flow
Internal Logic
The chatbot flow is managed through a sequence of Page instances. Each page can reference the next, allowing dynamic navigation.
Sessions are tied to users via the Session and Stepper models.
Dynamic Methods
Custom tasks such as saving data, calling APIs, or formatting messages are handled by dynamic methods specified in a dynamic file defined by DYNAMIC_METHOD_VIEWS. These include:
sendWhatsappMessage(session, phoneNumber, message)– your logic to send messages.formatRequest(request)– used by middleware to shape incoming data.- Any task-specific functions (e.g.,
add_to_cart) that can be dynamically executed.
Dynamic Method Example
# your_app/dynamic_methods.py
def add_to_cart(session, page, message, *args, **kwargs):
print(f"Adding product to cart for user {session.user.phoneNumber}")
return "Item added to cart"
Call it dynamically:
from chatbot_session_flow.views import perform_dynamic_action
response = perform_dynamic_action(session, page, "Item name")
Dynamic Message Templating
Use collected data within page content dynamically:
Hello {firstName}, your order has been placed!
The values in {} are replaced by corresponding session or user data.
Models
Profile
Handles user identity:
from chatbot_session_flow.models import Profile
profile = Profile.objects.create(
firstName="John",
lastName="Doe",
phoneNumber="+1234567890",
email="john@example.com"
)
Session
Tracks the user’s chatbot session:
session = Session.objects.create(user=profile, isValidSession=True)
print(session.is_session_expired())
Page
Each page drives a single step in the conversation:
page = Page.objects.create(title="Welcome", pageType="text", content="Hello {firstName}")
Common Issues & Fixes
No Migrations Detected
- Ensure your environment is correct.
- Use
pip install -e .if developing locally. - Run:
python manage.py makemigrations chatbot_session_flow python manage.py migrate
Dynamic Methods Not Found or Not Executing
- Confirm the file path in
DYNAMIC_METHOD_VIEWSis correct. - Check that the function name matches the
taskattribute in yourPage. - Ensure the function signature accepts dynamic args/kwargs:
def custom_task(session, page, message, *args, **kwargs): ...
known Issues
- As of yet there are no knows issues but you are encouragedd to test and create github issues for any issues faced in your development.
- Feel free to reachout To me via email
kamadennis05@gmail.com
Conclusion
This package offers a powerful framework for building WhatsApp-based conversational flows with dynamic logic and session handling. Feel free to contribute or extend the package to fit your business logic!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file chatbot_session_flow-0.1.11-py3-none-any.whl.
File metadata
- Download URL: chatbot_session_flow-0.1.11-py3-none-any.whl
- Upload date:
- Size: 11.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d42d5800c063e9b881c195a45d20acac14e510c890fb2a1bcab7ef36eae96daf
|
|
| MD5 |
af4d1d0b75c70fc857146159238380bd
|
|
| BLAKE2b-256 |
14c1cb456181884c6c3fffac26df11f1bcd231c94182e55029aec59b75a33f30
|