瀏覽代碼

Update keyword.py

master
befantasy GitHub 1 年之前
父節點
當前提交
d8bfa77705
沒有發現已知的金鑰在資料庫的簽署中 GPG 金鑰 ID: 4AEE18F83AFDEB23
共有 1 個檔案被更改,包括 21 行新增5 行删除
  1. +21
    -5
      plugins/keyword/keyword.py

+ 21
- 5
plugins/keyword/keyword.py 查看文件

@@ -2,7 +2,7 @@


import json import json
import os import os
import requests
import plugins import plugins
from bridge.context import ContextType from bridge.context import ContextType
from bridge.reply import Reply, ReplyType from bridge.reply import Reply, ReplyType
@@ -51,15 +51,31 @@ class Keyword(Plugin):
content = e_context["context"].content.strip() content = e_context["context"].content.strip()
logger.debug("[keyword] on_handle_context. content: %s" % content) logger.debug("[keyword] on_handle_context. content: %s" % content)
if content in self.keyword: if content in self.keyword:
logger.debug(f"[keyword] 匹配到关键字【{content}】")
logger.info(f"[keyword] 匹配到关键字【{content}】")
reply_text = self.keyword[content] reply_text = self.keyword[content]


# 判断匹配内容的类型 # 判断匹配内容的类型
if (reply_text.startswith("http://") or reply_text.startswith("https://")) and any(reply_text.endswith(ext) for ext in [".jpg", ".jpeg", ".png", ".gif", ".webp"]):
# 如果是以 http:// 或 https:// 开头,且.jpg/.jpeg/.png/.gif结尾,则认为是图片 URL
if (reply_text.startswith("http://") or reply_text.startswith("https://")) and any(reply_text.endswith(ext) for ext in [".jpg", ".jpeg", ".png", ".gif", ".img"]):
# 如果是以 http:// 或 https:// 开头,且".jpg", ".jpeg", ".png", ".gif", ".img"结尾,则认为是图片 URL。
reply = Reply() reply = Reply()
reply.type = ReplyType.IMAGE_URL reply.type = ReplyType.IMAGE_URL
reply.content = reply_text reply.content = reply_text
elif (reply_text.startswith("http://") or reply_text.startswith("https://")) and any(reply_text.endswith(ext) for ext in [".pdf", ".doc", ".docx", ".xls", "xlsx",".zip", ".rar"]):
# 如果是以 http:// 或 https:// 开头,且".pdf", ".doc", ".docx", ".xls", "xlsx",".zip", ".rar"结尾,则下载文件到tmp目录并发送给用户
file_path = "tmp"
if not os.path.exists(file_path):
os.makedirs(file_path)
file_name = reply_text.split("/")[-1] # 获取文件名
file_path = os.path.join(file_path, file_name)
response = requests.get(reply_text)
with open(file_path, "wb") as f:
f.write(response.content)
#channel/wechat/wechat_channel.py和channel/wechat_channel.py中缺少ReplyType.FILE类型。
reply = Reply()
reply.type = ReplyType.FILE
reply.content = file_path
else: else:
# 否则认为是普通文本 # 否则认为是普通文本
reply = Reply() reply = Reply()
@@ -68,7 +84,7 @@ class Keyword(Plugin):
e_context["reply"] = reply e_context["reply"] = reply
e_context.action = EventAction.BREAK_PASS # 事件结束,并跳过处理context的默认逻辑 e_context.action = EventAction.BREAK_PASS # 事件结束,并跳过处理context的默认逻辑
def get_help_text(self, **kwargs): def get_help_text(self, **kwargs):
help_text = "关键词过滤" help_text = "关键词过滤"
return help_text return help_text

Loading…
取消
儲存