Skip to content

Commit

Permalink
quoted text is now displayed as an embed field, added 2 options for e…
Browse files Browse the repository at this point in the history
…nabling/disabling quoted text and attachments
  • Loading branch information
NNTin committed Oct 22, 2020
1 parent 2f67c75 commit 42ce7cc
Show file tree
Hide file tree
Showing 5 changed files with 89 additions and 12 deletions.
16 changes: 12 additions & 4 deletions app.json
Original file line number Diff line number Diff line change
Expand Up @@ -47,15 +47,23 @@
},
"INCLUDE_REPLY_TO_USER": {
"description": "Include replies **from other** Twitter users tweeting **TO** your tracked twitter user?\nExample: `True`",
"required": false
"value": "true"
},
"INCLUDE_RETWEET": {
"description": "Include retweets?\nExample: `False`",
"required": false
"description": "Include retweets?\nExample: `False`\nWhether the bot should show retweets.",
"value": "true"
},
"IncludeAttachment": {
"description": "Include attachments?\nExample: `False`\nIf the tweet contains media the bot will try to attach an image.",
"value": "true"
},
"IncludeQuote": {
"description": "Include retweets?\nExample: `False`\nThis requires INCLUDE_RETWEET True. Shows the original tweet as an additional field in the embed.",
"value": "true"
},
"INCLUDE_USER_REPLY": {
"description": "Include replies **FROM** your tracked twitter user to other twitter users\nExample: `True`",
"required": false
"value": "true"
},
"CUSTOM_MESSAGE": {
"description": "OPTIONAL: Custom message. Useful for pinging @everyone, a role or individual discord members.\nExample: `A new tweet arived pinging role <@&123456> and user <@123456>`\nWith 123456 being the role or user id. You can get them by e.g. typing `\\@Linley#8686` the backslash \\ is important!",
Expand Down
20 changes: 20 additions & 0 deletions bot/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER!b}
IncludeRetweet: ${INCLUDE_RETWEET!b}
IncludeUserReply: ${INCLUDE_USER_REPLY!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT!b}
IncludeQuote: ${INCLUDE_QUOTE!b}
custom_message: ${CUSTOM_MESSAGE}
keyword_sets: ${KEYWORDS!ll}
blackword_sets: ${BLACKWORDS!ll}
Expand All @@ -52,6 +54,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_2!b}
IncludeRetweet: ${INCLUDE_RETWEET_2!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_2!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_2!b}
IncludeQuote: ${INCLUDE_QUOTE_2!b}
custom_message: ${CUSTOM_MESSAGE_2}
keyword_sets: ${KEYWORDS_2!ll}
blackword_sets: ${BLACKWORDS_2!ll}
Expand All @@ -65,6 +69,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_3!b}
IncludeRetweet: ${INCLUDE_RETWEET_3!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_3!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_3!b}
IncludeQuote: ${INCLUDE_QUOTE_3!b}
custom_message: ${CUSTOM_MESSAGE_3}
keyword_sets: ${KEYWORDS_3!ll}
blackword_sets: ${BLACKWORDS_3!ll}
Expand All @@ -78,6 +84,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_4!b}
IncludeRetweet: ${INCLUDE_RETWEET_4!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_4!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_4!b}
IncludeQuote: ${INCLUDE_QUOTE_4!b}
custom_message: ${CUSTOM_MESSAGE_4}
keyword_sets: ${KEYWORDS_4!ll}
blackword_sets: ${BLACKWORDS_4!ll}
Expand All @@ -91,6 +99,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_5!b}
IncludeRetweet: ${INCLUDE_RETWEET_5!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_5!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_5!b}
IncludeQuote: ${INCLUDE_QUOTE_5!b}
custom_message: ${CUSTOM_MESSAGE_5}
keyword_sets: ${KEYWORDS_5!ll}
blackword_sets: ${BLACKWORDS_5!ll}
Expand All @@ -104,6 +114,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_6!b}
IncludeRetweet: ${INCLUDE_RETWEET_6!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_6!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_6!b}
IncludeQuote: ${INCLUDE_QUOTE_6!b}
custom_message: ${CUSTOM_MESSAGE_6}
keyword_sets: ${KEYWORDS_6!ll}
blackword_sets: ${BLACKWORDS_6!ll}
Expand All @@ -117,6 +129,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_7!b}
IncludeRetweet: ${INCLUDE_RETWEET_7!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_7!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_7!b}
IncludeQuote: ${INCLUDE_QUOTE_7!b}
custom_message: ${CUSTOM_MESSAGE_7}
keyword_sets: ${KEYWORDS_7!ll}
blackword_sets: ${BLACKWORDS_7!ll}
Expand All @@ -130,6 +144,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_8!b}
IncludeRetweet: ${INCLUDE_RETWEET_8!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_8!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_8!b}
IncludeQuote: ${INCLUDE_QUOTE_8!b}
custom_message: ${CUSTOM_MESSAGE_8}
keyword_sets: ${KEYWORDS_8!ll}
blackword_sets: ${BLACKWORDS_8!ll}
Expand All @@ -143,6 +159,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_9!b}
IncludeRetweet: ${INCLUDE_RETWEET_9!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_9!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_9!b}
IncludeQuote: ${INCLUDE_QUOTE_9!b}
custom_message: ${CUSTOM_MESSAGE_9}
keyword_sets: ${KEYWORDS_9!ll}
blackword_sets: ${BLACKWORDS_9!ll}
Expand All @@ -156,6 +174,8 @@ Discord:
- IncludeReplyToUser: ${INCLUDE_REPLY_TO_USER_10!b}
IncludeRetweet: ${INCLUDE_RETWEET_10!b}
IncludeUserReply: ${INCLUDE_USER_REPLY_10!b}
IncludeAttachment: ${INCLUDE_ATTACHMENT_10!b}
IncludeQuote: ${INCLUDE_QUOTE_10!b}
custom_message: ${CUSTOM_MESSAGE_10}
keyword_sets: ${KEYWORDS_10!ll}
blackword_sets: ${BLACKWORDS_10!ll}
Expand Down
8 changes: 5 additions & 3 deletions bot/main.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/usr/local/bin/python
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from tweepy.streaming import StreamListener
from tweepy import Stream
Expand Down Expand Up @@ -52,6 +52,7 @@ def _on_status(self, status):

for wh_url in data_discord.get("webhook_urls", []):
p.create_embed()
p.attach_field()
p.attach_media()

p.send_message(wh_url)
Expand All @@ -71,8 +72,9 @@ def on_status(self, status):
f"---------Error---------\n"
f"unknown error\n"
f"You've found an error. Please contact the owner (https://discord.gg/JV5eUB) "
f"and send him what follows below:\n"
f"and send him what follows below in a pastebin (no picture!):\n"
f"{error}\n"
f"{self.config_discord}\n"
f"{status}"
f"-----------------------"
)
Expand Down Expand Up @@ -123,7 +125,7 @@ def print_error(_error):
f"---------Error---------\n"
f"unknown error\n"
f"You've found an error. Please contact the owner (https://discord.gg/JV5eUB) "
f"and send him what follows below:\n"
f"and send him what follows below in a pastebin (no picture!):\n"
f"{error}\n"
f"{config}\n"
f"Sleeping for 5 minute then continuing.\n"
Expand Down
51 changes: 46 additions & 5 deletions bot/utils/processor.py
Original file line number Diff line number Diff line change
Expand Up @@ -209,14 +209,14 @@ def get_text(self):
else:
self.text = self.status_tweet["text"]

for url in self.status_tweet["entities"]["urls"]:
for url in self.status_tweet["entities"].get("urls", []):
if url["expanded_url"] is None:
continue
self.text = self.text.replace(
url["url"], "[%s](%s)" % (url["display_url"], url["expanded_url"])
)

for userMention in self.status_tweet["entities"]["user_mentions"]:
for userMention in self.status_tweet["entities"].get("user_mentions", []):
self.text = self.text.replace(
"@%s" % userMention["screen_name"],
"[@%s](https://twitter.com/%s)"
Expand All @@ -225,7 +225,7 @@ def get_text(self):

if "extended_tweet" in self.status_tweet:
for hashtag in sorted(
self.status_tweet["extended_tweet"]["entities"]["hashtags"],
self.status_tweet["extended_tweet"]["entities"].get("hashtags", []),
key=lambda k: k["text"],
reverse=True,
):
Expand All @@ -235,7 +235,9 @@ def get_text(self):
)

for hashtag in sorted(
self.status_tweet["entities"]["hashtags"], key=lambda k: k["text"], reverse=True
self.status_tweet["entities"].get("hashtags", []),
key=lambda k: k["text"],
reverse=True,
):
self.text = self.text.replace(
"#%s" % hashtag["text"],
Expand All @@ -250,8 +252,47 @@ def keyword_set_present(self):
def blackword_set_present(self):
return blackword_set_present(self.discord_config.get("blackword_sets", [[""]]), self.text)

def attach_field(self):
if self.discord_config.get("IncludeQuote", True) and "quoted_status" in self.status_tweet:
if self.status_tweet["quoted_status"].get("text"):
text = self.status_tweet["quoted_status"]["text"]
for url in self.status_tweet["quoted_status"]["entities"].get("urls", []):
if url["expanded_url"] is None:
continue
text = text.replace(
url["url"], "[%s](%s)" % (url["display_url"], url["expanded_url"])
)

for userMention in self.status_tweet["quoted_status"]["entities"].get(
"user_mentions", []
):
text = text.replace(
"@%s" % userMention["screen_name"],
"[@%s](https://twitter.com/%s)"
% (userMention["screen_name"], userMention["screen_name"]),
)

for hashtag in sorted(
self.status_tweet["quoted_status"]["entities"].get("hashtags", []),
key=lambda k: k["text"],
reverse=True,
):
text = text.replace(
"#%s" % hashtag["text"],
"[#%s](https://twitter.com/hashtag/%s)"
% (hashtag["text"], hashtag["text"]),
)

text = unescape(text)
self.embed.add_field(
name=self.status_tweet["quoted_status"]["user"]["screen_name"], value=text
)

def attach_media(self):
if "retweeted_status" in self.status_tweet:
if (
self.discord_config.get("IncludeAttachment", True)
and "retweeted_status" in self.status_tweet
):
if (
"extended_tweet" in self.status_tweet["retweeted_status"]
and "media" in self.status_tweet["retweeted_status"]["extended_tweet"]["entities"]
Expand Down
6 changes: 6 additions & 0 deletions tests/test_config/config_schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,12 @@
},
"IncludeUserReply": {
"type": "boolean"
},
"IncludeQuote": {
"type": "boolean"
},
"IncludeAttachment": {
"type": "boolean"
}
},
"additionalProperties": false,
Expand Down

0 comments on commit 42ce7cc

Please sign in to comment.