Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Dify.AI
Dify
提交
5d9070bc
Dify
项目概览
Dify.AI
/
Dify
8 个月 前同步成功
通知
12
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Dify
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
5d9070bc
编写于
9月 13, 2023
作者:
J
Jyong
提交者:
GitHub
9月 13, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Feat/add blocking mode resource return (#1171)
Co-authored-by:
N
jyong
<
jyong@dify.ai
>
上级
b11fb0df
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
27 addition
and
3 deletion
+27
-3
api/models/model.py
api/models/model.py
+1
-1
api/services/completion_service.py
api/services/completion_service.py
+26
-2
未找到文件。
api/models/model.py
浏览文件 @
5d9070bc
...
...
@@ -147,7 +147,7 @@ class AppModelConfig(db.Model):
"suggested_questions"
:
self
.
suggested_questions_list
,
"suggested_questions_after_answer"
:
self
.
suggested_questions_after_answer_dict
,
"speech_to_text"
:
self
.
speech_to_text_dict
,
"retriever_resource"
:
self
.
retriever_resource
,
"retriever_resource"
:
self
.
retriever_resource
_dict
,
"more_like_this"
:
self
.
more_like_this_dict
,
"sensitive_word_avoidance"
:
self
.
sensitive_word_avoidance_dict
,
"model"
:
self
.
model_dict
,
...
...
api/services/completion_service.py
浏览文件 @
5d9070bc
...
...
@@ -366,6 +366,7 @@ class CompletionService:
generate_channel
=
list
(
pubsub
.
channels
.
keys
())[
0
].
decode
(
'utf-8'
)
if
not
streaming
:
try
:
message_result
=
{}
for
message
in
pubsub
.
listen
():
if
message
[
"type"
]
==
"message"
:
result
=
message
[
"data"
].
decode
(
'utf-8'
)
...
...
@@ -373,7 +374,10 @@ class CompletionService:
if
result
.
get
(
'error'
):
cls
.
handle_error
(
result
)
if
result
[
'event'
]
==
'message'
and
'data'
in
result
:
return
cls
.
get_message_response_data
(
result
.
get
(
'data'
))
message_result
[
'message'
]
=
result
.
get
(
'data'
)
if
result
[
'event'
]
==
'message_end'
and
'data'
in
result
:
message_result
[
'message_end'
]
=
result
.
get
(
'data'
)
return
cls
.
get_blocking_message_response_data
(
message_result
)
except
ValueError
as
e
:
if
e
.
args
[
0
]
!=
"I/O operation on closed file."
:
# ignore this error
raise
CompletionStoppedError
()
...
...
@@ -399,7 +403,6 @@ class CompletionService:
if
event
==
"end"
:
logging
.
debug
(
"{} finished"
.
format
(
generate_channel
))
break
if
event
==
'message'
:
yield
"data: "
+
json
.
dumps
(
cls
.
get_message_response_data
(
result
.
get
(
'data'
)))
+
"
\n\n
"
elif
event
==
'chain'
:
...
...
@@ -441,6 +444,27 @@ class CompletionService:
return
response_data
@
classmethod
def
get_blocking_message_response_data
(
cls
,
data
:
dict
):
message
=
data
.
get
(
'message'
)
response_data
=
{
'event'
:
'message'
,
'task_id'
:
message
.
get
(
'task_id'
),
'id'
:
message
.
get
(
'message_id'
),
'answer'
:
message
.
get
(
'text'
),
'metadata'
:
{},
'created_at'
:
int
(
time
.
time
())
}
if
message
.
get
(
'mode'
)
==
'chat'
:
response_data
[
'conversation_id'
]
=
message
.
get
(
'conversation_id'
)
if
'message_end'
in
data
:
message_end
=
data
.
get
(
'message_end'
)
if
'retriever_resources'
in
message_end
:
response_data
[
'metadata'
][
'retriever_resources'
]
=
message_end
.
get
(
'retriever_resources'
)
return
response_data
@
classmethod
def
get_message_end_data
(
cls
,
data
:
dict
):
response_data
=
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录