langflow-streamlit
is a powerful API that bridges the gap between Langflow and Streamlit applications. This library seamlessly integrates Langflow's advanced language processing capabilities with Streamlit's user-friendly interface, enabling developers to create interactive applications that harness the power of sophisticated language models.
Important: To use this library effectively, you need to set up a Langflow Store Key. This key allows you to access and use flows and components from the Langflow Store. For more information on setting up your Langflow Store Key, please refer to the Langflow documentation.
- Seamless Integration: Effortlessly establish communication between Langflow and Streamlit with minimal configuration.
- Streamlined Deployment: Quickly install and run the API using either
pip
orpoetry
. - Flexible Execution Options: Choose to run the full stack (Langflow + Streamlit API) or just the Streamlit backend with API.
- Langflow Store Integration: Access and utilize pre-built flows and Streamlit components from the Langflow Store to enhance your applications.
- Python 3.10 or higher
python3 -m venv env
source env/bin/activate
pip install langflow-streamlit==0.1.8
-
Clone the repository:
git clone https://github.com/yaitec/langflow-streamlit.git cd langflow-streamlit
-
Install Poetry if you haven't already:
pip install poetry
-
Install the project dependencies:
poetry install
If choose pip installation option
-
Run the full stack (Langflow, API, and Streamlit):
python -m langflow-streamlit run
-
Run only the Streamlit backend and API:
python -m langflow-streamlit run --streamlit-only
If choose clone the repository option
-
Run the full stack (Langflow, API, and Streamlit):
make start
-
Run only the Streamlit backend and API:
make start-streamlit-only
Note: Running only the Streamlit backend is useful when you want to use Langflow-created flows in your Streamlit application without running the full Langflow instance.
Open the URLs below in your browser
- Streamlit Chat:: Available at http://localhost:5001.
- Streamlit API: The API Documentation can abe accessed at http://localhost:7881/docs.
- Langflow: Available at http://localhost:7860.
The gif below shows how to search, download, and run Streamlit's flow:
The gif below shows how to use Listen
and Send
components:
Langflow provides pre-built Streamlit components that can be accessed through the Langflow store. These components enhance your Streamlit applications with powerful functionality:
- Send: Send messages to a Streamlit chat session.
- Listen: Listen for incoming messages in a Streamlit chat, dynamically updating the layout of the Streamlit application.
To use these components:
- Access the Langflow store within your Langflow instance.
- Search for and download the desired Streamlit component.
- Integrate the component into your Langflow workflow.
- Connect the component to your Streamlit application using the
langflow-streamlit
API.
For detailed instructions on using Streamlit components, refer to the Usage section below.
Variable | Description | Default |
---|---|---|
STREAMLIT_ONLY | If True, runs only Streamlit and Streamlit API; else, runs Langflow too | False |
LOG_LEVEL | Defines log level of library | "info" |
LOG_FILE_GENERATION | If True, creates a langflow-streamlit.log file for debug purpose and overrides LOG_LEVEL to 'debug' | False |
You can learn how to set environment variables for each alternative bellow, click in the arrow that correlated to installation option that you choosed and check how to setup it properly.
If you choose pip installation option
these are the options that you can set:langflow-streamlit --streamlit-only --log-level error --log-file-generation
If you choose clone the repository option
-
Setting it in zsh or bash
export STREAMLIT_ONLY=True LOG_LEVEL=debug LOG_FILE_GENERATION=True
-
Setting it in PowerShell
$env:STREAMLIT_ONLY = "True" $env:LOG_LEVEL = "debug" $env:LOG_FILE_GENERATION = "True"
-
Run the full stack:
poetry run langflow-streamlit run
-
Run only the Streamlit frontend and API backend:
poetry run langflow-streamlit run --streamlit-only
-
Run the full stack:
make start
-
Run only the Streamlit frontend and API backend:
make start-streamlit-only
-
Check the other available commands:
make help
To set up the development environment:
-
Clone the repository (if you haven't already).
-
Enter inside the cloned repository directory.
cd <repository_path>
-
Install development dependencies:
poetry install --with dev
-
Run tests:
make test
-
Check code style:
make lint
We welcome contributions! Please feel free to submit a Pull Request or open an Issue on the GitHub repository.
- Fork the repository
- Create your feature branch (
git checkout -b feature/AmazingFeature
) - Commit your changes (
git commit -m 'Add some AmazingFeature'
) - Push to the branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
This project is licensed under the MIT License. See the LICENSE file for details.
YAITEC - [email protected]
Project Link: https://github.com/yaitec/langflow-streamlit