Hi there, looks like you have already created a Plugin, now let's get you started with the development!
Before start, you need some basic knowledge about the Plugin types, Plugin supports to extend the following abilities in Dify:
- Tool: Tool Providers like Google Search, Stable Diffusion, etc. it can be used to perform a specific task.
- Model: Model Providers like OpenAI, Anthropic, etc. you can use their models to enhance the AI capabilities.
- Endpoint: Like Service API in Dify and Ingress in Kubernetes, you can extend a http service as an endpoint and control its logics using your own code.
Based on the ability you want to extend, we have divided the Plugin into three types: Tool, Model, and Extension.
- Tool: It's a tool provider, but not only limited to tools, you can implement a endpoint there, for example, you need both
Sending Message
andReceiving Message
if you are building a Discord Bot, Tool and Endpoint are both required. - Model: Just a model provider, extending others is not allowed.
- Extension: Other times, you may only need a simple http service to extend the functionalities, Extension is the right choice for you.
I believe you have chosen the right type for your Plugin while creating it, if not, you can change it later by modifying the manifest.yaml
file.
Now you can edit the manifest.yaml
file to describe your Plugin, here is the basic structure of it:
- version(version, required):Plugin's version
- type(type, required):Plugin's type, currently only supports
plugin
, future supportbundle
- author(string, required):作者,在 Marketplace 中定义为组织名
- label(label, required):Multi-language name
- created_at(RFC3339, required):Creation time, Marketplace requires that the creation time must be less than the current time
- icon(asset, required):Icon path
- resource (object):Resources to be applied
- memory (int64):Maximum memory usage, mainly related to resource application on SaaS for serverless, unit bytes
- permission(object):Permission application
- tool(object):Reverse call tool permission
- enabled (bool)
- model(object):Reverse call model permission
- enabled(bool)
- llm(bool)
- text_embedding(bool)
- rerank(bool)
- tts(bool)
- speech2text(bool)
- moderation(bool)
- node(object):Reverse call node permission
- enabled(bool)
- endpoint(object):Allow to register endpoint permission
- enabled(bool)
- app(object):Reverse call app permission
- enabled(bool)
- storage(object):Apply for persistent storage permission
- enabled(bool)
- size(int64):Maximum allowed persistent memory, unit bytes
- tool(object):Reverse call tool permission
- plugins(object, required):Plugin extension specific ability yaml file list, absolute path in the plugin package, if you need to extend the model, you need to define a file like openai.yaml, and fill in the path here, and the file on the path must exist, otherwise the packaging will fail.
- Format
- tools(list[string]): Extended tool suppliers, as for the detailed format, please refer to Tool Guide
- models(list[string]):Extended model suppliers, as for the detailed format, please refer to Model Guide
- endpoints(list[string]):Extended Endpoints suppliers, as for the detailed format, please refer to Endpoint Guide
- Restrictions
- Not allowed to extend both tools and models
- Not allowed to have no extension
- Not allowed to extend both models and endpoints
- Currently only supports up to one supplier of each type of extension
- Format
- meta(object)
- version(version, required):manifest format version, initial version 0.0.1
- arch(list[string], required):Supported architectures, currently only supports amd64 arm64
- runner(object, required):Runtime configuration
- language(string):Currently only supports python
- version(string):Language version, currently only supports 3.12
- entrypoint(string):Program entry, in python it should be main
- First of all, you need a Python 3.10+ environment, as our SDK requires that.
- Then, install the dependencies:
pip install -r requirements.txt
- If you want to add more dependencies, you can add them to the
requirements.txt
file, once you have set the runner to python in themanifest.yaml
file,requirements.txt
will be automatically generated and used for packaging and deployment.
Now you can start to implement your Plugin, by following these examples, you can quickly understand how to implement your own Plugin:
- OpenAI: best practice for model provider
- Google Search: a simple example for tool provider
- Neko: a funny example for endpoint group
You may already noticed that a .env.example
file in the root directory of your Plugin, just copy it to .env
and fill in the corresponding values, there are some environment variables you need to set if you want to debug your Plugin locally.
INSTALL_METHOD
: Set this toremote
, your plugin will connect to a Dify instance through the network.REMOTE_INSTALL_HOST
: The host of your Dify instance, you can use our SaaS instancehttps://debug.dify.ai
, or self-hosted Dify instance.REMOTE_INSTALL_PORT
: The port of your Dify instance, default is 5003REMOTE_INSTALL_KEY
: You should get your debugging key from the Dify instance you used, at the right top of the plugin management page, you can see a button with adebug
icon, click it and you will get the key.
Run the following command to start your Plugin:
python -m main
Refresh the page of your Dify instance, you should be able to see your Plugin in the list now, but it will be marked as debugging
, you can use it normally, but not recommended for production.
After all, just package your Plugin by running the following command:
dify-plugin plugin package ./ROOT_DIRECTORY_OF_YOUR_PLUGIN
you will get a plugin.difypkg
file, that's all, you can submit it to the Marketplace now, look forward to your Plugin being listed!