Правила (Rule)
- это возможность провалидировать событие до его обработки по определенным правилам.
Использование правил
Класс, который валидирует событие, должен наследовать от базового класса BaseRule. Валидация события происходит в методе passes, который принимает объект события, а после возвращает true или false. Если хоть одно правило вернуло false - обработка события текущим хендлером прекращается.
use Fastik1\VkBot\Rules\isChatMessageRule;
use Fastik1\VkBot\Rules\isPrivateMessageRule;
use Fastik1\Vkfast\Bot\Events\MessageNew;
$bot->message(function (MessageNew $event) { // обработка всех сообщений из чатов (использование правила)
// обработка события, которое прошло валидацию правилами
})->rule(new isChatMessageRule);
$bot->message(function (MessageNew $event) { // обработка всех личных сообщений (использование правила)
// обработка события, которое прошло валидацию правилами
})->rule([new isPrivateMessageRule, /* другие правила в виде массива */]);Реализация правила isChatMessageRule
isChatMessageRulenamespace Fastik1\Vkfast\Bot\Rules; // используйте свой namespace при создании собственных правил
use Fastik1\Vkfast\Bot\Events\Event;
use Fastik1\Vkfast\Bot\Events\MessageNew;
class IsChatMessageBaseRule extends BaseRule
{
public function passes(MessageNew|Event $event): bool
{
return $event->message->peer_id != $event->message->from_id; // если peer_id и from_id равны - значит это сообщение из чата
}
}Использование динамический правил
Вы можете сделать свое правило динамичным. Пример такого правила:
Использование такого правила:
Таким образом, мы можем удобно проверять событие на определенный peer_id.
Last updated