dify插件代码

Junyan Qin (Chin) a577e462c6 feat: add supports for provider to register `array[tool]` type field hace 6 meses
.github 19c1009fb4 test plugin server with mysql hace 6 meses
.script 81c3deb4fa feat: installation script (#14) hace 9 meses
.vscode ba80dcc78d readme (#68) hace 7 meses
cmd 01747753f7 feat: add tests for third-party signature verification hace 6 meses
docker d8861845bd refactor: update tiktoken encoding retrieval to handle full encodings hace 6 meses
docs 309142acf1 bump: cli version (#24) hace 8 meses
internal 94149eb423 Merge pull request #177 from langgenius/fix/use-aws-iam-baseendpoint hace 6 meses
pkg a577e462c6 feat: add supports for provider to register `array[tool]` type field hace 6 meses
tests b19140ca23 refactor: optimize plugin declaration caching and encoding (#34) hace 7 meses
.env.example 6f75bcca43 feat: verify plugin with public keys specified in environment variable in addition to official one hace 6 meses
.gitignore 6bb621c928 fix some time uv venv wrong python version hace 6 meses
LICENSE 41ff75a976 LICENSE (#42) hace 7 meses
README.md f46872048d cohre: UPDATE README.md hace 6 meses
dify.rb 309142acf1 bump: cli version (#24) hace 8 meses
entrypoint.sh 6ba6c9ace7 add entrypoint for service hace 9 meses
go.mod f51249fc29 chore: upgrade ants to v2 hace 6 meses
go.sum f51249fc29 chore: upgrade ants to v2 hace 6 meses

README.md

Dify Plugin Daemon

Overview

Dify Plugin Daemon is a service that manages the lifecycle of plugins. It's responsible for 3 types of runtimes:

  1. Local runtime: runs on the same machine as the Dify server.
  2. Debug runtime: listens to a port to wait for a debugging plugin to connect.
  3. Serverless runtime: runs on a serverless platform such as AWS Lambda.

Dify api server will communicate with the daemon to get all the status of plugins like which plugin was installed to which workspace, and receive requests from Dify api server to invoke a plugin like a serverless function.

All requests from Dify api based on HTTP protocol, but depends on the runtime type, the daemon will forward the request to the corresponding runtime in different ways.

  • For local runtime, daemon will start plugin as the subprocess and communicate with the plugin via STDIN/STDOUT.
  • For debug runtime, daemon wait for a plugin to connect and communicate in full-duplex way, it's TCP based.
  • For serverless runtime, plugin will be packaged to a third-party service like AWS Lambda and then be invoked by the daemon via HTTP protocol.

For more detailed introduction about Dify plugin, please refer to our docs https://docs.dify.ai/plugins/introduction.

Development

Run daemon

Firstly copy the .env.example file to .env and set the correct environment variables like DB_HOST etc.

cp .env.example .env

Attention that the PYTHON_INTERPRETER_PATH is the path to the python interpreter, please specify the correct path according to your python installation and make sure the python version is 3.11 or higher, as dify-plugin-sdk requires.

We recommend you to use vscode to debug the daemon, and a launch.json file is provided in the .vscode directory.

Python environment

UV

Daemon uses uv to manage the dependencies of plugins, before you start the daemon, you need to install uv by yourself.

Interpreter

There is a possibility that you have multiple python versions installed on your machine, a variable PYTHON_INTERPRETER_PATH is provided to specify the python interpreter path for you.

Deployment

Currently, the daemon only supports Linux and MacOS, lots of adaptions are needed for Windows, feel free to contribute if you need it.

Docker

NOTE: Since the daemon depends on a shared cwd directory for running plugins, it's not recommended to use network-based volumes or bind mounts from outside the host machine. This could result in poor performance, such as plugins not launching in a timely manner.

uses docker volume to share the directory with the host machine, it's better for performance.

Kubernetes

For now, Daemon community edition dose not support smoothly scale out with the number of replicas, If you are interested in this feature, please contact us. we have a more production-ready version for enterprise users.

LICENSE

Dify Plugin Daemon is released under the Apache-2.0 license.