123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 |
- package plugin_daemon
- import (
- "errors"
- "github.com/langgenius/dify-plugin-daemon/internal/core/plugin_manager"
- "github.com/langgenius/dify-plugin-daemon/internal/core/session_manager"
- "github.com/langgenius/dify-plugin-daemon/internal/types/entities/model_entities"
- "github.com/langgenius/dify-plugin-daemon/internal/types/entities/plugin_entities"
- "github.com/langgenius/dify-plugin-daemon/internal/types/entities/requests"
- "github.com/langgenius/dify-plugin-daemon/internal/utils/log"
- "github.com/langgenius/dify-plugin-daemon/internal/utils/parser"
- "github.com/langgenius/dify-plugin-daemon/internal/utils/stream"
- )
- func genericInvokePlugin[Req any, Rsp any](
- session *session_manager.Session,
- request *Req,
- response_buffer_size int,
- typ PluginAccessType,
- action PluginAccessAction,
- ) (
- *stream.StreamResponse[Rsp], error,
- ) {
- runtime := plugin_manager.Get(session.PluginIdentity())
- if runtime == nil {
- return nil, errors.New("plugin not found")
- }
- response := stream.NewStreamResponse[Rsp](response_buffer_size)
- listener := runtime.Listen(session.ID())
- listener.AddListener(func(message []byte) {
- chunk, err := parser.UnmarshalJsonBytes[plugin_entities.SessionMessage](message)
- if err != nil {
- log.Error("unmarshal json failed: %s", err.Error())
- return
- }
- switch chunk.Type {
- case plugin_entities.SESSION_MESSAGE_TYPE_STREAM:
- chunk, err := parser.UnmarshalJsonBytes[Rsp](chunk.Data)
- if err != nil {
- log.Error("unmarshal json failed: %s", err.Error())
- return
- }
- response.Write(chunk)
- case plugin_entities.SESSION_MESSAGE_TYPE_INVOKE:
- invokeDify(runtime, session, chunk.Data)
- case plugin_entities.SESSION_MESSAGE_TYPE_END:
- response.Close()
- case plugin_entities.SESSION_MESSAGE_TYPE_ERROR:
- e, err := parser.UnmarshalJsonBytes[plugin_entities.ErrorResponse](chunk.Data)
- if err != nil {
- break
- }
- response.WriteError(errors.New(e.Error))
- response.Close()
- default:
- response.WriteError(errors.New("unknown stream message type: " + string(chunk.Type)))
- response.Close()
- }
- })
- response.OnClose(func() {
- listener.Close()
- })
- runtime.Write(session.ID(), []byte(parser.MarshalJson(
- getInvokeModelMap(
- session,
- typ,
- action,
- request,
- ),
- )))
- return response, nil
- }
- func getInvokeModelMap(
- session *session_manager.Session,
- typ PluginAccessType,
- action PluginAccessAction,
- request any,
- ) map[string]any {
- req := getBasicPluginAccessMap(session.ID(), session.UserID(), typ, action)
- data := req["data"].(map[string]any)
- for k, v := range parser.StructToMap(request) {
- data[k] = v
- }
- return req
- }
- func InvokeLLM(
- session *session_manager.Session,
- request *requests.RequestInvokeLLM,
- ) (
- *stream.StreamResponse[model_entities.LLMResultChunk], error,
- ) {
- return genericInvokePlugin[requests.RequestInvokeLLM, model_entities.LLMResultChunk](
- session,
- request,
- 512,
- PLUGIN_ACCESS_TYPE_MODEL,
- PLUGIN_ACCESS_ACTION_INVOKE_LLM,
- )
- }
- func InvokeTextEmbedding(
- session *session_manager.Session,
- request *requests.RequestInvokeTextEmbedding,
- ) (
- *stream.StreamResponse[model_entities.TextEmbeddingResult], error,
- ) {
- return genericInvokePlugin[requests.RequestInvokeTextEmbedding, model_entities.TextEmbeddingResult](
- session,
- request,
- 1,
- PLUGIN_ACCESS_TYPE_MODEL,
- PLUGIN_ACCESS_ACTION_INVOKE_TEXT_EMBEDDING,
- )
- }
- func InvokeRerank(
- session *session_manager.Session,
- request *requests.RequestInvokeRerank,
- ) (
- *stream.StreamResponse[model_entities.RerankResult], error,
- ) {
- return genericInvokePlugin[requests.RequestInvokeRerank, model_entities.RerankResult](
- session,
- request,
- 1,
- PLUGIN_ACCESS_TYPE_MODEL,
- PLUGIN_ACCESS_ACTION_INVOKE_RERANK,
- )
- }
- func InvokeTTS(
- session *session_manager.Session,
- request *requests.RequestInvokeTTS,
- ) (
- *stream.StreamResponse[string], error,
- ) {
- return genericInvokePlugin[requests.RequestInvokeTTS, string](
- session,
- request,
- 1,
- PLUGIN_ACCESS_TYPE_MODEL,
- PLUGIN_ACCESS_ACTION_INVOKE_TTS,
- )
- }
- func InvokeSpeech2Text(
- session *session_manager.Session,
- request *requests.RequestInvokeSpeech2Text,
- ) (
- *stream.StreamResponse[string], error,
- ) {
- return genericInvokePlugin[requests.RequestInvokeSpeech2Text, string](
- session,
- request,
- 1,
- PLUGIN_ACCESS_TYPE_MODEL,
- PLUGIN_ACCESS_ACTION_INVOKE_SPEECH2TEXT,
- )
- }
- func InvokeModeration(
- session *session_manager.Session,
- request *requests.RequestInvokeModeration,
- ) (
- *stream.StreamResponse[bool], error,
- ) {
- return genericInvokePlugin[requests.RequestInvokeModeration, bool](
- session,
- request,
- 1,
- PLUGIN_ACCESS_TYPE_MODEL,
- PLUGIN_ACCESS_ACTION_INVOKE_MODERATION,
- )
- }
|