-
Notifications
You must be signed in to change notification settings - Fork 116
/
bot.py
106 lines (87 loc) · 3.42 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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
import logging
import telegram
import tweepy
from pytz import timezone, utc
from telegram import Bot
from telegram.error import TelegramError
from models import TelegramChat, TwitterUser
from util import escape_markdown, prepare_tweet_text
class TwitterForwarderBot(Bot):
def __init__(self, token, tweepy_api_object, update_offset=0):
super().__init__(token=token)
self.logger = logging.getLogger(self.__class__.__name__)
self.logger.info("Initializing")
self.update_offset = update_offset
self.tw = tweepy_api_object
def reply(self, update, text, *args, **kwargs):
self.sendMessage(chat_id=update.message.chat.id, text=text, *args, **kwargs)
def send_tweet(self, chat, tweet):
try:
self.logger.debug("Sending tweet {} to chat {}...".format(
tweet.tw_id, chat.chat_id
))
'''
Use a soft-hyphen to put an invisible link to the first
image in the tweet, which will then be displayed as preview
'''
photo_url = ''
if tweet.photo_url:
photo_url = '[\xad](%s)' % tweet.photo_url
created_dt = utc.localize(tweet.created_at)
if chat.timezone_name is not None:
tz = timezone(chat.timezone_name)
created_dt = created_dt.astimezone(tz)
created_at = created_dt.strftime('%Y-%m-%d %H:%M:%S %Z')
self.sendMessage(
chat_id=chat.chat_id,
disable_web_page_preview=not photo_url,
text="""
{link_preview}*{name}* ([@{screen_name}](https://twitter.com/{screen_name})) at {created_at}:
{text}
-- [Link to this Tweet](https://twitter.com/{screen_name}/status/{tw_id})
"""
.format(
link_preview=photo_url,
text=prepare_tweet_text(tweet.text),
name=escape_markdown(tweet.name),
screen_name=tweet.screen_name,
created_at=created_at,
tw_id=tweet.tw_id,
),
parse_mode=telegram.ParseMode.MARKDOWN)
except TelegramError as e:
self.logger.info("Couldn't send tweet {} to chat {}: {}".format(
tweet.tw_id, chat.chat_id, e.message
))
delet_this = None
if e.message == 'Bad Request: group chat was migrated to a supergroup chat':
delet_this = True
if e.message == "Unauthorized":
delet_this = True
if delet_this:
self.logger.info("Marking chat for deletion")
chat.delete_soon = True
chat.save()
def get_chat(self, tg_chat):
db_chat, _created = TelegramChat.get_or_create(
chat_id=tg_chat.id,
tg_type=tg_chat.type,
)
return db_chat
def get_tw_user(self, tw_username):
try:
tw_user = self.tw.get_user(tw_username)
except tweepy.error.TweepError as err:
self.logger.error(err)
return None
db_user, _created = TwitterUser.get_or_create(
screen_name=tw_user.screen_name,
defaults={
'name': tw_user.name,
},
)
if not _created:
if db_user.name != tw_user.name:
db_user.name = tw_user.name
db_user.save()
return db_user