猛男视频迁移成插件。删除原有逻辑

This commit is contained in:
liuwei
2025-03-19 16:24:42 +08:00
parent ca51ee50ce
commit 15fc732acb
13 changed files with 2 additions and 181 deletions

View File

@@ -5,7 +5,7 @@ api-key = "app-u5EnYq3ill19bm6pWJwGkY4D" # Dify的API Key
base-url = "http://192.168.2.240/v1" #Dify API接口base url
commands = ["ai", "dify", "聊天", "AI"]
command-tip = """-----Bot-----
command-tip = """
💬AI聊天指令
聊天 请求内容
"""

View File

@@ -1,83 +0,0 @@
import logging
import tomllib
import os
import requests
from wcferry import WxMsg, Wcf
from robot_cmd.robot_command import Feature, PermissionStatus, GroupBotManager
class BotVideo:
def __init__(self, wcf: Wcf, gbm: GroupBotManager):
self.LOG = logging.getLogger(__name__)
self.wcf = wcf # 假设 wcf 对象在此类中初始化
self.gbm = gbm # 权限功能
with open("group_video/config.toml", "rb") as f:
plugin_config = tomllib.load(f)
config = plugin_config["Video"]
self.enable = config["enable"]
self.command = config["command"]
self.LOG.info(f"[点视频] 组件初始化完成,指令: {self.command}")
def download_stream(self, url, save_path):
"""
从指定URL读取视频流并保存到本地
:param url: 视频流的URL
:param save_path: 本地保存路径(包含文件名,例如 "video.mp4"
"""
try:
# 发送GET请求启用流式传输
response = requests.get(url, stream=True)
# 检查请求是否成功
response.raise_for_status() # 如果状态码不是200将抛出异常
# 确保保存路径的目录存在
os.makedirs(os.path.dirname(save_path) or ".", exist_ok=True)
# 检查是否是视频流可选根据Content-Type判断
content_type = response.headers.get("Content-Type", "").lower()
if "video" not in content_type and "application/octet-stream" not in content_type:
print(f"警告: 返回的可能不是视频流Content-Type: {content_type}")
print("响应内容预览:", response.text[:100]) # 打印前100字符查看
return
# 以二进制写入模式保存流数据
with open(save_path, "wb") as file:
for chunk in response.iter_content(chunk_size=1024): # 分块读取每块1KB
if chunk: # 过滤空块
file.write(chunk)
print(f"视频已下载到: {save_path}")
return os.path.abspath(save_path)
except requests.RequestException as e:
print(f"请求失败: {e}")
except IOError as e:
print(f"文件写入失败: {e}")
except Exception as e:
print(f"发生未知错误: {e}")
def get_video(self, message: WxMsg):
if not self.enable:
return
content = str(message.content).strip()
command = content.split(" ")
if command[0] not in self.command:
return
# 如果触发了指令,但是没有权限,则返回权限不足
if self.gbm.get_group_permission(message.roomid, Feature.VIDEO) == PermissionStatus.DISABLED:
return
try:
file_abspath = self.download_stream("https://api.guiguiya.com/api/hook/heisis", "down_load_dir/video.mp4")
except requests.RequestException as e:
self.wcf.send_text(f"❌请求出错:{e}",
(message.roomid if message.from_group() else message.sender), message.sender)
return
if file_abspath.endswith("mp4"):
self.wcf.send_file(file_abspath, (message.roomid if message.from_group() else message.sender))
return

View File

@@ -1,3 +0,0 @@
[Video]
enable = true
command = ["黑丝视频", "黑丝", "来个黑丝","搞个黑丝"]

View File

@@ -1,76 +0,0 @@
import logging
import tomllib
import os
import requests
from wcferry import WxMsg, Wcf
from robot_cmd.robot_command import Feature, PermissionStatus, GroupBotManager
class BotVideoMan:
def __init__(self, wcf: Wcf, gbm: GroupBotManager):
self.LOG = logging.getLogger(__name__)
self.wcf = wcf # 假设 wcf 对象在此类中初始化
self.gbm = gbm # 权限功能
with open("group_video_man/config.toml", "rb") as f:
plugin_config = tomllib.load(f)
config = plugin_config["VideoMan"]
self.enable = config["enable"]
self.command = config["command"]
self.LOG.info(f"[猛男视频] 组件初始化完成,指令: {self.command}")
def get_video(self, message: WxMsg):
if not self.enable:
return
content = str(message.content).strip()
command = content.split(" ")
if command[0] not in self.command:
return
# 如果触发了指令,但是没有权限,则返回权限不足
if self.gbm.get_group_permission(message.roomid, Feature.VIDEO_MAN) == PermissionStatus.DISABLED:
return
try:
file_abspath = self.download_video("https://api.guiguiya.com/api/video/fuji?type=json",
"group_video_man/down_load_dir")
self.wcf.send_file(file_abspath, (message.roomid if message.from_group() else message.sender))
return
except requests.RequestException as e:
self.wcf.send_text(f"❌请求出错:{e}",
(message.roomid if message.from_group() else message.sender), message.sender)
return
def download_video(self, api_url, save_dir):
# 确保 save_dir 是一个目录
if os.path.isfile(save_dir):
print(f"错误: {save_dir} 是一个文件,不能作为目录使用。")
return None
os.makedirs(save_dir, exist_ok=True)
save_path = os.path.join(save_dir, "video.mp4")
response = requests.get(api_url)
if response.status_code == 200:
data = response.json()
video_url = data.get("url")
if video_url:
video_response = requests.get(video_url, stream=True)
if video_response.status_code == 200:
with open(save_path, "wb") as file:
for chunk in video_response.iter_content(chunk_size=1024):
file.write(chunk)
abs_path = os.path.abspath(save_path)
print(f"视频已下载至: {abs_path}")
return abs_path
else:
print("无法下载视频HTTP 状态码:", video_response.status_code)
else:
print("API 响应中没有找到视频 URL")
else:
print("API 请求失败HTTP 状态码:", response.status_code)
return None

View File

@@ -1,3 +0,0 @@
[VideoMan]
enable = true
command = ["猛男", "肌肉", "帅哥"]

View File

@@ -2,7 +2,6 @@
enable = true
command = ["美腿", "腿来"]
command-format = """
-----Bot-----
🦵美腿图片指令:
美腿
腿来

View File

@@ -1,7 +1,6 @@
enable = true
command = ["点歌", "音乐", "音乐点播", "点播音乐", "音乐点歌"]
command-format = """
-----Bot-----
🎵点歌指令:
点歌 歌曲名
"""

View File

@@ -2,7 +2,6 @@
enable = true
command = ["插件", "plugin", "插件管理"]
command-format = """
-----Bot-----
🔧插件管理指令:
插件 列表 - 查看所有插件
插件 启用 [插件名] - 启用插件

View File

@@ -314,7 +314,7 @@ class PluginManagerPlugin(MessagePluginInterface):
# 构建插件详情消息
status_text = "✅ 已启用" if plugin.status == PluginStatus.RUNNING else "❌ 已禁用"
message = f"""-----Bot-----
message = f"""
📦 插件详情:{plugin.name}
📝 描述:{plugin.description}
🔢 版本:{plugin.version}

View File

@@ -2,7 +2,6 @@
enable = true
command = ["黑丝视频", "黑丝", "来个黑丝", "搞个黑丝"]
command-format = """
-----Bot-----
🎬视频指令:
黑丝
"""

View File

@@ -2,7 +2,6 @@
enable = true
command = ["图来", "秀人", "美图", "随机图片"]
command-format = """
-----Bot-----
🖼️秀人图片指令:
图来
秀人

View File

@@ -2,7 +2,6 @@
enable = true
command = ["积分交易", "积分转账", "转账积分", "积分赠送", "赠送积分", "积分转移", "转移积分", "送积分", "积分送人", "送人积分", "积分赠予", "赠予"]
command-format = """
-----Bot-----
🔄转账积分:
积分转账 积分数 @用户
"""

View File

@@ -28,7 +28,6 @@ from game_task.game_task_encyclopedia import game_process_message, get_group_ids
from group_add.main import GroupAdd
from group_auto.group_auto_invite import get_first_group_id, process_command
from group_auto.group_member_change import GroupMemberChange
from group_video_man.bot_video_man import BotVideoMan
from message_sign.main import SignInSystem
from message_storage.message_to_db import MessageStorage
from plugin_common.event_system import EventType, EventSystem
@@ -122,8 +121,6 @@ class Robot(Job):
self.signin = SignInSystem(wcf, self.gbm, self.allContacts, self.db_pool, self.redis_pool, self.message_util)
# 积分赠送功能加载
self.trade = PointTrade(wcf, self.gbm, self.db_pool)
# 肌肉男视频
self.videoman = BotVideoMan(wcf, self.gbm)
# 加群测试
self.group_add = GroupAdd(wcf, self.gbm)
# 抖音转视频
@@ -328,11 +325,6 @@ class Robot(Job):
self.trade.handle_text(message=msg)
except Exception as e:
self.LOG.error(f"point trade error: {e}")
# 加入肌肉男视频功能
try:
self.videoman.get_video(message=msg)
except Exception as e:
self.LOG.error(f"videoman get_video error: {e}")
# 抖音组件
try:
self.douyin.handle_douyin_links(message=msg)