Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/spreed.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorVitor Mattos <vitor@php.rio>2022-04-18 23:54:58 +0300
committerVitor Mattos <vitor@php.rio>2022-04-19 14:59:53 +0300
commit60d3fa7f1edc5263d3333a8430f94122c929b0b4 (patch)
tree5641dd1aba9b15f282f5da6490cc395740b26c9d /lib
parentd94c3c1aef2e6910292ae1584bc75a47e74801b5 (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.php203
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();
+ }
}
}