diff options
author | Vitor Mattos <vitor@php.rio> | 2022-04-20 17:02:40 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-04-20 17:02:40 +0300 |
commit | 9c0d9e29df08d2be50f5a89dcf01903136c18ca2 (patch) | |
tree | 6526f139267eea6a83bdc3d96674efe294a332e7 /lib | |
parent | 0e9ef95f419413649cc025ccb2db25ecd4b51342 (diff) | |
parent | 60d3fa7f1edc5263d3333a8430f94122c929b0b4 (diff) |
Merge pull request #7166 from nextcloud/feature/move-parser-listeners-annonymous-functions-to-static
Move parser listerner anonymous functions to static
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Chat/Parser/Listener.php | 203 |
1 files changed, 109 insertions, 94 deletions
diff --git a/lib/Chat/Parser/Listener.php b/lib/Chat/Parser/Listener.php index 99363b8ec..af2f50a6e 100644 --- a/lib/Chat/Parser/Listener.php +++ b/lib/Chat/Parser/Listener.php @@ -4,6 +4,9 @@ declare(strict_types=1); /** * @copyright Copyright (c) 2018 Joas Schilling <coding@schilljs.com> * + * @author Joas Schilling <coding@schilljs.com> + * @author Vitor Mattos <vitor@php.rio> + * * @license GNU AGPL version 3 or any later version * * This program is free software: you can redistribute it and/or modify @@ -31,103 +34,115 @@ use OCP\EventDispatcher\IEventDispatcher; class Listener { public static function register(IEventDispatcher $dispatcher): void { - $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, static function (ChatMessageEvent $event) { - $message = $event->getMessage(); + $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, [self::class, 'parseMention'], -100); + + $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, [self::class, 'parseChangelog'], -75); + + $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, [self::class, 'parseSystemMessage']); + + $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, [self::class, 'parseCommand']); + + $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, [self::class, 'parseReaction']); + + $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, [self::class, 'parseDeletedMessage'], 9999); + } + + public static function parseMention(ChatMessageEvent $event): void { + $message = $event->getMessage(); + + if ($message->getMessageType() !== ChatManager::VERB_MESSAGE) { + return; + } + + /** @var UserMention $parser */ + $parser = \OC::$server->get(UserMention::class); + $parser->parseMessage($message); + } + + public static function parseChangelog(ChatMessageEvent $event): void { + $message = $event->getMessage(); + + if ($message->getMessageType() !== ChatManager::VERB_MESSAGE) { + return; + } + + /** @var Changelog $parser */ + $parser = \OC::$server->get(Changelog::class); + try { + $parser->parseMessage($message); + $event->stopPropagation(); + } catch (\OutOfBoundsException $e) { + // Unknown message, ignore + } + } - if ($message->getMessageType() !== ChatManager::VERB_MESSAGE) { - return; - } + public static function parseSystemMessage(ChatMessageEvent $event): void { + $message = $event->getMessage(); - /** @var UserMention $parser */ - $parser = \OC::$server->get(UserMention::class); + if ($message->getMessageType() !== ChatManager::VERB_SYSTEM) { + return; + } + + /** @var SystemMessage $parser */ + $parser = \OC::$server->get(SystemMessage::class); + + try { $parser->parseMessage($message); - }, -100); - - $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, static function (ChatMessageEvent $event) { - $message = $event->getMessage(); - - if ($message->getMessageType() !== ChatManager::VERB_MESSAGE) { - return; - } - - /** @var Changelog $parser */ - $parser = \OC::$server->get(Changelog::class); - try { - $parser->parseMessage($message); - $event->stopPropagation(); - } catch (\OutOfBoundsException $e) { - // Unknown message, ignore - } - }, -75); - - $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, static function (ChatMessageEvent $event) { - $message = $event->getMessage(); - - if ($message->getMessageType() !== ChatManager::VERB_SYSTEM) { - return; - } - - /** @var SystemMessage $parser */ - $parser = \OC::$server->get(SystemMessage::class); - - try { - $parser->parseMessage($message); - $event->stopPropagation(); - } catch (\OutOfBoundsException $e) { - // Unknown message, ignore - } - }); - - $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, static function (ChatMessageEvent $event) { - $chatMessage = $event->getMessage(); - - if ($chatMessage->getMessageType() !== ChatManager::VERB_COMMAND) { - return; - } - - /** @var CommandParser $parser */ - $parser = \OC::$server->get(CommandParser::class); - - try { - $parser->parseMessage($chatMessage); - $event->stopPropagation(); - } catch (\OutOfBoundsException $e) { - // Unknown message, ignore - } catch (\RuntimeException $e) { - $event->stopPropagation(); - } - }); - - $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, static function (ChatMessageEvent $event) { - $chatMessage = $event->getMessage(); - - if ($chatMessage->getMessageType() !== ChatManager::VERB_REACTION && $chatMessage->getMessageType() !== ChatManager::VERB_REACTION_DELETED) { - return; - } - - /** @var ReactionParser $parser */ - $parser = \OC::$server->get(ReactionParser::class); + $event->stopPropagation(); + } catch (\OutOfBoundsException $e) { + // Unknown message, ignore + } + } + + public static function parseCommand(ChatMessageEvent $event): void { + $chatMessage = $event->getMessage(); + + if ($chatMessage->getMessageType() !== ChatManager::VERB_COMMAND) { + return; + } + + /** @var CommandParser $parser */ + $parser = \OC::$server->get(CommandParser::class); + + try { $parser->parseMessage($chatMessage); - }); - - $dispatcher->addListener(MessageParser::EVENT_MESSAGE_PARSE, static function (ChatMessageEvent $event) { - $chatMessage = $event->getMessage(); - - if ($chatMessage->getMessageType() !== ChatManager::VERB_MESSAGE_DELETED) { - return; - } - - /** @var SystemMessage $parser */ - $parser = \OC::$server->get(SystemMessage::class); - - try { - $parser->parseDeletedMessage($chatMessage); - $event->stopPropagation(); - } catch (\OutOfBoundsException $e) { - // Unknown message, ignore - } catch (\RuntimeException $e) { - $event->stopPropagation(); - } - }, 9999);// First things first + $event->stopPropagation(); + } catch (\OutOfBoundsException $e) { + // Unknown message, ignore + } catch (\RuntimeException $e) { + $event->stopPropagation(); + } + } + + public static function parseReaction(ChatMessageEvent $event): void { + $chatMessage = $event->getMessage(); + + if ($chatMessage->getMessageType() !== ChatManager::VERB_REACTION && $chatMessage->getMessageType() !== ChatManager::VERB_REACTION_DELETED) { + return; + } + + /** @var ReactionParser $parser */ + $parser = \OC::$server->get(ReactionParser::class); + $parser->parseMessage($chatMessage); + } + + public static function parseDeletedMessage(ChatMessageEvent $event): void { + $chatMessage = $event->getMessage(); + + if ($chatMessage->getMessageType() !== ChatManager::VERB_MESSAGE_DELETED) { + return; + } + + /** @var SystemMessage $parser */ + $parser = \OC::$server->get(SystemMessage::class); + + try { + $parser->parseDeletedMessage($chatMessage); + $event->stopPropagation(); + } catch (\OutOfBoundsException $e) { + // Unknown message, ignore + } catch (\RuntimeException $e) { + $event->stopPropagation(); + } } } |