From d1bab5d5851696dea6981d7a6f26a09c67b05a5d Mon Sep 17 00:00:00 2001 From: liuwei Date: Wed, 9 Apr 2025 17:44:47 +0800 Subject: [PATCH] =?UTF-8?q?=E7=A7=AF=E5=88=86=E6=89=93=E5=8A=AB=E5=8A=9F?= =?UTF-8?q?=E8=83=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugins/point_trade/main.py | 141 ++++++++++++++++++------------------ 1 file changed, 71 insertions(+), 70 deletions(-) diff --git a/plugins/point_trade/main.py b/plugins/point_trade/main.py index 506828f..f67ea42 100644 --- a/plugins/point_trade/main.py +++ b/plugins/point_trade/main.py @@ -58,7 +58,7 @@ class PointTradePlugin(MessagePluginInterface): self.message_util = context.get("message_util") self.gbm = context.get("gbm") self.db_manager = DBConnectionManager.get_instance() - + # 初始化积分数据库操作类 self.points_db = PointsDBOperator(self.db_manager) @@ -70,7 +70,8 @@ class PointTradePlugin(MessagePluginInterface): # 从配置中获取参数 point_trade_config = self._config.get("PointTrade", {}) - self._commands = point_trade_config.get("command", ["积分交易", "积分转账", "转账积分", "我的积分", "积分排行", "打劫"]) + self._commands = point_trade_config.get("command", + ["积分交易", "积分转账", "转账积分", "我的积分", "积分排行", "打劫"]) self.command_format = point_trade_config.get("command-format", """ 积分交易指令: 积分转账 积分数 @用户 - 转账给指定用户 @@ -79,15 +80,15 @@ class PointTradePlugin(MessagePluginInterface): 打劫 @用户 - 尝试打劫用户积分(有风险) """) self.enable = point_trade_config.get("enable", True) - + # 打劫功能配置 self.rob_success_rate = point_trade_config.get("rob-success-rate", 0.3) # 打劫成功率 - self.rob_min_percent = point_trade_config.get("rob-min-percent", 0.1) # 打劫最小百分比 - self.rob_max_percent = point_trade_config.get("rob-max-percent", 0.3) # 打劫最大百分比 + self.rob_min_percent = point_trade_config.get("rob-min-percent", 0.1) # 打劫最小百分比 + self.rob_max_percent = point_trade_config.get("rob-max-percent", 0.3) # 打劫最大百分比 self.rob_penalty_percent = point_trade_config.get("rob-penalty-percent", 0.2) # 打劫失败惩罚百分比 self.rob_cooldown = point_trade_config.get("rob-cooldown", 1800) # 打劫冷却时间(秒) self.rob_min_points = point_trade_config.get("rob-min-points", 10) # 打劫最低积分要求 - + # 打劫冷却记录 {wxid: last_rob_time} self.rob_cooldown_records = {} @@ -182,10 +183,10 @@ class PointTradePlugin(MessagePluginInterface): try: # 使用积分系统进行转账 success, result = self.points_db.transfer_points( - trader_wxid, target_wxid, group_id, + trader_wxid, target_wxid, group_id, reward_points, f"积分转账命令执行" ) - + if not success: error_msg = result.get("error", "未知错误") if "积分不足" in error_msg: @@ -198,18 +199,18 @@ class PointTradePlugin(MessagePluginInterface): f"❌转账失败!\n{error_msg}", (roomid if roomid else sender), sender) return True, f"转账失败: {error_msg}" - + # 获取转账后的积分信息 from_user = result.get("from_user", {}) to_user = result.get("to_user", {}) - + # 获取用户昵称 from_user_info = self._get_user_record(trader_wxid, group_id) to_user_info = self._get_user_record(target_wxid, group_id) - + from_user_name = from_user_info.get('wx_nick_name', trader_wxid) if from_user_info else trader_wxid to_user_name = to_user_info.get('wx_nick_name', target_wxid) if to_user_info else target_wxid - + output = ( f"✅积分转账成功!\n" f"👤{from_user_name} 转给 👤{to_user_name} {reward_points} 积分\n" @@ -231,23 +232,23 @@ class PointTradePlugin(MessagePluginInterface): sender = message.get("sender") roomid = message.get("roomid", "") wcf: Wcf = message.get("wcf") - + try: # 获取用户积分信息 user_points = self.points_db.get_user_points(sender, roomid) - + if not user_points: wcf.send_text(f"❌未找到你的积分记录!请先参与积分活动[签到,答题/t]。", - (roomid if roomid else sender), sender) + (roomid if roomid else sender), sender) return True, "未找到积分记录" - + # 获取用户昵称 user_info = self._get_user_record(sender, roomid) user_name = user_info.get('wx_nick_name', sender) if user_info else sender - + # 获取用户积分交易记录 transactions = self.points_db.get_user_transactions(sender, roomid, 5) - + # 统计不同来源的积分 source_stats = {} for tx in transactions: @@ -256,10 +257,10 @@ class PointTradePlugin(MessagePluginInterface): if source not in source_stats: source_stats[source] = 0 source_stats[source] += points - + # 构建积分详情消息 source_details = "\n".join([f"- {source}: {points}" for source, points in source_stats.items()]) - + # 构建最近交易记录 recent_txs = "" if transactions: @@ -270,55 +271,55 @@ class PointTradePlugin(MessagePluginInterface): desc = tx.get('description', '无描述') date = tx.get('created_at', '').strftime('%m-%d %H:%M') if tx.get('created_at') else '未知时间' recent_txs += f"{i}. {date} {tx_type} {points} 积分 - {desc}\n" - + output = ( f"📊 {user_name} 的积分详情\n" f"总积分: {user_points.get('total_points', 0)}\n" f"\n积分来源统计:\n{source_details}" f"{recent_txs}" ) - + wcf.send_text(output, (roomid if roomid else sender), sender) return True, "查询积分成功" - + except Exception as e: self.LOG.error(f"查询积分出错: {e}") wcf.send_text(f"❌查询积分失败!请稍后重试。错误: {str(e)}", - (roomid if roomid else sender), sender) + (roomid if roomid else sender), sender) return True, f"处理出错: {str(e)}" - + def _handle_points_ranking(self, message: Dict[str, Any]) -> Tuple[bool, Optional[str]]: """处理积分排行榜命令""" sender = message.get("sender") roomid = message.get("roomid", "") wcf: Wcf = message.get("wcf") - + if not roomid: wcf.send_text("❌积分排行榜仅在群聊中可用!", sender, "") return True, "非群聊环境" - + try: # 获取群内积分排行 ranking = self.points_db.get_points_ranking(roomid, 10) - + if not ranking: wcf.send_text("❌暂无积分排行数据!请先参与积分活动。", roomid, sender) return True, "无排行数据" - + # 构建排行榜消息 rank_list = [] for i, user in enumerate(ranking, 1): user_id = user.get('user_id', '') points = user.get('total_points', 0) - + # 获取用户昵称 user_info = self._get_user_record(user_id, roomid) user_name = user_info.get('wx_nick_name', user_id) if user_info else user_id - + # 添加排名标记 rank_mark = "🥇" if i == 1 else "🥈" if i == 2 else "🥉" if i == 3 else f"{i}." rank_list.append(f"{rank_mark} {user_name}: {points} 积分") - + output = ( f"🏆 积分排行榜 🏆\n" f"\n" @@ -326,10 +327,10 @@ class PointTradePlugin(MessagePluginInterface): f"\n" f"更新时间: {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}" ) - + wcf.send_text(output, roomid, sender) return True, "查询排行榜成功" - + except Exception as e: self.LOG.error(f"查询积分排行榜出错: {e}") wcf.send_text(f"❌查询积分排行榜失败!请稍后重试。错误: {str(e)}", roomid, sender) @@ -421,18 +422,18 @@ class PointTradePlugin(MessagePluginInterface): """处理打劫积分命令""" import random import time - + content = str(message.get("content", "")).strip() sender = message.get("sender") roomid = message.get("roomid", "") wcf: Wcf = message.get("wcf") xml = message.get("xml", "") - + # 检查是否在群聊中 if not roomid: wcf.send_text("❌打劫功能仅在群聊中可用!", sender, "") return True, "非群聊环境" - + # 检查冷却时间 current_time = time.time() if sender in self.rob_cooldown_records: @@ -441,82 +442,82 @@ class PointTradePlugin(MessagePluginInterface): if time_passed < self.rob_cooldown: remaining_time = int(self.rob_cooldown - time_passed) minutes, seconds = divmod(remaining_time, 60) - wcf.send_text(f"❌你最近已经打劫过了,需要冷却 {minutes}分{seconds}秒 后才能再次打劫!", - roomid, sender) + wcf.send_text(f"❌你最近已经打劫过了,需要冷却 {minutes}分{seconds}秒 后才能再次打劫!", + roomid, sender) return True, "冷却中" - + # 检查@用户是否有效 at_users = self.at_list(xml) if len(at_users) != 1: wcf.send_text(f"打劫失败❌\n请指定一个打劫目标!\n打劫 @用户", - roomid, sender) + roomid, sender) return True, "目标无效" - + target_wxid = next(iter(at_users)) robber_wxid = sender - + # 不能打劫自己 if target_wxid == robber_wxid: wcf.send_text("❌你不能打劫自己!", roomid, sender) return True, "不能打劫自己" - + try: # 获取打劫者和目标的积分信息 robber_points = self.points_db.get_user_points(robber_wxid, roomid) target_points = self.points_db.get_user_points(target_wxid, roomid) - + if not robber_points: wcf.send_text("❌你没有积分记录,无法进行打劫!请先参与积分活动。", roomid, sender) return True, "打劫者无积分" - + if not target_points: wcf.send_text("❌目标没有积分记录,无法进行打劫!", roomid, sender) return True, "目标无积分" - + robber_total = robber_points.get('total_points', 0) target_total = target_points.get('total_points', 0) - + # 检查最低积分要求 if robber_total < self.rob_min_points: wcf.send_text(f"❌你的积分不足 {self.rob_min_points} 点,无法进行打劫!", roomid, sender) return True, "打劫者积分不足" - + if target_total < self.rob_min_points: wcf.send_text(f"❌目标积分不足 {self.rob_min_points} 点,不值得打劫!", roomid, sender) return True, "目标积分不足" - + # 获取用户昵称 robber_info = self._get_user_record(robber_wxid, roomid) target_info = self._get_user_record(target_wxid, roomid) - + robber_name = robber_info.get('wx_nick_name', robber_wxid) if robber_info else robber_wxid target_name = target_info.get('wx_nick_name', target_wxid) if target_info else target_wxid - + # 决定打劫是否成功 is_success = random.random() < self.rob_success_rate - + # 更新冷却时间 self.rob_cooldown_records[sender] = current_time - + if is_success: # 打劫成功,随机获取目标一定比例的积分 rob_percent = random.uniform(self.rob_min_percent, self.rob_max_percent) rob_amount = int(target_total * rob_percent) - + # 确保至少抢到1点积分 rob_amount = max(1, rob_amount) - + # 执行积分转移 success, result = self.points_db.transfer_points( - target_wxid, robber_wxid, roomid, + target_wxid, robber_wxid, roomid, rob_amount, f"被{robber_name}打劫" ) - + if success: # 获取转账后的积分信息 from_user = result.get("from_user", {}) to_user = result.get("to_user", {}) - + # 构建打劫成功消息 output = ( f"🔫 打劫成功!\n" @@ -524,7 +525,7 @@ class PointTradePlugin(MessagePluginInterface): f"👤{robber_name} 当前积分: {to_user.get('total_points', 0)}\n" f"👤{target_name} 当前积分: {from_user.get('total_points', 0)}" ) - + wcf.send_text(output, roomid, sender) return True, "打劫成功" else: @@ -533,32 +534,32 @@ class PointTradePlugin(MessagePluginInterface): else: # 打劫失败,扣除打劫者一定比例的积分作为惩罚 penalty_amount = int(robber_total * self.rob_penalty_percent) - + # 确保至少扣除1点积分 penalty_amount = max(1, penalty_amount) - + # 记录积分变动 - success, result = self.points_db.add_points( - robber_wxid, roomid, -penalty_amount, - PointSource.OTHER, f"打劫{target_name}失败的惩罚" + success, result = self.points_db.transfer_points( + robber_wxid, target_wxid, roomid, + penalty_amount, f"打劫{target_name}失败的惩罚" ) - + if success: # 构建打劫失败消息 output = ( f"🚨 打劫失败!\n" - f"👤{robber_name} 试图打劫 👤{target_name} 但被当场抓获!\n" + f"👤{robber_name} 试图打劫 👤{target_name} 但被当场抓获,并赔款!\n" f"👮‍♂️ 被罚款 {penalty_amount} 积分!\n" f"👤{robber_name} 当前积分: {result.get('total_points', 0)}" ) - + wcf.send_text(output, roomid, sender) return True, "打劫失败" else: wcf.send_text(f"❌处理打劫惩罚时出现问题:{result.get('error', '未知错误')}", roomid, sender) return True, "处理惩罚失败" - + except Exception as e: self.LOG.error(f"处理打劫请求出错: {e}") wcf.send_text(f"❌打劫过程中出现意外:{str(e)}", roomid, sender) - return True, f"处理出错: {str(e)}" \ No newline at end of file + return True, f"处理出错: {str(e)}"