From 4c8ec128c113750fb26481724f9e89314c76df45 Mon Sep 17 00:00:00 2001 From: Tan Nguyen Date: Wed, 11 Oct 2023 21:42:00 +0700 Subject: [PATCH 1/4] update setting service --- src/Services/SettingService.php | 289 +------------------------------- src/Trait/BotSettingTrait.php | 72 ++++++++ src/Trait/EventSettingTrait.php | 220 ++++++++++++++++++++++++ 3 files changed, 296 insertions(+), 285 deletions(-) create mode 100644 src/Trait/BotSettingTrait.php create mode 100644 src/Trait/EventSettingTrait.php diff --git a/src/Services/SettingService.php b/src/Services/SettingService.php index b05b3c5..f8062bb 100644 --- a/src/Services/SettingService.php +++ b/src/Services/SettingService.php @@ -2,15 +2,17 @@ namespace LbilTech\TelegramGitNotifier\Services; -use LbilTech\TelegramGitNotifier\Constants\EventConstant; -use LbilTech\TelegramGitNotifier\Constants\SettingConstant; use LbilTech\TelegramGitNotifier\Interfaces\SettingInterface; use LbilTech\TelegramGitNotifier\Models\Event; use LbilTech\TelegramGitNotifier\Models\Setting; +use LbilTech\TelegramGitNotifier\Trait\BotSettingTrait; +use LbilTech\TelegramGitNotifier\Trait\EventSettingTrait; use Telegram; class SettingService extends AppService implements SettingInterface { + use EventSettingTrait, BotSettingTrait; + public Setting $setting; public Event $event; @@ -27,287 +29,4 @@ public function __construct( $this->setting = $setting; $this->event = $event; } - - public function eventMarkup( - ?string $parentEvent = null, - string $platform = EventConstant::DEFAULT_PLATFORM - ): array { - $replyMarkup = $replyMarkupItem = []; - - $this->event->setEventConfig($platform); - $events = $parentEvent === null ? $this->event->eventConfig - : $this->event->eventConfig[$parentEvent]; - - foreach ($events as $key => $value) { - if (count($replyMarkupItem) - === SettingConstant::BTN_LINE_ITEM_COUNT - ) { - $replyMarkup[] = $replyMarkupItem; - $replyMarkupItem = []; - } - - $callbackData = $this->getCallbackData( - $key, - $platform, - $value, - $parentEvent - ); - $eventName = $this->getEventName($key, $value); - - $replyMarkupItem[] = $this->telegram->buildInlineKeyBoardButton( - $eventName, - '', - $callbackData - ); - } - - if (count($replyMarkupItem) > 0) { - $replyMarkup[] = $replyMarkupItem; - } - - $replyMarkup[] = $this->getEndKeyboard($platform, $parentEvent); - - return $replyMarkup; - } - - public function getCallbackData( - string $event, - string $platform, - array|bool $value = false, - ?string $parentEvent = null - ): string { - $platformSeparator = $platform === EventConstant::DEFAULT_PLATFORM - ? EventConstant::GITHUB_EVENT_SEPARATOR - : EventConstant::GITLAB_EVENT_SEPARATOR; - $prefix = EventConstant::EVENT_PREFIX . $platformSeparator; - - if (is_array($value)) { - return $prefix . EventConstant::EVENT_HAS_ACTION_SEPARATOR . $event; - } elseif ($parentEvent) { - return $prefix . $parentEvent . '.' . $event - . EventConstant::EVENT_UPDATE_SEPARATOR; - } - - return $prefix . $event . EventConstant::EVENT_UPDATE_SEPARATOR; - } - - public function getEventName(string $event, $value): string - { - if (is_array($value)) { - return '⚙ ' . $event; - } elseif ($value) { - return '✅ ' . $event; - } - - return '❌ ' . $event; - } - - public function getEndKeyboard( - string $platform, - ?string $parentEvent = null - ): array { - $back = SettingConstant::SETTING_BACK_TO_SETTINGS_MENU; - - if ($parentEvent) { - $back = SettingConstant::SETTING_BACK_TO_EVENTS_MENU - . $platform; - } - - return [ - $this->telegram->buildInlineKeyBoardButton('🔙 Back', '', $back), - $this->telegram->buildInlineKeyBoardButton( - '📚 Menu', - '', - SettingConstant::SETTING_BACK_TO_MAIN_MENU - ) - ]; - } - - public function eventHandle( - ?string $callback = null, - ?string $platform = null - ): void { - $platform = $this->getPlatformFromCallback($callback, $platform); - - if ($this->sendSettingEventMessage($platform, $callback)) { - return; - } - - $event = $this->getEventFromCallback($callback); - - if ($this->handleEventWithActions($event, $platform)) { - return; - } - - $this->handleEventUpdate($event, $platform); - } - - public function getPlatformFromCallback( - ?string $callback, - ?string $platform - ): string { - if ($platform) { - return $platform; - } - - if (str_contains($callback, EventConstant::GITHUB_EVENT_SEPARATOR)) { - return 'github'; - } elseif ( - str_contains( - $callback, - EventConstant::GITLAB_EVENT_SEPARATOR - ) - ) { - return 'gitlab'; - } - - return EventConstant::DEFAULT_PLATFORM; - } - - public function sendSettingEventMessage( - string $platform, - ?string $callback = null, - ?string $view = null - ): bool { - if (SettingConstant::SETTING_GITHUB_EVENTS === $callback - || SettingConstant::SETTING_GITLAB_EVENTS === $callback - || !$callback - ) { - $this->editMessageText( - view( - $view ?? - config('telegram-git-notifier.view.tools.custom_event'), - compact('platform') - ), - ['reply_markup' => $this->eventMarkup(null, $platform)] - ); - return true; - } - - return false; - } - - public function getEventFromCallback(?string $callback): string - { - return str_replace([ - EventConstant::EVENT_PREFIX, - EventConstant::GITHUB_EVENT_SEPARATOR, - EventConstant::GITLAB_EVENT_SEPARATOR - ], '', $callback); - } - - public function handleEventWithActions( - string $event, - string $platform, - ?string $view = null - ): bool { - if (str_contains($event, EventConstant::EVENT_HAS_ACTION_SEPARATOR)) { - $event = str_replace( - EventConstant::EVENT_HAS_ACTION_SEPARATOR, - '', - $event - ); - $this->editMessageText( - view( - $view ?? config('telegram-git-notifier.view.tools.custom_event_action'), - compact('event', 'platform') - ), - ['reply_markup' => $this->eventMarkup($event, $platform)] - ); - return true; - } - - return false; - } - - public function handleEventUpdate(string $event, string $platform): void - { - if (str_contains($event, EventConstant::EVENT_UPDATE_SEPARATOR)) { - $event = str_replace( - EventConstant::EVENT_UPDATE_SEPARATOR, - '', - $event - ); - $this->eventUpdateHandle($event, $platform); - } - } - - public function eventUpdateHandle(string $event, string $platform): void - { - [$event, $action] = explode('.', $event); - - $this->event->setEventConfig($platform); - $this->event->updateEvent($event, $action); - $this->eventHandle( - $action - ? EventConstant::PLATFORM_EVENT_SEPARATOR[$platform] - . EventConstant::EVENT_HAS_ACTION_SEPARATOR . $event - : null, - $platform - ); - } - - public function settingHandle(?string $view = null): void - { - $this->sendMessage( - view($view ?? config('telegram-git-notifier.view.tools.setting')), - ['reply_markup' => $this->settingMarkup()] - ); - } - - public function settingMarkup(): array - { - $markup = [ - [ - $this->telegram->buildInlineKeyBoardButton( - $this->setting[SettingConstant::T_IS_NOTIFIED] - ? '✅ Allow notifications' - : 'Allow notifications', - '', - SettingConstant::SETTING_IS_NOTIFIED - ), - ], - [ - $this->telegram->buildInlineKeyBoardButton( - $this->setting[SettingConstant::T_ALL_EVENTS_NOTIFICATION] - ? '✅ Enable All Events Notify' - : 'Enable All Events Notify', - '', - SettingConstant::SETTING_ALL_EVENTS_NOTIFY - ), - ] - ]; - - $markup = $this->customEventMarkup($markup); - - $markup[] = [ - $this->telegram->buildInlineKeyBoardButton( - '🔙 Back to menu', - '', - SettingConstant::SETTING_BACK . 'menu' - ), - ]; - - return $markup; - } - - public function customEventMarkup(array $markup): array - { - if (!$this->setting[SettingConstant::T_ALL_EVENTS_NOTIFICATION]) { - $markup[] = [ - $this->telegram->buildInlineKeyBoardButton( - '🦑 Custom github events', - '', - SettingConstant::SETTING_GITHUB_EVENTS - ), - $this->telegram->buildInlineKeyBoardButton( - '🦊 Custom gitlab events', - '', - SettingConstant::SETTING_GITLAB_EVENTS - ), - ]; - } - - return $markup; - } } diff --git a/src/Trait/BotSettingTrait.php b/src/Trait/BotSettingTrait.php new file mode 100644 index 0000000..e41dc0c --- /dev/null +++ b/src/Trait/BotSettingTrait.php @@ -0,0 +1,72 @@ +sendMessage( + view($view ?? config('telegram-git-notifier.view.tools.setting')), + ['reply_markup' => $this->settingMarkup()] + ); + } + + public function settingMarkup(): array + { + $markup = [ + [ + $this->telegram->buildInlineKeyBoardButton( + $this->setting[SettingConstant::T_IS_NOTIFIED] + ? '✅ Allow notifications' + : 'Allow notifications', + '', + SettingConstant::SETTING_IS_NOTIFIED + ), + ], + [ + $this->telegram->buildInlineKeyBoardButton( + $this->setting[SettingConstant::T_ALL_EVENTS_NOTIFICATION] + ? '✅ Enable All Events Notify' + : 'Enable All Events Notify', + '', + SettingConstant::SETTING_ALL_EVENTS_NOTIFY + ), + ] + ]; + + $markup = $this->customEventMarkup($markup); + + $markup[] = [ + $this->telegram->buildInlineKeyBoardButton( + '🔙 Back to menu', + '', + SettingConstant::SETTING_BACK . 'menu' + ), + ]; + + return $markup; + } + + public function customEventMarkup(array $markup): array + { + if (!$this->setting[SettingConstant::T_ALL_EVENTS_NOTIFICATION]) { + $markup[] = [ + $this->telegram->buildInlineKeyBoardButton( + '🦑 Custom github events', + '', + SettingConstant::SETTING_GITHUB_EVENTS + ), + $this->telegram->buildInlineKeyBoardButton( + '🦊 Custom gitlab events', + '', + SettingConstant::SETTING_GITLAB_EVENTS + ), + ]; + } + + return $markup; + } +} diff --git a/src/Trait/EventSettingTrait.php b/src/Trait/EventSettingTrait.php new file mode 100644 index 0000000..7815eb7 --- /dev/null +++ b/src/Trait/EventSettingTrait.php @@ -0,0 +1,220 @@ +event->setEventConfig($platform); + $events = $parentEvent === null ? $this->event->eventConfig + : $this->event->eventConfig[$parentEvent]; + + foreach ($events as $key => $value) { + if (count($replyMarkupItem) === SettingConstant::BTN_LINE_ITEM_COUNT) { + $replyMarkup[] = $replyMarkupItem; + $replyMarkupItem = []; + } + + $callbackData = $this->getCallbackData( + $key, + $platform, + $value, + $parentEvent + ); + $eventName = $this->getEventName($key, $value); + + $replyMarkupItem[] = $this->telegram->buildInlineKeyBoardButton( + $eventName, + '', + $callbackData + ); + } + + if (count($replyMarkupItem) > 0) { + $replyMarkup[] = $replyMarkupItem; + } + + $replyMarkup[] = $this->getEndKeyboard($platform, $parentEvent); + + return $replyMarkup; + } + + public function getCallbackData( + string $event, + string $platform, + array|bool $value = false, + ?string $parentEvent = null + ): string { + $platformSeparator = $platform === EventConstant::DEFAULT_PLATFORM + ? EventConstant::GITHUB_EVENT_SEPARATOR + : EventConstant::GITLAB_EVENT_SEPARATOR; + $prefix = EventConstant::EVENT_PREFIX . $platformSeparator; + + if (is_array($value)) { + return $prefix . EventConstant::EVENT_HAS_ACTION_SEPARATOR . $event; + } elseif ($parentEvent) { + return $prefix . $parentEvent . '.' . $event + . EventConstant::EVENT_UPDATE_SEPARATOR; + } + + return $prefix . $event . EventConstant::EVENT_UPDATE_SEPARATOR; + } + + public function getEventName(string $event, $value): string + { + if (is_array($value)) { + return '⚙ ' . $event; + } elseif ($value) { + return '✅ ' . $event; + } + + return '❌ ' . $event; + } + + public function getEndKeyboard( + string $platform, + ?string $parentEvent = null + ): array { + $back = SettingConstant::SETTING_BACK_TO_SETTINGS_MENU; + + if ($parentEvent) { + $back = SettingConstant::SETTING_BACK_TO_EVENTS_MENU + . $platform; + } + + return [ + $this->telegram->buildInlineKeyBoardButton('🔙 Back', '', $back), + $this->telegram->buildInlineKeyBoardButton( + '📚 Menu', + '', + SettingConstant::SETTING_BACK_TO_MAIN_MENU + ) + ]; + } + + public function eventHandle( + ?string $callback = null, + ?string $platform = null + ): void { + $platform = $this->getPlatformFromCallback($callback, $platform); + + if ($this->sendSettingEventMessage($platform, $callback)) { + return; + } + + $event = $this->getEventFromCallback($callback); + + if ($this->handleEventWithActions($event, $platform)) { + return; + } + + $this->handleEventUpdate($event, $platform); + } + + public function getPlatformFromCallback( + ?string $callback, + ?string $platform + ): string { + if ($platform) { + return $platform; + } + + if (str_contains($callback, EventConstant::GITHUB_EVENT_SEPARATOR)) { + return 'github'; + } elseif (str_contains($callback, EventConstant::GITLAB_EVENT_SEPARATOR)) { + return 'gitlab'; + } + + return EventConstant::DEFAULT_PLATFORM; + } + + public function sendSettingEventMessage( + string $platform, + ?string $callback = null, + ?string $view = null + ): bool { + if (SettingConstant::SETTING_GITHUB_EVENTS === $callback + || SettingConstant::SETTING_GITLAB_EVENTS === $callback + || !$callback + ) { + $this->editMessageText( + view( + $view ?? config('telegram-git-notifier.view.tools.custom_event'), + compact('platform') + ), + ['reply_markup' => $this->eventMarkup(null, $platform)] + ); + return true; + } + + return false; + } + + public function getEventFromCallback(?string $callback): string + { + return str_replace([ + EventConstant::EVENT_PREFIX, + EventConstant::GITHUB_EVENT_SEPARATOR, + EventConstant::GITLAB_EVENT_SEPARATOR + ], '', $callback); + } + + public function handleEventWithActions( + string $event, + string $platform, + ?string $view = null + ): bool { + if (str_contains($event, EventConstant::EVENT_HAS_ACTION_SEPARATOR)) { + $event = str_replace( + EventConstant::EVENT_HAS_ACTION_SEPARATOR, + '', + $event + ); + $this->editMessageText( + view( + $view ?? config('telegram-git-notifier.view.tools.custom_event_action'), + compact('event', 'platform') + ), + ['reply_markup' => $this->eventMarkup($event, $platform)] + ); + return true; + } + + return false; + } + + public function handleEventUpdate(string $event, string $platform): void + { + if (str_contains($event, EventConstant::EVENT_UPDATE_SEPARATOR)) { + $event = str_replace( + EventConstant::EVENT_UPDATE_SEPARATOR, + '', + $event + ); + $this->eventUpdateHandle($event, $platform); + } + } + + public function eventUpdateHandle(string $event, string $platform): void + { + [$event, $action] = explode('.', $event); + + $this->event->setEventConfig($platform); + $this->event->updateEvent($event, $action); + $this->eventHandle( + $action + ? EventConstant::PLATFORM_EVENT_SEPARATOR[$platform] + . EventConstant::EVENT_HAS_ACTION_SEPARATOR . $event + : null, + $platform + ); + } +} From f344a20767013a650f50ffce1aebc522a2408ad5 Mon Sep 17 00:00:00 2001 From: Tan Nguyen Date: Thu, 12 Oct 2023 10:22:02 +0700 Subject: [PATCH 2/4] optimize some check update type methods --- src/Interfaces/TelegramInterface.php | 7 +++++++ src/Services/TelegramService.php | 13 ++++++++++--- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/src/Interfaces/TelegramInterface.php b/src/Interfaces/TelegramInterface.php index c1dad9f..4776b77 100644 --- a/src/Interfaces/TelegramInterface.php +++ b/src/Interfaces/TelegramInterface.php @@ -26,4 +26,11 @@ public function setMyCommands( * @return bool */ public function isCallback(): bool; + + /** + * Check message or command from a telegram + * + * @return bool + */ + public function isMessage(): bool; } diff --git a/src/Services/TelegramService.php b/src/Services/TelegramService.php index 6530b72..3f137b9 100644 --- a/src/Services/TelegramService.php +++ b/src/Services/TelegramService.php @@ -32,9 +32,16 @@ public function setMyCommands( public function isCallback(): bool { - if (!is_null($this->telegram->getData()) - && !is_null($this->telegram->Callback_ChatID()) - ) { + if ($this->telegram->getUpdateType() === Telegram::CALLBACK_QUERY) { + return true; + } + + return false; + } + + public function isMessage(): bool + { + if ($this->telegram->getUpdateType() === Telegram::MESSAGE) { return true; } From dd83729e6ac54d56775a1ab8c1f430307d86c22d Mon Sep 17 00:00:00 2001 From: Tan Nguyen Date: Thu, 12 Oct 2023 10:23:37 +0700 Subject: [PATCH 3/4] fix small: style code --- src/Services/SettingService.php | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/Services/SettingService.php b/src/Services/SettingService.php index f8062bb..b48955d 100644 --- a/src/Services/SettingService.php +++ b/src/Services/SettingService.php @@ -11,7 +11,8 @@ class SettingService extends AppService implements SettingInterface { - use EventSettingTrait, BotSettingTrait; + use EventSettingTrait; + use BotSettingTrait; public Setting $setting; From b1c5cd9d74cb8e3c06950865c86c1e29aca40f4c Mon Sep 17 00:00:00 2001 From: Tan Nguyen Date: Fri, 13 Oct 2023 23:46:49 +0700 Subject: [PATCH 4/4] feat: add the new method to check owner of the bot --- config/tg-notifier.php | 4 ++-- src/Interfaces/TelegramInterface.php | 7 +++++++ src/Services/AppService.php | 2 +- src/Services/TelegramService.php | 15 ++++++++++++++- 4 files changed, 24 insertions(+), 4 deletions(-) diff --git a/config/tg-notifier.php b/config/tg-notifier.php index f2d77a6..1021753 100644 --- a/config/tg-notifier.php +++ b/config/tg-notifier.php @@ -18,8 +18,8 @@ ], 'author' => [ - 'contact' => $_ENV['TGN_AUTHOR_CONTACT'] ?? - 'https://t.me/tannp27', + 'discussion' => $_ENV['TGN_AUTHOR_DISCUSSION'] ?? + 'https://github.com/lbiltech/telegram-git-notifier/discussions', 'source_code' => $_ENV['TGN_AUTHOR_SOURCE_CODE'] ?? 'https://github.com/lbiltech/telegram-git-notifier', ], diff --git a/src/Interfaces/TelegramInterface.php b/src/Interfaces/TelegramInterface.php index 4776b77..9b11158 100644 --- a/src/Interfaces/TelegramInterface.php +++ b/src/Interfaces/TelegramInterface.php @@ -33,4 +33,11 @@ public function isCallback(): bool; * @return bool */ public function isMessage(): bool; + + /** + * Check owner of a telegram + * + * @return bool + */ + public function isOwner(): bool; } diff --git a/src/Services/AppService.php b/src/Services/AppService.php index c115806..8de81eb 100644 --- a/src/Services/AppService.php +++ b/src/Services/AppService.php @@ -12,7 +12,7 @@ class AppService implements AppInterface { public Telegram $telegram; - protected string $chatId; + public string $chatId; public function __construct(Telegram $telegram = null) { diff --git a/src/Services/TelegramService.php b/src/Services/TelegramService.php index 3f137b9..3712935 100644 --- a/src/Services/TelegramService.php +++ b/src/Services/TelegramService.php @@ -10,9 +10,13 @@ class TelegramService extends AppService implements TelegramInterface public Telegram $telegram; public function __construct( - Telegram $telegram + Telegram $telegram, + ?string $chatId = null ) { parent::__construct($telegram); + $this->setCurrentChatId($chatId); + + $this->telegram = $telegram; } public function setMyCommands( @@ -47,4 +51,13 @@ public function isMessage(): bool return false; } + + public function isOwner(): bool + { + if ($this->telegram->ChatID() == $this->chatId) { + return true; + } + + return false; + } }