mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 01:00:13 +00:00 
			
		
		
		
	SendRegularPoll, SendQuizPoll
This commit is contained in:
		| @@ -6,6 +6,9 @@ | ||||
|     * `RegularPoll` type was added to represent polls with type `regular` | ||||
|     * `QuizPoll` type was added to represent polls with type `quiz` | ||||
|     * `UnknownPollType` type was added to represent polls which are unknown in current version | ||||
| * `SendPoll` was rewritten as sealed class | ||||
|     * `SendRegularPoll` was created and represent `sendPoll` method with type `regular` | ||||
|     * `SendQuizPoll` was created and represent `sendPoll` method with type `quiz` | ||||
|  | ||||
| ## 0.22.0 | ||||
|  | ||||
|   | ||||
| @@ -1,51 +0,0 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.requests.send | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.abstracts.ReplyingMarkupSendMessageRequest | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.abstracts.SendMessageRequest | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.TelegramBotAPIMessageDeserializationStrategyClass | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.PollContent | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| private val commonResultDeserializer: DeserializationStrategy<ContentMessage<PollContent>> | ||||
|     = TelegramBotAPIMessageDeserializationStrategyClass() | ||||
|  | ||||
| @Serializable | ||||
| data class SendPoll( | ||||
|     @SerialName(chatIdField) | ||||
|     override val chatId: ChatIdentifier, | ||||
|     @SerialName(questionField) | ||||
|     val question: String, | ||||
|     @SerialName(optionsField) | ||||
|     val options: List<String>, | ||||
|     @SerialName(disableNotificationField) | ||||
|     override val disableNotification: Boolean = false, | ||||
|     @SerialName(replyToMessageIdField) | ||||
|     override val replyToMessageId: MessageIdentifier? = null, | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: KeyboardMarkup? = null | ||||
| ) : SendMessageRequest<ContentMessage<PollContent>>, | ||||
|     ReplyingMarkupSendMessageRequest<ContentMessage<PollContent>> { | ||||
|  | ||||
|     init { | ||||
|         if (question.length !in pollQuestionTextLength) { | ||||
|             throw IllegalArgumentException("The length of questions for polls must be in $pollQuestionTextLength range, but was ${question.length}") | ||||
|         } | ||||
|         options.forEach { | ||||
|             if (it.length !in pollOptionTextLength) { | ||||
|                 throw IllegalArgumentException("The length of question option text for polls must be in $pollOptionTextLength range, but was ${it.length}") | ||||
|             } | ||||
|         } | ||||
|         if (options.size !in pollOptionsLimit) { | ||||
|             throw IllegalArgumentException("The amount of question options for polls must be in $pollOptionsLimit range, but was ${options.size}") | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     override fun method(): String = "sendPoll" | ||||
|     override val resultDeserializer: DeserializationStrategy<ContentMessage<PollContent>> | ||||
|         get() = commonResultDeserializer | ||||
|     override val requestSerializer: SerializationStrategy<*> | ||||
|         get() = serializer() | ||||
| } | ||||
| @@ -0,0 +1,127 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.requests.send.polls | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.abstracts.ReplyingMarkupSendMessageRequest | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.abstracts.SendMessageRequest | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.TelegramBotAPIMessageDeserializationStrategyClass | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.PollContent | ||||
| import kotlinx.serialization.* | ||||
|  | ||||
| private val commonResultDeserializer: DeserializationStrategy<ContentMessage<PollContent>> = TelegramBotAPIMessageDeserializationStrategyClass() | ||||
|  | ||||
| private fun checkPollInfo( | ||||
|     question: String, | ||||
|     options: List<String> | ||||
| ) { | ||||
|     if (question.length !in pollQuestionTextLength) { | ||||
|         throw IllegalArgumentException("The length of questions for polls must be in $pollQuestionTextLength range, but was ${question.length}") | ||||
|     } | ||||
|     options.forEach { | ||||
|         if (it.length !in pollOptionTextLength) { | ||||
|             throw IllegalArgumentException("The length of question option text for polls must be in $pollOptionTextLength range, but was ${it.length}") | ||||
|         } | ||||
|     } | ||||
|     if (options.size !in pollOptionsLimit) { | ||||
|         throw IllegalArgumentException("The amount of question options for polls must be in $pollOptionsLimit range, but was ${options.size}") | ||||
|     } | ||||
| } | ||||
|  | ||||
| fun SendPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     question: String, | ||||
|     options: List<String>, | ||||
|     isAnonymous: Boolean = true, | ||||
|     isClosed: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = SendRegularPoll( | ||||
|     chatId, | ||||
|     question, | ||||
|     options, | ||||
|     isAnonymous, | ||||
|     isClosed, | ||||
|     disableNotification = disableNotification, | ||||
|     replyToMessageId = replyToMessageId, | ||||
|     replyMarkup = replyMarkup | ||||
| ) | ||||
|  | ||||
| sealed class SendPoll : SendMessageRequest<ContentMessage<PollContent>>, | ||||
|     ReplyingMarkupSendMessageRequest<ContentMessage<PollContent>> { | ||||
|     abstract val question: String | ||||
|     abstract val options: List<String> | ||||
|     abstract val isAnonymous: Boolean | ||||
|     abstract val isClosed: Boolean | ||||
|     abstract val type: String | ||||
|  | ||||
|     override fun method(): String = "sendPoll" | ||||
|     override val resultDeserializer: DeserializationStrategy<ContentMessage<PollContent>> | ||||
|         get() = commonResultDeserializer | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| data class SendRegularPoll( | ||||
|     @SerialName(chatIdField) | ||||
|     override val chatId: ChatIdentifier, | ||||
|     @SerialName(questionField) | ||||
|     override val question: String, | ||||
|     @SerialName(optionsField) | ||||
|     override val options: List<String>, | ||||
|     @SerialName(isAnonymousField) | ||||
|     override val isAnonymous: Boolean = true, | ||||
|     @SerialName(isClosedField) | ||||
|     override val isClosed: Boolean = false, | ||||
|     @SerialName(allowsMultipleAnswersField) | ||||
|     val allowMultipleAnswers: Boolean = false, | ||||
|     @SerialName(disableNotificationField) | ||||
|     override val disableNotification: Boolean = false, | ||||
|     @SerialName(replyToMessageIdField) | ||||
|     override val replyToMessageId: MessageIdentifier? = null, | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: KeyboardMarkup? = null | ||||
| ) : SendPoll() { | ||||
|     override val type: String = regularPollType | ||||
|     override val requestSerializer: SerializationStrategy<*> | ||||
|         get() = serializer() | ||||
|  | ||||
|     init { | ||||
|         checkPollInfo(question, options) | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| data class SendQuizPoll( | ||||
|     @SerialName(chatIdField) | ||||
|     override val chatId: ChatIdentifier, | ||||
|     @SerialName(questionField) | ||||
|     override val question: String, | ||||
|     @SerialName(optionsField) | ||||
|     override val options: List<String>, | ||||
|     @SerialName(correctOptionIdField) | ||||
|     val correctOptionId: Int, | ||||
|     @SerialName(isAnonymousField) | ||||
|     override val isAnonymous: Boolean = true, | ||||
|     @SerialName(isClosedField) | ||||
|     override val isClosed: Boolean = false, | ||||
|     @SerialName(disableNotificationField) | ||||
|     override val disableNotification: Boolean = false, | ||||
|     @SerialName(replyToMessageIdField) | ||||
|     override val replyToMessageId: MessageIdentifier? = null, | ||||
|     @SerialName(replyMarkupField) | ||||
|     override val replyMarkup: KeyboardMarkup? = null | ||||
| ) : SendPoll() { | ||||
|     override val type: String = quizPollType | ||||
|     override val requestSerializer: SerializationStrategy<*> | ||||
|         get() = serializer() | ||||
|  | ||||
|     init { | ||||
|         checkPollInfo(question, options) | ||||
|         val correctOptionIdRange = 0 .. options.size | ||||
|         if (correctOptionId !in correctOptionIdRange) { | ||||
|             throw IllegalArgumentException("Correct option id must be in range of $correctOptionIdRange, but actual " + | ||||
|                 "value is $correctOptionId") | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,7 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.types.message.content | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.Request | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendPoll | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.polls.SendPoll | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| @@ -17,12 +17,13 @@ data class PollContent( | ||||
|         disableNotification: Boolean, | ||||
|         replyToMessageId: MessageIdentifier?, | ||||
|         replyMarkup: KeyboardMarkup? | ||||
|     ): Request<ContentMessage<PollContent>> = SendPoll( | ||||
|         chatId, | ||||
|         poll.question, | ||||
|         poll.options.map { it.text }, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
|     ): Request<ContentMessage<PollContent>> = | ||||
|         SendPoll( | ||||
|             chatId, | ||||
|             poll.question, | ||||
|             poll.options.map { it.text }, | ||||
|             disableNotification, | ||||
|             replyToMessageId, | ||||
|             replyMarkup | ||||
|         ) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user