-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbot.py
57 lines (43 loc) · 1.58 KB
/
bot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import logging
import requests
__author__ = ' Ilya Sosnovskiy - https://github.com/pashcovich'
__version__ = 0.1
loger = logging.getLogger()
loger.setLevel(logging.INFO)
log_format = logging.Formatter("%(asctime)s [%(levelname)-5.5s] %(message)s")
logPath = './logs/'
logFile = 'bot'
fileHandler = logging.FileHandler("{0}/{1}.log".format(logPath, logFile))
fileHandler.setFormatter(log_format)
loger.addHandler(fileHandler)
class BotHandler:
def __init__(self, token=None):
if token is None:
raise ValueError('`token` must be passed')
else:
self.token = token
self.api_url = "https://api.telegram.org/bot{}/".format(token)
def get_updates(self, offset=None, timeout=30):
method = 'getUpdates'
params = {'timeout': timeout, 'offset': offset}
resp = requests.get(self.api_url + method, params)
result_json = resp.json()['result']
return result_json
def send_message(self, chat_id, text, parse_mode=None):
if parse_mode is None:
params = {'chat_id': chat_id, 'text': text}
else:
params = {'chat_id': chat_id, 'text': text, 'parse_mode': parse_mode}
method = 'sendMessage'
resp = requests.post(self.api_url + method, params)
return resp
def get_last_update(self):
get_result = self.get_updates()
if len(get_result) > 0:
loger.info(get_result)
last_update = get_result[-1]
else:
last_update = None
return last_update