How to contribute?
This page may contain outdated information. It will be updated as soon as possible.
👋 Hello there!
We welcome contributions from developers of all levels to our open-source project on GitHub. If you'd like to contribute, please check our contributing guidelines and help make Langflow more accessible.
As an open-source project in a rapidly developing field, we are extremely open to contributions, whether in the form of a new feature, improved infra, or better documentation.
To contribute to this project, please follow a "fork and pull request" workflow. Please do not try to push directly to this repo unless you are a maintainer.
Local Development
You can develop Langflow using docker compose, or locally.
We provide a .vscode/launch.json file for debugging the backend in VSCode, which is a lot faster than using docker compose.
Setting up hooks:
make init
This will install the pre-commit hooks, which will run make format on every commit.
It is advised to run make lint before pushing to the repository.
Run Locally
Langflow can run locally by cloning the repository and installing the dependencies. We recommend using a virtual environment to isolate the dependencies from your system.
Before you start, make sure you have the following installed:
- Poetry (>=1.4)
- Node.js
Then, in the root folder, install the dependencies and start the development server for the backend:
make backend
And the frontend:
make frontend
Docker Compose
The following snippet will run the backend and frontend in separate containers. The frontend will be available at localhost:3000 and the backend at localhost:7860.
docker compose up --build# ormake dev build=1
Documentation
The documentation is built using Docusaurus. To run the documentation locally, run the following commands:
cd docsnpm installnpm run start
The documentation will be available at localhost:3000 and all the files are located in the docs/docs folder. Once you are done with your changes, you can create a Pull Request to the main branch.
Submitting Components
New components are added as objects of the CustomComponent class and any dependencies are added to the pyproject.toml file.
Add an example component
You have a new document loader called MyCustomDocumentLoader and it would look awesome in Langflow.
- Write your loader as an object of the CustomComponent class. You'll create a new class,
MyCustomDocumentLoader, that will inherit fromCustomComponentand override the base class's methods. - Define optional attributes like
display_name,description, anddocumentationto provide information about your custom component. - Implement the
build_configmethod to define the configuration options for your custom component. - Implement the
buildmethod to define the logic for taking input parameters specified in thebuild_configmethod and returning the desired output. - Add the code to the /components/documentloaders folder.
- Add the dependency to /documentloaders/init.py as
from .MyCustomDocumentLoader import MyCustomDocumentLoader. - Add any new dependencies to the outer pyproject.toml file.
- Submit documentation for your component. For this example, you'd submit documentation to the loaders page.
- Submit your changes as a pull request. The Langflow team will have a look, suggest changes, and add your component to Langflow.
User Sharing
You might want to share and test your custom component with others, but don't need it merged into the main source code.
If so, you can share your component on the Langflow store.
-
Undergo pre-validation before receiving an API key.
-
To deploy your amazing component directly to the Langflow store, without it being merged into the main source code, navigate to your flow, and then click Share. The share window appears:

-
Choose whether you want to flow to be public or private. You can also Export your flow as a JSON file from this window. When you're ready to share the flow, click Share Flow. You should see a Flow shared successfully popup.
-
To confirm, navigate to the Langflow Store and filter results by Created By Me. You should see your new flow on the Langflow Store.
