1
0
mirror of https://github.com/eternnoir/pyTelegramBotAPI.git synced 2023-08-10 21:12:57 +03:00

Merge pull request #821 from Badiboy/master

send_poll revised to standart signature
This commit is contained in:
Badiboy 2020-05-02 13:35:34 +03:00 committed by GitHub
commit d8a08638a7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 75 additions and 26 deletions

View File

@ -2,7 +2,8 @@
<p align="center">A simple, but extensible Python implementation for the <a href="https://core.telegram.org/bots/api">Telegram Bot API</a>. <p align="center">A simple, but extensible Python implementation for the <a href="https://core.telegram.org/bots/api">Telegram Bot API</a>.
[![Download Month](https://img.shields.io/pypi/v/pyTelegramBotAPI.svg)](https://pypi.python.org/pypi/pyTelegramBotAPI) [![PyPi Package Version](https://img.shields.io/pypi/v/pyTelegramBotAPI.svg)](https://pypi.python.org/pypi/pyTelegramBotAPI)
[![Supported Python versions](https://img.shields.io/pypi/pyversions/pyTelegramBotAPI.svg)](https://pypi.python.org/pypi/pyTelegramBotAPI)
[![Build Status](https://travis-ci.org/eternnoir/pyTelegramBotAPI.svg?branch=master)](https://travis-ci.org/eternnoir/pyTelegramBotAPI) [![Build Status](https://travis-ci.org/eternnoir/pyTelegramBotAPI.svg?branch=master)](https://travis-ci.org/eternnoir/pyTelegramBotAPI)
* [Getting started.](#getting-started) * [Getting started.](#getting-started)

View File

@ -1207,17 +1207,42 @@ class TeleBot:
disable_notification, reply_to_message_id, reply_markup, provider_data) disable_notification, reply_to_message_id, reply_markup, provider_data)
return types.Message.de_json(result) return types.Message.de_json(result)
def send_poll(self, chat_id, poll, explanation_parse_mode=None, disable_notifications=False, reply_to_message=None, reply_markup=None): def send_poll(
self, chat_id,
question, options,
is_anonymous=None, type=None, allows_multiple_answers=None, correct_option_id=None,
explanation=None, explanation_parse_mode=None, open_period=None, close_date=None, is_closed=None,
disable_notifications=False, reply_to_message_id=None, reply_markup=None):
""" """
Sends poll Send polls
:param chat_id: :param chat_id:
:param poll: :param question:
:param options: array of str with answers
:param is_anonymous:
:param type:
:param allows_multiple_answers:
:param correct_option_id:
:param explanation:
:param explanation_parse_mode:
:param open_period:
:param close_date:
:param is_closed:
:param disable_notifications: :param disable_notifications:
:param reply_to_message: :param reply_to_message_id:
:param reply_markup: :param reply_markup:
:return: :return:
""" """
return types.Message.de_json(apihelper.send_poll(self.token, chat_id, poll, explanation_parse_mode, disable_notifications, reply_to_message, reply_markup))
if isinstance(question, types.Poll):
raise Exception("The send_poll signature was changed, please see send_poll function details.")
return types.Message.de_json(
apihelper.send_poll(
self.token, chat_id,
question, options,
is_anonymous, type, allows_multiple_answers, correct_option_id,
explanation, explanation_parse_mode, open_period, close_date, is_closed,
disable_notifications, reply_to_message_id, reply_markup))
def stop_poll(self, chat_id, message_id): def stop_poll(self, chat_id, message_id):
""" """

View File

@ -998,31 +998,36 @@ def delete_sticker_from_set(token, sticker):
return _make_request(token, method_url, params=payload, method='post') return _make_request(token, method_url, params=payload, method='post')
def send_poll(token, chat_id, poll, explanation_parse_mode=None, disable_notifications=False, reply_to_message_id=None, reply_markup=None): def send_poll(
token, chat_id,
question, options,
is_anonymous = None, type = None, allows_multiple_answers = None, correct_option_id = None,
explanation = None, explanation_parse_mode=None, open_period = None, close_date = None, is_closed = None,
disable_notifications=False, reply_to_message_id=None, reply_markup=None):
method_url = r'sendPoll' method_url = r'sendPoll'
payload = { payload = {
'chat_id': str(chat_id), 'chat_id': str(chat_id),
'question': poll.question, 'question': question,
'options': _convert_list_json_serializable(poll.options)} 'options': json.dumps(options)}
if poll.is_anonymous is not None: if is_anonymous is not None:
payload['is_anonymous'] = poll.is_anonymous payload['is_anonymous'] = is_anonymous
if poll.type is not None: if type is not None:
payload['type'] = poll.type payload['type'] = type
if poll.allows_multiple_answers is not None: if allows_multiple_answers is not None:
payload['allows_multiple_answers'] = poll.allows_multiple_answers payload['allows_multiple_answers'] = allows_multiple_answers
if poll.correct_option_id is not None: if correct_option_id is not None:
payload['correct_option_id'] = poll.correct_option_id payload['correct_option_id'] = correct_option_id
if poll.explanation is not None: if explanation is not None:
payload['explanation'] = poll.explanation payload['explanation'] = explanation
if explanation_parse_mode is not None: if explanation_parse_mode is not None:
payload['explanation_parse_mode'] = explanation_parse_mode payload['explanation_parse_mode'] = explanation_parse_mode
if poll.open_period is not None: if open_period is not None:
payload['open_period'] = poll.open_period payload['open_period'] = open_period
if poll.close_date is not None: if close_date is not None:
payload['close_date'] = poll.close_date payload['close_date'] = close_date
if poll.is_closed is not None: if is_closed is not None:
payload['is_closed'] = poll.is_closed payload['is_closed'] = is_closed
if disable_notifications: if disable_notifications:
payload['disable_notification'] = disable_notifications payload['disable_notification'] = disable_notifications

View File

@ -5,6 +5,8 @@ import string
import sys import sys
import threading import threading
import traceback import traceback
import warnings
import functools
import six import six
from six import string_types from six import string_types
@ -259,3 +261,19 @@ def per_thread(key, construct_value, reset=False):
def generate_random_token(): def generate_random_token():
return ''.join(random.sample(string.ascii_letters, 16)) return ''.join(random.sample(string.ascii_letters, 16))
def deprecated(func):
"""This is a decorator which can be used to mark functions
as deprecated. It will result in a warning being emitted
when the function is used."""
# https://stackoverflow.com/a/30253848/441814
@functools.wraps(func)
def new_func(*args, **kwargs):
warnings.simplefilter('always', DeprecationWarning) # turn off filter
warnings.warn("Call to deprecated function {}.".format(func.__name__),
category=DeprecationWarning,
stacklevel=2)
warnings.simplefilter('default', DeprecationWarning) # reset filter
return func(*args, **kwargs)
return new_func