def handle_message(self, data): cmd = data["category"] raffle_name = data["name"] raffle_id = data["id"] room_id = data["roomid"] expireAt = data["expireAt"] # 大航海 if cmd == "guard": if config["Raffle_Handler"]["GUARD"] != "False": Log.raffle("监控服务器检测到 %s 的 %s" % (room_id, raffle_name)) RaffleHandler.push2queue((room_id,), GuardRaffleHandler.check) # 如果不是总督就设置为2(本房间) broadcast_type = 0 if raffle_name == "总督" else 2 Statistics.add2pushed_raffles(raffle_name, broadcast_type) # PK(WIP) elif cmd == "pk": if config["Raffle_Handler"]["PK"] != "False": Log.raffle("监控服务器检测到 %s 的 %s" % (room_id, raffle_name)) RaffleHandler.push2queue((room_id,), PkRaffleHandler.check) Statistics.add2pushed_raffles(raffle_name, 1) # 节奏风暴 elif cmd == "storm": if config["Raffle_Handler"]["STORM"] != "False": Log.raffle("监控服务器检测到 %s 的 %s" % (room_id, raffle_name)) RaffleHandler.push2queue((room_id,), StormRaffleHandler.check) Statistics.add2pushed_raffles(raffle_name, 1) # 天选 elif cmd == "anchor": if config["Raffle_Handler"]["ANCHOR"] != "False": Log.raffle("监控服务器检测到 %s 的 天选时刻, 奖品为: %s" % (room_id, raffle_name)) RaffleHandler.push2queue((room_id, raffle_name, raffle_id, expireAt), AnchorRaffleHandler.join) Statistics.add2pushed_raffles("天选时刻", 1)
def handle_danmu(self, body): data = json.loads(body.decode("utf-8")) cmd = data["cmd"] if cmd == "PREPARING": Log.info("%s 号弹幕监控下播 %s" % (self._area_id, self._room_id)) return False elif cmd == "NOTICE_MSG": # 1 《第五人格》哔哩哔哩直播预选赛六强诞生! # 2 全区广播:<%user_name%>送给<%user_name%>1个嗨翻全城,快来抽奖吧 # 3 <%user_name%> 在 <%user_name%> 的房间开通了总督并触发了抽奖,点击前往TA的房间去抽奖吧 # 4 欢迎 <%总督 user_name%> 登船 # 5 恭喜 <%user_name%> 获得大奖 <%23333x银瓜子%>, 感谢 <%user_name%> 的赠送 # 6 <%user_name%> 在直播间 <%529%> 使用了 <%20%> 倍节奏风暴,大家快去跟风领取奖励吧!(只报20的) msg_type = data["msg_type"] msg_common = data["msg_common"] real_roomid = data["real_roomid"] msg_common = data["msg_common"].replace(" ", "") msg_common = msg_common.replace("“", "") msg_common = msg_common.replace("”", "") for each in ["~", "点击前往TA的直播间抽奖吧!", "快来抽奖吧!", "继续进击小电视地图哦!", "完成今日", "啦"]: msg_common = msg_common.replace(each, "") # 小电视,DokiDoki,摩天大楼之类的抽奖活动 if msg_type == 2 or msg_type == 8: str_gift = msg_common.split('%>')[-1].split(',')[0] if "个" in str_gift: raffle_num, raffle_name = str_gift.split("个") elif "了" in str_gift: raffle_num = 1 raffle_name = str_gift.split("了")[-1] else: raffle_num = 1 raffle_name = str_gift broadcast = '' # This method is abandoned if config["Raffle_Handler"]["TV"] != "False": Log.raffle("%s 号弹幕监控检测到 %s 的 %s 个 %s" % (self._area_id, real_roomid, raffle_num, raffle_name)) RaffleHandler.push2queue((real_roomid, raffle_name,), TvRaffleHandler.check) # 如果不是全区就设置为1(分区) broadcast_type = 0 if broadcast == '全区' else 1 Statistics.add2pushed_raffles('小电视类', broadcast_type, raffle_num) # 大航海 elif msg_type == 3: raffle_name = msg_common.split("开通了")[-1][:2] if config["Raffle_Handler"]["GUARD"] != "False": Log.raffle("%s 号弹幕监控检测到 %s 的 %s" % (self._area_id, real_roomid, raffle_name)) RaffleHandler.push2queue((real_roomid,), GuardRaffleHandler.check) # 如果不是总督就设置为2(本房间) broadcast_type = 0 if raffle_name == "总督" else 2 Statistics.add2pushed_raffles(raffle_name, broadcast_type) # 节奏风暴 elif msg_type == 6: raffle_name = "二十倍节奏风暴" if config["Raffle_Handler"]["STORM"] != "False": Log.raffle("%s 号弹幕监控检测到 %s 的 %s" % (self._area_id, real_roomid, raffle_name)) RaffleHandler.push2queue((real_roomid,), StormRaffleHandler.check) Statistics.add2pushed_raffles(raffle_name) return True
def handle_danmu(self, body): data = json.loads(body.decode("utf-8")) cmd = data["cmd"] if cmd == "PREPARING": Log.info("%s 号弹幕监控下播 %s" % (self._area_id, self._room_id)) return False elif cmd == "NOTICE_MSG": # 1 《第五人格》哔哩哔哩直播预选赛六强诞生! # 2 全区广播:<%user_name%>送给<%user_name%>1个嗨翻全城,快来抽奖吧 # 3 <%user_name%> 在 <%user_name%> 的房间开通了总督并触发了抽奖,点击前往TA的房间去抽奖吧 # 4 欢迎 <%总督 user_name%> 登船 # 5 恭喜 <%user_name%> 获得大奖 <%23333x银瓜子%>, 感谢 <%user_name%> 的赠送 # 6 <%user_name%> 在直播间 <%529%> 使用了 <%20%> 倍节奏风暴,大家快去跟风领取奖励吧!(只报20的) msg_type = data["msg_type"] msg_common = data["msg_common"] real_roomid = data["real_roomid"] msg_common = data["msg_common"].replace(" ", "") msg_common = msg_common.replace("“", "") msg_common = msg_common.replace("”", "") # 小电视,DokiDoki,摩天大楼之类的抽奖活动 if msg_type == 2 or msg_type == 8: str_gift = msg_common.split('%>')[-1].split(',')[0] if "个" in str_gift: raffle_num, raffle_name = str_gift.split("个") elif "了" in str_gift: raffle_num = 1 raffle_name = str_gift.split("了")[-1] else: raffle_num = 1 raffle_name = str_gift broadcast = msg_common.split("广播")[0] Log.critical( "%s 号弹幕监控检测到 %s 的 %s 个 %s" % (self._area_id, real_roomid, raffle_num, raffle_name)) if config["Raffle_Handler"]["TV"] != "False": Raffle_Handler.RaffleHandler.push2queue(( real_roomid, raffle_name, ), TvRaffleHandler.check) # 如果不是全区就设置为1(分区) broadcast_type = 0 if broadcast == '全区' else 1 Statistics.add2pushed_raffles(raffle_name, broadcast_type, raffle_num) # 大航海 elif msg_type == 3: raffle_name = msg_common.split("开通了")[-1][:2] Log.critical("%s 号弹幕监控检测到 %s 的 %s" % (self._area_id, real_roomid, raffle_name)) if config["Raffle_Handler"]["GUARD"] != "False": Raffle_Handler.RaffleHandler.push2queue( (real_roomid, ), GuardRaffleHandler.check) # 如果不是总督就设置为2(本房间) broadcast_type = 0 if raffle_name == "总督" else 2 Statistics.add2pushed_raffles(raffle_name, broadcast_type) # 节奏风暴 elif msg_type == 6: raffle_name = "二十倍节奏风暴" Log.critical("%s 号弹幕监控检测到 %s 的 %s" % (self._area_id, real_roomid, raffle_name)) if config["Raffle_Handler"]["STORM"] != "False": Raffle_Handler.RaffleHandler.push2queue( (real_roomid, ), StormRaffleHandler.check) Statistics.add2pushed_raffles(raffle_name) # 论缩进的重要性,缩进太多永远都是: # 网络波动, X 号弹幕姬延迟3s后重启 # X 号弹幕姬异常或主动断开,正在处理剩余信息 # X 号弹幕姬退出,剩余任务处理完毕 # Debug 这个问题Debug了两天 return True