Build Conversational AI.
Project description
Welcome to Chainlit 👋
Build python production-ready conversational AI applications in minutes, not weeks ⚡️
⚠️ Notice: Chainlit is now community-maintained.
As of May 1st 2025, the original Chainlit team has stepped back from active development. The project is maintained by @Chainlit/chainlit-maintainers under a formal Maintainer Agreement.
Maintainers are responsible for code review, releases, and security.
Chainlit SAS provides no warranties on future updates.Want to help maintain? Apply here →
Website • Documentation • Chainlit Help • Cookbook
https://github.com/user-attachments/assets/b3738aba-55c0-42fa-ac00-6efd1ee0d148
Installation
Open a terminal and run:
pip install chainlit
chainlit hello
If this opens the hello app in your browser, you're all set!
Development version
The latest in-development version can be installed straight from GitHub with:
pip install git+https://github.com/Chainlit/chainlit.git#subdirectory=backend/
(Requires Node and pnpm installed on the system.)
🚀 Quickstart
🐍 Pure Python
Create a new file demo.py with the following code:
import chainlit as cl
@cl.step(type="tool")
async def tool():
# Fake tool
await cl.sleep(2)
return "Response from the tool!"
@cl.on_message # this function will be called every time a user inputs a message in the UI
async def main(message: cl.Message):
"""
This function is called every time a user inputs a message in the UI.
It sends back an intermediate response from the tool, followed by the final answer.
Args:
message: The user's message.
Returns:
None.
"""
# Call the tool
tool_res = await tool()
await cl.Message(content=tool_res).send()
Now run it!
chainlit run demo.py -w
📚 More Examples - Cookbook
You can find various examples of Chainlit apps here that leverage tools and services such as OpenAI, Anthropiс, LangChain, LlamaIndex, ChromaDB, Pinecone and more.
Tell us what you would like to see added in Chainlit using the Github issues or on Discord.
💁 Contributing
As an open-source initiative in a rapidly evolving domain, we welcome contributions, be it through the addition of new features or the improvement of documentation.
For detailed information on how to contribute, see here.
📃 License
Chainlit is open-source and licensed under the Apache 2.0 license.
Database backend selection (Postgres vs SQLite)
Chainlit supports two data layers:
- Postgres (default): high-scale, uses asyncpg
- SQLite: simple local persistence, uses SQLAlchemy + aiosqlite
Select the backend via the DATABASE_URL environment variable:
- Postgres example:
DATABASE_URL=postgresql+asyncpg://user:pass@host:5432/db - SQLite example:
DATABASE_URL=sqlite+aiosqlite:///./chainlit.db
Notes
- When DATABASE_URL starts with
sqlite, Chainlit will automatically use the SQLAlchemy data layer. - To force a specific implementation, set CHAINLIT_DATA_LAYER:
CHAINLIT_DATA_LAYER=sqlalchemyto force SQLAlchemy (e.g., for SQLite)CHAINLIT_DATA_LAYER=asyncpgto force Postgres implementation
- Cloud storage (S3/GCS/Azure) configuration is shared across both data layers via environment variables (
BUCKET_NAME,APP_AWS_*,APP_GCS_*,APP_AZURE_*). - Schema: Chainlit does not manage database migrations. Ensure required tables exist before running. For SQLite quick starts, see tests at
backend/tests/data/test_sql_alchemy.pyfor create table statements you can adapt. - Schema: Chainlit does not manage database migrations. Ensure required tables exist before running. For SQLite quick starts, use
backend/chainlit/data/sqlite_schema.sql.
Quick start for SQLite (optional)
- Create the database file and schema (one-time):
- On macOS/Linux:
sqlite3 chainlit.db < backend/chainlit/data/sqlite_schema.sql
- On macOS/Linux:
- Run Chainlit with:
DATABASE_URL=sqlite+aiosqlite:///./chainlit.db chainlit run demo.py
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 Distribution
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 chainlit_chandru20-2.8.2.tar.gz.
File metadata
- Download URL: chainlit_chandru20-2.8.2.tar.gz
- Upload date:
- Size: 9.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1571e14190493c9744aef1eb36872b9c45a3c746327eda5acf122541a40d2fd7
|
|
| MD5 |
aa1501e544636ae339c0186b5952ca91
|
|
| BLAKE2b-256 |
161af6bd7e6d32434f8eefb504fe148be76a3cf798b6837698e4465b63183e9f
|
File details
Details for the file chainlit_chandru20-2.8.2-py3-none-any.whl.
File metadata
- Download URL: chainlit_chandru20-2.8.2-py3-none-any.whl
- Upload date:
- Size: 9.7 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d3c8074a5b18cac79bae46160f44d45f0fde34ce869e048f82362f3224134316
|
|
| MD5 |
46256a5ca03b5ad20a3c9ca54b5b4a44
|
|
| BLAKE2b-256 |
d54e0c59c0238331418e772aa1f2e09fc3ac0b7bcb390154bd1d9abb5272bd4c
|