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

Merge pull request #1011 from Badiboy/master

Long polling updates and combo content types
This commit is contained in:
Badiboy 2020-11-07 13:02:22 +03:00 committed by GitHub
commit ece7ca97e0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 7 deletions

View File

@ -52,10 +52,10 @@ def _make_request(token, method_name, method='get', params=None, files=None):
:param files: Optional files. :param files: Optional files.
:return: The result parsed to a JSON dictionary. :return: The result parsed to a JSON dictionary.
""" """
if API_URL is None: if API_URL:
request_url = "https://api.telegram.org/bot{0}/{1}".format(token, method_name)
else:
request_url = API_URL.format(token, method_name) request_url = API_URL.format(token, method_name)
else:
request_url = "https://api.telegram.org/bot{0}/{1}".format(token, method_name)
logger.debug("Request: method={0} url={1} params={2} files={3}".format(method, request_url, params, files)) logger.debug("Request: method={0} url={1} params={2} files={3}".format(method, request_url, params, files))
read_timeout = READ_TIMEOUT read_timeout = READ_TIMEOUT
@ -67,7 +67,12 @@ def _make_request(token, method_name, method='get', params=None, files=None):
read_timeout = params.pop('timeout') + 10 read_timeout = params.pop('timeout') + 10
if 'connect-timeout' in params: if 'connect-timeout' in params:
connect_timeout = params.pop('connect-timeout') + 10 connect_timeout = params.pop('connect-timeout') + 10
if 'long_polling_timeout' in params:
# For getUpdates: the only function with timeout on the BOT API side
params['timeout'] = params.pop('long_polling_timeout')
result = None
if RETRY_ON_ERROR: if RETRY_ON_ERROR:
got_result = False got_result = False
current_try = 0 current_try = 0
@ -235,7 +240,7 @@ def get_updates(token, offset=None, limit=None, timeout=None, allowed_updates=No
if limit: if limit:
payload['limit'] = limit payload['limit'] = limit
if timeout: if timeout:
payload['timeout'] = timeout payload['long_polling_timeout'] = timeout
if allowed_updates: if allowed_updates:
payload['allowed_updates'] = json.dumps(allowed_updates) payload['allowed_updates'] = json.dumps(allowed_updates)
return _make_request(token, method_url, params=payload) return _make_request(token, method_url, params=payload)

View File

@ -21,6 +21,15 @@ logger = logging.getLogger('TeleBot')
thread_local = threading.local() thread_local = threading.local()
content_type_media = [
'text', 'audio', 'document', 'photo', 'sticker', 'video', 'video_note', 'voice', 'contact', 'dice', 'poll',
'venue', 'location'
]
content_type_service = [
'new_chat_members', 'left_chat_member', 'new_chat_title', 'new_chat_photo', 'delete_chat_photo', 'group_chat_created',
'supergroup_chat_created', 'channel_chat_created', 'migrate_to_chat_id', 'migrate_from_chat_id', 'pinned_message'
]
class WorkerThread(threading.Thread): class WorkerThread(threading.Thread):
count = 0 count = 0
@ -286,7 +295,6 @@ def chunks(lst, n):
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): def deprecated(func):
"""This is a decorator which can be used to mark functions """This is a decorator which can be used to mark functions
as deprecated. It will result in a warning being emitted as deprecated. It will result in a warning being emitted