-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
222 additions
and
30 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
package init | ||
|
||
import ( | ||
_ "embed" | ||
) | ||
|
||
//go:embed templates/README.md | ||
var README []byte |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
## {{ .PluginName }} | ||
|
||
**Author:** {{ .Author }} | ||
**Version:** {{ .Version }} | ||
**Date:** {{ .Date }} | ||
**Type:** {{ .Category }} | ||
|
||
### Description | ||
|
||
{{ .Description }} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
INSTALL_METHOD=REMOTE | ||
REMOTE_INSTALL_HOST=debug-plugin.dify.dev | ||
REMOTE_INSTALL_PORT=5003 | ||
REMOTE_INSTALL_KEY=********-****-****-****-************ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
## User Guide of how to develop a Dify Plugin | ||
|
||
Hi there, looks like you have already created a Plugin, now let's get you started with the development! | ||
|
||
### Choose a Plugin type you want to develop | ||
|
||
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` and `Receiving 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. | ||
|
||
### Manifest | ||
|
||
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 support `bundle` | ||
- 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 | ||
- 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](https://docs.dify.ai/docs/plugins/standard/tool_provider) | ||
- models(list[string]):Extended model suppliers, as for the detailed format, please refer to [Model Guide](https://docs.dify.ai/docs/plugins/standard/model_provider) | ||
- endpoints(list[string]):Extended Endpoints suppliers, as for the detailed format, please refer to [Endpoint Guide](https://docs.dify.ai/docs/plugins/standard/endpoint_group) | ||
- 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 | ||
- 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 | ||
|
||
### Install Dependencies | ||
|
||
- First of all, you need a Python 3.10+ environment, as our SDK requires that. | ||
- Then, install the dependencies: | ||
```bash | ||
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 the `manifest.yaml` file, `requirements.txt` will be automatically generated and used for packaging and deployment. | ||
|
||
### Implement the Plugin | ||
|
||
Now you can start to implement your Plugin, by following these examples, you can quickly understand how to implement your own Plugin: | ||
|
||
- [OpenAI](https://github.com/langgenius/dify-plugin-sdks/tree/main/python/examples/openai): best practice for model provider | ||
- [Google Search](https://github.com/langgenius/dify-plugin-sdks/tree/main/python/examples/google): a simple example for tool provider | ||
- [Neko](https://github.com/langgenius/dify-plugin-sdks/tree/main/python/examples/neko): a funny example for endpoint group | ||
|
||
### Test and Debug the Plugin | ||
|
||
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 to `remote`, 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 instance `https://debug.dify.ai`, or self-hosted Dify instance. | ||
- `REMOTE_INSTALL_PORT`: The port of your Dify instance, default is 5003 | ||
- `REMOTE_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 a `debug` icon, click it and you will get the key. | ||
|
||
Run the following command to start your Plugin: | ||
|
||
```bash | ||
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. | ||
|
||
### Package the Plugin | ||
|
||
After all, just package your Plugin by running the following command: | ||
|
||
```bash | ||
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! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters