async def handle_event(bot: Bot, event: Event): log_msg = f"{bot.type.upper()} Bot {event.self_id} [{event.name}]: " if event.type == "message": log_msg += f"Message {event.id} from " log_msg += str(event.user_id) if event.detail_type == "group": log_msg += f"@[群:{event.group_id}]: " log_msg += repr(str(event.message)) elif event.type == "notice": log_msg += f"Notice {event.raw_event}" elif event.type == "request": log_msg += f"Request {event.raw_event}" elif event.type == "meta_event": log_msg += f"MetaEvent {event.raw_event}" logger.info(log_msg) coros = [] state = {} for preprocessor in _event_preprocessors: coros.append(preprocessor(bot, event, state)) if coros: try: logger.debug("Running PreProcessors...") await asyncio.gather(*coros) except IgnoredException: logger.info(f"Event {event.name} is ignored") return # Trie Match _, _ = TrieRule.get_value(bot, event, state) break_flag = False for priority in sorted(matchers.keys()): if break_flag: break pending_tasks = [ _run_matcher(matcher, bot, event, state.copy()) for matcher in matchers[priority] ] logger.debug(f"Checking for all matchers in priority {priority}...") results = await asyncio.gather(*pending_tasks, return_exceptions=True) i = 0 for index, result in enumerate(results): if isinstance(result, _ExceptionContainer): e_list = result.exceptions if StopPropagation in e_list: break_flag = True logger.debug("Stop event propagation") if ExpiredException in e_list: del matchers[priority][index - i] i += 1
async def handle_getting_matchers(): matcher_dict = {} def _matcher_to_dict(matcher): return { "type": matcher.type, "module": matcher.module, "handlers": len(matcher.handlers), "priority": matcher.priority, "temp": matcher.temp or bool(matcher.expire_time), "block": matcher.block } for priority in matchers.keys(): matcher_dict[priority] = list(map(_matcher_to_dict, matchers[priority])) return {"status": 200, "data": matcher_dict}
async def handle_event(bot: Bot, event: Event): coros = [] state = {} for preprocessor in _event_preprocessors: coros.append(preprocessor(bot, event, state)) if coros: try: await asyncio.gather(*coros) except IgnoredException: logger.info(f"Event {event} is ignored") return # Trie Match if event.type == "message": _, _ = TrieRule.get_value(bot, event, state) break_flag = False for priority in sorted(matchers.keys()): if break_flag: break pending_tasks = [ _run_matcher(matcher, bot, event, state.copy()) for matcher in matchers[priority] ] results = await asyncio.gather(*pending_tasks, return_exceptions=True) i = 0 for index, result in enumerate(results): if isinstance(result, _ExceptionContainer): e_list = result.exceptions if StopPropagation in e_list: break_flag = True if ExpiredException in e_list: del matchers[priority][index - i] i += 1
async def handle_event(bot: "Bot", event: "Event"): """ :说明: 处理一个事件。调用该函数以实现分发事件。 :参数: * ``bot: Bot``: Bot 对象 * ``event: Event``: Event 对象 :示例: .. code-block:: python import asyncio asyncio.create_task(handle_event(bot, event)) """ show_log = True log_msg = f"<m>{bot.type.upper()} {bot.self_id}</m> | " try: log_msg += event.get_log_string() except NoLogException: show_log = False if show_log: logger.opt(colors=True).info(log_msg) state = {} coros = list(map(lambda x: x(bot, event, state), _event_preprocessors)) if coros: try: logger.debug("Running PreProcessors...") await asyncio.gather(*coros) except IgnoredException: logger.opt(colors=True).info( f"Event {event.get_event_name()} is <b>ignored</b>") return except Exception as e: logger.opt(colors=True, exception=e).error( "<r><bg #f8bbd0>Error when running EventPreProcessors. " "Event ignored!</bg #f8bbd0></r>") return # Trie Match _, _ = TrieRule.get_value(bot, event, state) break_flag = False for priority in sorted(matchers.keys()): if break_flag: break if show_log: logger.debug(f"Checking for matchers in priority {priority}...") pending_tasks = [ _check_matcher(priority, matcher, bot, event, state.copy()) for matcher in matchers[priority] ] results = await asyncio.gather(*pending_tasks, return_exceptions=True) for result in results: if isinstance(result, StopPropagation): if not break_flag: break_flag = True logger.debug("Stop event propagation") coros = list(map(lambda x: x(bot, event, state), _event_postprocessors)) if coros: try: logger.debug("Running PostProcessors...") await asyncio.gather(*coros) except Exception as e: logger.opt(colors=True, exception=e).error( "<r><bg #f8bbd0>Error when running EventPostProcessors</bg #f8bbd0></r>" )
async def handle_event(bot: Bot, event: Event): """ :说明: 处理一个事件。调用该函数以实现分发事件。 :参数: * ``bot: Bot``: Bot 对象 * ``event: Event``: Event 对象 :示例: .. code-block:: python import asyncio asyncio.create_task(handle_event(bot, event)) """ show_log = True log_msg = f"<m>{bot.type.upper()} </m>| {event.self_id} [{event.name}]: " if event.type == "message": log_msg += f"Message {event.id} from " log_msg += str(event.user_id) if event.detail_type == "group": log_msg += f"@[群:{event.group_id}]:" log_msg += ' "' + "".join( map( lambda x: escape_tag(str(x)) if x.type == "text" else f"<le>{escape_tag(str(x))}</le>", event.message)) + '"' # type: ignore elif event.type == "notice": log_msg += f"Notice {event.raw_event}" elif event.type == "request": log_msg += f"Request {event.raw_event}" elif event.type == "meta_event": # log_msg += f"MetaEvent {event.detail_type}" show_log = False if show_log: logger.opt(colors=True).info(log_msg) state = {} coros = list(map(lambda x: x(bot, event, state), _event_preprocessors)) if coros: try: logger.debug("Running PreProcessors...") await asyncio.gather(*coros) except IgnoredException: logger.opt( colors=True).info(f"Event {event.name} is <b>ignored</b>") return except Exception as e: logger.opt(colors=True, exception=e).error( "<r><bg #f8bbd0>Error when running EventPreProcessors. " "Event ignored!</bg #f8bbd0></r>") return # Trie Match _, _ = TrieRule.get_value(bot, event, state) break_flag = False for priority in sorted(matchers.keys()): if break_flag: break if show_log: logger.debug(f"Checking for matchers in priority {priority}...") run_matchers = await _check_matcher(priority, bot, event, state) pending_tasks = [ _run_matcher(matcher, bot, event, state.copy()) for matcher in run_matchers ] results = await asyncio.gather(*pending_tasks, return_exceptions=True) for result in results: if isinstance(result, StopPropagation): if not break_flag: break_flag = True logger.debug("Stop event propagation") coros = list(map(lambda x: x(bot, event, state), _event_postprocessors)) if coros: try: logger.debug("Running PostProcessors...") await asyncio.gather(*coros) except Exception as e: logger.opt(colors=True, exception=e).error( "<r><bg #f8bbd0>Error when running EventPostProcessors</bg #f8bbd0></r>" )
async def handle_event(bot: "Bot", event: "Event") -> None: """处理一个事件。调用该函数以实现分发事件。 参数: bot: Bot 对象 event: Event 对象 用法: ```python import asyncio asyncio.create_task(handle_event(bot, event)) ``` """ show_log = True log_msg = f"<m>{escape_tag(bot.type.upper())} {escape_tag(bot.self_id)}</m> | " try: log_msg += event.get_log_string() except NoLogException: show_log = False if show_log: logger.opt(colors=True).success(log_msg) state: Dict[Any, Any] = {} dependency_cache: T_DependencyCache = {} async with AsyncExitStack() as stack: coros = list( map( lambda x: _run_coro_with_catch( x( bot=bot, event=event, state=state, stack=stack, dependency_cache=dependency_cache, )), _event_preprocessors, )) if coros: try: if show_log: logger.debug("Running PreProcessors...") await asyncio.gather(*coros) except IgnoredException as e: logger.opt(colors=True).info( f"Event {escape_tag(event.get_event_name())} is <b>ignored</b>" ) return except Exception as e: logger.opt(colors=True, exception=e).error( "<r><bg #f8bbd0>Error when running EventPreProcessors. " "Event ignored!</bg #f8bbd0></r>") return # Trie Match try: TrieRule.get_value(bot, event, state) except Exception as e: logger.opt( colors=True, exception=e).warning("Error while parsing command for event") break_flag = False for priority in sorted(matchers.keys()): if break_flag: break if show_log: logger.debug( f"Checking for matchers in priority {priority}...") pending_tasks = [ _check_matcher(priority, matcher, bot, event, state.copy(), stack, dependency_cache) for matcher in matchers[priority] ] results = await asyncio.gather(*pending_tasks, return_exceptions=True) for result in results: if not isinstance(result, Exception): continue if isinstance(result, StopPropagation): break_flag = True logger.debug("Stop event propagation") else: logger.opt(colors=True, exception=result).error( "<r><bg #f8bbd0>Error when checking Matcher.</bg #f8bbd0></r>" ) coros = list( map( lambda x: _run_coro_with_catch( x( bot=bot, event=event, state=state, stack=stack, dependency_cache=dependency_cache, )), _event_postprocessors, )) if coros: try: if show_log: logger.debug("Running PostProcessors...") await asyncio.gather(*coros) except Exception as e: logger.opt(colors=True, exception=e).error( "<r><bg #f8bbd0>Error when running EventPostProcessors</bg #f8bbd0></r>" )
async def handle_event(bot: Bot, event: Event): show_log = True log_msg = f"<m>{bot.type.upper()} </m>| {event.self_id} [{event.name}]: " if event.type == "message": log_msg += f"Message {event.id} from " log_msg += str(event.user_id) if event.detail_type == "group": log_msg += f"@[群:{event.group_id}]:" log_msg += ' "' + "".join( map( lambda x: escape_tag(str(x)) if x.type == "text" else f"<le>{escape_tag(str(x))}</le>", event.message)) + '"' # type: ignore elif event.type == "notice": log_msg += f"Notice {event.raw_event}" elif event.type == "request": log_msg += f"Request {event.raw_event}" elif event.type == "meta_event": # log_msg += f"MetaEvent {event.detail_type}" show_log = False if show_log: logger.opt(colors=True).info(log_msg) coros = [] state = {} for preprocessor in _event_preprocessors: coros.append(preprocessor(bot, event, state)) if coros: try: logger.debug("Running PreProcessors...") await asyncio.gather(*coros) except IgnoredException: logger.opt( colors=True).info(f"Event {event.name} is <b>ignored</b>") return # Trie Match _, _ = TrieRule.get_value(bot, event, state) break_flag = False for priority in sorted(matchers.keys()): if break_flag: break pending_tasks = [ _run_matcher(matcher, bot, event, state.copy()) for matcher in matchers[priority] ] if show_log: logger.debug(f"Checking for matchers in priority {priority}...") results = await asyncio.gather(*pending_tasks, return_exceptions=True) i = 0 for index, result in enumerate(results): if isinstance(result, _ExceptionContainer): e_list = result.exceptions if StopPropagation in e_list: if not break_flag: break_flag = True logger.debug("Stop event propagation") if ExpiredException in e_list: logger.debug( f"Matcher {matchers[priority][index - i]} will be removed." ) del matchers[priority][index - i] i += 1