send_poll

template<class Agent>
api_result<message_t, Agent&&> send_poll(Agent &&agent, send_poll_args_t args)
template<class Agent, class F>
void send_poll(Agent &&agent, send_poll_args_t args, F &&callback)

agent is any object satisfying agent concept.

callback is any callable object accepting expected<message_t>.

Use this method to send a native poll. On success, the sent Message is returned.

struct send_poll_args_t

Arguments that should be passed to send_poll().

variant_t<integer_t, string_t> chat_id

Unique identifier for the target chat or username of the target channel (in the format @channelusername)

string_t question

Poll question, 1-300 characters

array_t<input_poll_option_t> options

A JSON-serialized list of 2-10 answer options

optional_t<integer_t> message_thread_id

Unique identifier for the target message thread (topic) of the forum; for forum supergroups only

optional_t<string_t> question_parse_mode

Mode for parsing entities in the question. See formatting options for more details. Currently, only custom emoji entities are allowed

optional_t<array_t<message_entity_t>> question_entities

A JSON-serialized list of special entities that appear in the poll question. It can be specified instead of question_parse_mode

optional_t<boolean_t> is_anonymous

True, if the poll needs to be anonymous, defaults to True

optional_t<string_t> type

Poll type, “quiz” or “regular”, defaults to “regular”

optional_t<boolean_t> allows_multiple_answers

True, if the poll allows multiple answers, ignored for polls in quiz mode, defaults to False

optional_t<integer_t> correct_option_id

0-based identifier of the correct answer option, required for polls in quiz mode

optional_t<string_t> explanation

Text that is shown when a user chooses an incorrect answer or taps on the lamp icon in a quiz-style poll, 0-200 characters with at most 2 line feeds after entities parsing

optional_t<string_t> explanation_parse_mode

Mode for parsing entities in the explanation. See formatting options for more details.

optional_t<array_t<message_entity_t>> explanation_entities

A JSON-serialized list of special entities that appear in the poll explanation. It can be specified instead of explanation_parse_mode

optional_t<integer_t> open_period

Amount of time in seconds the poll will be active after creation, 5-600. Can’t be used together with close_date.

optional_t<integer_t> close_date

Point in time (Unix timestamp) when the poll will be automatically closed. Must be at least 5 and no more than 600 seconds in the future. Can’t be used together with open_period.

optional_t<boolean_t> is_closed

Pass True if the poll needs to be immediately closed. This can be useful for poll preview.

optional_t<boolean_t> disable_notification

Sends the message silently. Users will receive a notification with no sound.

optional_t<boolean_t> protect_content

Protects the contents of the sent message from forwarding and saving

optional_t<boolean_t> allow_paid_broadcast

Pass True to allow up to 1000 messages per second, ignoring broadcasting limits for a fee of 0.1 Telegram Stars per message. The relevant Stars will be withdrawn from the bot’s balance

optional_t<string_t> message_effect_id

Unique identifier of the message effect to be added to the message; for private chats only

optional_t<reply_parameters_t> reply_parameters

Description of the message to reply to

optional_t<variant_t<inline_keyboard_markup_t, reply_keyboard_markup_t, reply_keyboard_remove_t, force_reply_t>> reply_markup

Additional interface options. A JSON-serialized object for an inline keyboard, custom reply keyboard, instructions to remove a reply keyboard or to force a reply from the user

optional_t<string_t> business_connection_id

Unique identifier of the business connection on behalf of which the message will be sent