Build Conversational AI.
Project description
Welcome to Chainlit by Literal AI 👋
Build production-ready Conversational AI applications in minutes, not weeks ⚡️
Chainlit is an open-source async Python framework which allows developers to build scalable Conversational AI or agentic applications.
- ✅ ChatGPT-like application
- ✅ Embedded Chatbot & Software Copilot
- ✅ Slack & Discord
- ✅ Custom frontend (build your own agentic experience)
- ✅ API Endpoint
Full documentation is available here. You can ask Chainlit related questions to Chainlit Help, an app built using Chainlit!
[!NOTE] Check out Literal AI, our product to monitor and evaluate LLM applications! It works with any Python or TypeScript applications and seamlessly with Chainlit by adding a
LITERAL_API_KEY
in your project.Chainlit is developed and maintained by the Literal AI team, which is currently focused on expanding the capabilities of Literal AI. While we continue to support and maintain Chainlit, we are also committed to enabling the community to contribute, particularly in areas like integrations and data layers.
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
🎉 Key Features and Integrations
Full documentation is available here. Key features:
- 💬 Multi Modal chats
- 💭 Chain of Thought visualization
- 💾 Data persistence + human feedback
- 🐛 Debug Mode
- 👤 Authentication
Chainlit is compatible with all Python programs and libraries. That being said, it comes with integrations for:
📚 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.
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
File details
Details for the file chainlit-2.0.dev2.tar.gz
.
File metadata
- Download URL: chainlit-2.0.dev2.tar.gz
- Upload date:
- Size: 4.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 60ddff1878cbddbdf173039c042831017ae3414080696e8b08fce938e4fccf0e |
|
MD5 | 93bff41872d6d34de9742a3ec4efc045 |
|
BLAKE2b-256 | 390907d4c6c5195e7e780a13e2912e248a544c009d30421c5bb3044990eb30d0 |
File details
Details for the file chainlit-2.0.dev2-py3-none-any.whl
.
File metadata
- Download URL: chainlit-2.0.dev2-py3-none-any.whl
- Upload date:
- Size: 4.5 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c7a73b7018da8e318f13db7c39ac108d4e4df9b07bae1d29c7f086e8df73c1b8 |
|
MD5 | 00be80e4830975ceca962a6bd4467a6c |
|
BLAKE2b-256 | e674b230a1a07432599c7c3f8341877a7881640a8278a8933ca22d86823cd09a |