From d27bf642eb209ad209314ab1bf9976158912b424 Mon Sep 17 00:00:00 2001 From: levlam Date: Sun, 19 Apr 2020 09:47:37 +0300 Subject: [PATCH] Add MessageDice::is_valid(). GitOrigin-RevId: 924ffa6d43cda4b32994f22b2300cf0f79ab7458 --- td/telegram/MessageContent.cpp | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/td/telegram/MessageContent.cpp b/td/telegram/MessageContent.cpp index bb33b1b9..a50f3a58 100644 --- a/td/telegram/MessageContent.cpp +++ b/td/telegram/MessageContent.cpp @@ -658,6 +658,16 @@ class MessageDice : public MessageContent { MessageContentType get_type() const override { return MessageContentType::Dice; } + + bool is_valid() const { + if (dice_value < 0) { + return false; + } + if (emoji == "DEFAULT_EMOJI" || emoji == "🎯") { + return dice_value <= 6; + } + return dice_value <= 1000; + } }; constexpr const char *MessageDice::DEFAULT_EMOJI; @@ -1275,7 +1285,7 @@ static void parse(unique_ptr &content, ParserT &parser) { m->emoji = MessageDice::DEFAULT_EMOJI; } parse(m->dice_value, parser); - is_bad = m->dice_value < 0 || m->dice_value > 6; + is_bad = !m->is_valid(); content = std::move(m); break; } @@ -3744,7 +3754,7 @@ unique_ptr get_message_content(Td *td, FormattedText message, auto message_dice = move_tl_object_as(media); auto m = td::make_unique(message_dice->emoticon_, message_dice->value_); - if (m->dice_value < 0 || m->dice_value > 6) { + if (!m->is_valid()) { break; }