English | 中文
We appreciate any form of contributions.
Star and share the Github Repo.
Search up for any questions in Q&A section, if you can't find one, don't hesitate to create one. It might helps others that have similar question.
Yes! Sharing how you use Flowise is a way of contribution. Export your chatflow as JSON, attach a screenshot and share it in Show and Tell section.
Ideas are welcome such as new feature, apps integration, and blockchain networks. Submit in Ideas section.
Found an issue? Report it.
Not sure what to contribute? Some ideas:
- Create new components from
packages/components
- Update existing components such as extending functionality, fixing bugs
- Add new chatflow ideas
Flowise has 3 different modules in a single mono repository.
server
: Node backend to serve API logicsui
: React frontendcomponents
: Third-party nodes integrations
- Install PNPM. The project is configured to use pnpm v9.
npm i -g pnpm
-
Fork the official Flowise Github Repository.
-
Clone your forked repository.
-
Create a new branch, see guide. Naming conventions:
- For feature branch:
feature/<Your New Feature>
- For bug fix branch:
bugfix/<Your New Bugfix>
.
- For feature branch:
-
Switch to the newly created branch.
-
Go into repository folder
cd Flowise
-
Install all dependencies of all modules:
pnpm install
-
Build all the code:
pnpm build
-
Start the app on http://localhost:3000
pnpm start
-
For development:
- Create
.env
file and specify theVITE_PORT
(refer to.env.example
) inpackages/ui
- Create
.env
file and specify thePORT
(refer to.env.example
) inpackages/server
- Run
pnpm dev
Any changes made in
packages/ui
orpackages/server
will be reflected on http://localhost:8080For changes made in
packages/components
, runpnpm build
again to pickup the changes. - Create
-
After making all the changes, run
pnpm build
and
pnpm start
to make sure everything works fine in production.
-
Commit code and submit Pull Request from forked branch pointing to Flowise master.
Flowise support different environment variables to configure your instance. You can specify the following variables in the .env
file inside packages/server
folder. Read more
Variable | Description | Type | Default |
---|---|---|---|
PORT | The HTTP port Flowise runs on | Number | 3000 |
CORS_ORIGINS | The allowed origins for all cross-origin HTTP calls | String | |
IFRAME_ORIGINS | The allowed origins for iframe src embedding | String | |
FLOWISE_USERNAME | Username to login | String | |
FLOWISE_PASSWORD | Password to login | String | |
FLOWISE_FILE_SIZE_LIMIT | Upload File Size Limit | String | 50mb |
DISABLE_CHATFLOW_REUSE | Forces the creation of a new ChatFlow for each call instead of reusing existing ones from cache | Boolean | |
DEBUG | Print logs from components | Boolean | |
LOG_PATH | Location where log files are stored | String | your-path/Flowise/logs |
LOG_LEVEL | Different levels of logs | Enum String: error , info , verbose , debug |
info |
LOG_JSON_SPACES | Spaces to beautify JSON logs | 2 | |
APIKEY_STORAGE_TYPE | To store api keys on a JSON file or database. Default is json |
Enum String: json , db |
json |
APIKEY_PATH | Location where api keys are saved when APIKEY_STORAGE_TYPE is json |
String | your-path/Flowise/packages/server |
TOOL_FUNCTION_BUILTIN_DEP | NodeJS built-in modules to be used for Tool Function | String | |
TOOL_FUNCTION_EXTERNAL_DEP | External modules to be used for Tool Function | String | |
DATABASE_TYPE | Type of database to store the flowise data | Enum String: sqlite , mysql , postgres |
sqlite |
DATABASE_PATH | Location where database is saved (When DATABASE_TYPE is sqlite) | String | your-home-dir/.flowise |
DATABASE_HOST | Host URL or IP address (When DATABASE_TYPE is not sqlite) | String | |
DATABASE_PORT | Database port (When DATABASE_TYPE is not sqlite) | String | |
DATABASE_USER | Database username (When DATABASE_TYPE is not sqlite) | String | |
DATABASE_PASSWORD | Database password (When DATABASE_TYPE is not sqlite) | String | |
DATABASE_NAME | Database name (When DATABASE_TYPE is not sqlite) | String | |
DATABASE_SSL_KEY_BASE64 | Database SSL client cert in base64 (takes priority over DATABASE_SSL) | Boolean | false |
DATABASE_SSL | Database connection overssl (When DATABASE_TYPE is postgre) | Boolean | false |
SECRETKEY_PATH | Location where encryption key (used to encrypt/decrypt credentials) is saved | String | your-path/Flowise/packages/server |
FLOWISE_SECRETKEY_OVERWRITE | Encryption key to be used instead of the key stored in SECRETKEY_PATH | String | |
DISABLE_FLOWISE_TELEMETRY | Turn off telemetry | Boolean | |
MODEL_LIST_CONFIG_JSON | File path to load list of models from your local config file | String | /your_model_list_config_file_path |
STORAGE_TYPE | Type of storage for uploaded files. default is local |
Enum String: s3 , local |
local |
BLOB_STORAGE_PATH | Local folder path where uploaded files are stored when STORAGE_TYPE is local |
String | your-home-dir/.flowise/storage |
S3_STORAGE_BUCKET_NAME | Bucket name to hold the uploaded files when STORAGE_TYPE is s3 |
String | |
S3_STORAGE_ACCESS_KEY_ID | AWS Access Key | String | |
S3_STORAGE_SECRET_ACCESS_KEY | AWS Secret Key | String | |
S3_STORAGE_REGION | Region for S3 bucket | String | |
S3_ENDPOINT_URL | Custom Endpoint for S3 | String | |
SHOW_COMMUNITY_NODES | Show nodes created by community | Boolean |
You can also specify the env variables when using npx
. For example:
npx flowise start --PORT=3000 --DEBUG=true
A member of the FlowiseAI team will automatically be notified/assigned when you open a pull request. You can also reach out to us on Discord.
This project and everyone participating in it are governed by the Code of Conduct which can be found in the file. By participating, you are expected to uphold this code. Please report unacceptable behavior to hello@flowiseai.com.