diff options
author | Vitor Mattos <vitor@php.rio> | 2022-04-18 23:54:58 +0300 |
---|---|---|
committer | Vitor Mattos <vitor@php.rio> | 2022-04-19 14:59:53 +0300 |
commit | 60d3fa7f1edc5263d3333a8430f94122c929b0b4 (patch) | |
tree | 5641dd1aba9b15f282f5da6490cc395740b26c9d /lib | |
parent | d94c3c1aef2e6910292ae1584bc75a47e74801b5 (diff) |
Move parser listerner annonymous functions to static
Signed-off-by: Vitor Mattos <vitor@php.rio>
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(); + } } } |