X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=app%2FModels%2FChatLog.php;h=8564ff097b55abbe7eb12e4072568222bb60c944;hb=47d864b96b80abb11fdf8e2fdc8920e93916d5b9;hp=f918269073a0fa733e7ea9765a0a57d514b2bca2;hpb=50ec833111c8a11711a98e642321c8dad25b01ae;p=alttp.git diff --git a/app/Models/ChatLog.php b/app/Models/ChatLog.php index f918269..8564ff0 100644 --- a/app/Models/ChatLog.php +++ b/app/Models/ChatLog.php @@ -34,7 +34,7 @@ class ChatLog extends Model { } if ($this->command == 'PRIVMSG') { - if ($this->isKnownBot()) { + if (static::isKnownBot($this->nick)) { $this->type = 'bot'; } else if (substr($this->params[0], 0, 1) == '#') { $this->type = 'chat'; @@ -53,14 +53,15 @@ class ChatLog extends Model { throw new \Exception('unidentified message'); } - public function isKnownBot() { - return in_array(strtolower($this->nick), [ + public static function isKnownBot($nick) { + return in_array(strtolower($nick), [ 'birrellthesquirrel', 'funtoon', 'nidbot2000', 'nightbot', 'pokemoncommunitygame', 'speedgaming', + 'starbase47', 'streamelements', 'wizebot', 'zockerstuebchen', @@ -94,6 +95,9 @@ class ChatLog extends Model { if (Str::contains($rawText, ['hype'])) { return 'hype'; } + if (Str::startsWith($rawText, 'o7') || Str::endsWith($rawText, 'o7') || Str::contains($rawText, 'salut')) { + return 'o7'; + } return 'unclassified'; } @@ -130,38 +134,42 @@ class ChatLog extends Model { } } - protected function scanForSpam() { - if (substr($this->text_content, 0, 1) == '!') { + public static function spammyText($text) { + if (substr($text, 0, 1) == '!') { return true; } - if (strpos($this->text_content, '$') !== false) { + if (strpos($text, '$') !== false) { return true; } - if (strpos($this->text_content, '€') !== false) { + if (strpos($text, '€') !== false) { return true; } - if (strpos($this->text_content, '@') !== false) { + if (strpos($text, '@') !== false) { return true; } - if (strpos($this->text_content, '://') !== false) { + if (strpos($text, '://') !== false) { return true; } - if (is_numeric($this->text_content)) { + if (strpos($text, 'followers') !== false) { return true; } - if (strpos($this->text_content, 'followers') !== false) { + if (strpos($text, 'promotion') !== false) { return true; } - if (strpos($this->text_content, 'promotion') !== false) { + if (strpos($text, 'viewers') !== false) { return true; } - if (strpos($this->text_content, 'viewers') !== false) { + if (strpos($text, 'view ers') !== false) { return true; } - if (strpos($this->text_content, 'view ers') !== false) { + return false; + } + + protected function scanForSpam() { + if (is_numeric($text)) { return true; } - return false; + return static::spammyText($this->text_content); } protected $casts = [