diff --git a/modules/tweets.py b/modules/tweets.py deleted file mode 100644 index d100bb47..00000000 --- a/modules/tweets.py +++ /dev/null @@ -1,122 +0,0 @@ -#--depends-on commands -#--depends-on config - -#--require-config twitter-api-key -#--require-config twitter-api-secret -#--require-config twitter-access-token -#--require-config twitter-access-secret - -import datetime, html, re, time, traceback -import twitter -from src import ModuleManager, utils - -REGEX_TWITTERURL = re.compile( - "https?://(?:www\.)?twitter.com/[^/]+/status/(\d+)", re.I) - -@utils.export("channelset", {"setting": "auto-tweet", - "help": "Enable/disable automatically getting tweet info", - "validate": utils.bool_or_none, "example": "on"}) -class Module(ModuleManager.BaseModule): - _name = "Twitter" - - def make_timestamp(self, s): - seconds_since = time.time() - datetime.datetime.strptime(s, - "%a %b %d %H:%M:%S %z %Y").timestamp() - since, unit = utils.time_unit(seconds_since) - return "%s %s ago" % (since, unit) - - def _get_api(self): - api_key = self.bot.config["twitter-api-key"] - api_secret = self.bot.config["twitter-api-secret"] - access_token = self.bot.config["twitter-access-token"] - access_secret = self.bot.config["twitter-access-secret"] - return twitter.Twitter(auth=twitter.OAuth( - access_token, access_secret, api_key, api_secret)) - - def _from_id(self, tweet_id): - api = self._get_api() - try: - return api.statuses.show(id=tweet_id) - except: - traceback.print_exc() - - def _format_tweet(self, tweet): - linked_id = tweet["id"] - username = tweet["user"]["screen_name"] - - verified = "" - if tweet["user"]["verified"]: - verified = " %s" % utils.irc.color("✓", utils.consts.LIGHTBLUE) - - tweet_link = "https://twitter.com/%s/status/%s" % (username, - linked_id) - - short_url = self.exports.get_one("shortlink")(tweet_link) - short_url = " - %s" % short_url if short_url else "" - - if "retweeted_status" in tweet: - original_username = "@%s" % tweet["retweeted_status" - ]["user"]["screen_name"] - original_text = tweet["retweeted_status"]["text"] - retweet_timestamp = self.make_timestamp(tweet[ - "created_at"]) - original_timestamp = self.make_timestamp(tweet[ - "retweeted_status"]["created_at"]) - return "(@%s%s (%s) retweeted %s (%s)) %s%s" % ( - username, verified, retweet_timestamp, original_username, - original_timestamp, html.unescape(original_text), - short_url) - else: - return "(@%s%s, %s) %s%s" % (username, verified, - self.make_timestamp(tweet["created_at"]), - html.unescape(tweet["text"]), short_url) - - @utils.hook("received.command.tw", alias_of="tweet") - @utils.hook("received.command.tweet") - def tweet(self, event): - """ - :help: Get/find a tweet - :usage: [@username/URL/ID] - """ - - if event["args"]: - target = event["args"] - else: - target = event["target"].buffer.find(REGEX_TWITTERURL) - if target: - target = target.message - if target: - url_match = re.search(REGEX_TWITTERURL, target) - if url_match or target.isdigit(): - tweet_id = url_match.group(1) if url_match else target - tweet = self._from_id(tweet_id) - else: - if target.startswith("@"): - target = target[1:] - api = self._get_api() - try: - tweet = api.statuses.user_timeline( - screen_name=target, count=1)[0] - except: - traceback.print_exc() - tweet = None - if tweet: - tweet_str = self._format_tweet(tweet) - event["stdout"].write(tweet_str) - else: - event["stderr"].write("Invalid tweet identifiers provided") - else: - event["stderr"].write("No tweet provided to get information about") - - @utils.hook("command.regex", pattern=REGEX_TWITTERURL) - def regex(self, event): - """ - :command: tweet - """ - if event["target"].get_setting("auto-tweet", False): - event.eat() - tweet_id = event["match"].group(1) - tweet = self._from_id(tweet_id) - if tweet: - tweet_str = self._format_tweet(tweet) - event["stdout"].write(tweet_str) diff --git a/src/ModuleManager.py b/src/ModuleManager.py index ef452ff8..ff293446 100644 --- a/src/ModuleManager.py +++ b/src/ModuleManager.py @@ -250,6 +250,7 @@ class ModuleManager(object): to_remove = [] for name, dependencies in definition_dependencies.items(): if not dependencies: + changed = True # pop things with no unfufilled dependencies to_remove.append(name) for name in to_remove: @@ -257,8 +258,8 @@ class ModuleManager(object): del definition_dependencies[name] for deps in definition_dependencies.values(): if name in deps: - # fulfill dependencies for things we just popped changed = True + # fulfill dependencies for things we just popped deps.remove(name) if not changed: