Advertisement
Guest User

VirtueTron9000 v0.1.5

a guest
Jun 28th, 2018
223
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 6.05 KB | None | 0 0
  1. #!/usr/bin/python
  2. LICENCE = "WTFPL", "http://www.wtfpl.net/about/"
  3. VERSION = "v0.1.5"
  4.  
  5. print("Hello, Reddit!")
  6. print("VirtueTron9000 {0} (c) CrashARuntimeToday@outlook.com".format(VERSION))
  7.  
  8. import pickle
  9. import praw
  10. from datetime import datetime, timedelta
  11. from math import ceil
  12. from time import sleep
  13.  
  14.  
  15. reddit = praw.Reddit(client_id="VirtueTron9000",
  16.                      client_secret="🤖🤡🍆💯™",
  17.                      username="SignalAVirtueToday",
  18.                      password="https://youtu.be/RCVJ7bujnSc",
  19.                      user_agent="VirtueTron 9000 {0}".format(VERSION))
  20.  
  21. class Tracker:
  22.     def __init__(self, name, good_karma, bad_karma):
  23.         self.name = name
  24.         self.smv = None
  25.         self.scan_count = 0
  26.         self.next_refresh = None
  27.         self.update(good_karma, bad_karma)
  28.    
  29.     def update(self, good_karma, bad_karma):
  30.         self.good_karma = good_karma
  31.         self.bad_karma = bad_karma
  32.         self.scan_count += 1
  33.         self.next_refresh = datetime.now() + timedelta(minutes=15)
  34.  
  35. delay = 2
  36. def praw_fucked_up():
  37.     if delay > 128:
  38.         delay = 2
  39.     sleep(delay)
  40.     delay *= 2
  41.  
  42. def calc_score(name):
  43.     NAUGHTY_LIST = "TheRedPill", "MarriedRedPill", "ChristianRedPill", "MGTOW", "Braincels", "AskTRP", "AskMRP", "RedPillWomen", "RedPillWives", "CringeAnarchy", "The_Donald", "RPChristians"
  44.     good_karma, bad_karma, good_count, bad_count = 0, 0, 0, 0
  45.     for comment in reddit.redditor(name).comments.new(limit=100):
  46.         if comment.subreddit.display_name == "TheBluePill":
  47.             good_karma += comment.score - 1
  48.             good_count += 1
  49.         elif comment.subreddit.display_name in NAUGHTY_LIST and comment.score > 1:
  50.             bad_karma -= comment.score - 1
  51.             bad_count += 1
  52.     if good_count > 0:
  53.         good_karma /= good_count
  54.     if bad_count > 0:
  55.         bad_karma /= bad_count
  56.         if bad_count > 20 and not any(reddit.subreddit("TheBluePill").banned(redditor=name)):
  57.             print("User: {0} is vexatious ({1} posts in NAUGHTY_LIST)".format(name, bad_count))
  58.             reddit.subreddit("TheBluePill").flair.set(name, "VEXATIOUS LITIGANT", "vexatious")
  59.     print("Scanned user: {0}, good_karma: {1} ({2} comments), bad_karma: {3} ({4} comments)".format(name, good_karma, good_count, bad_karma, bad_count))
  60.     return good_karma, bad_karma
  61.  
  62. def update_flairs():
  63.     IMMUTABLE_FLAIRS = "vanguard", "vexatious", "endorsedflair", "alpha", "betaasfuck", "feeemale", "purged"
  64.     print("Recalculating SMV")
  65.     i = 0
  66.     total = len(users)
  67.     for user in sorted(users.values(), key=lambda x: x.good_karma + x.bad_karma):
  68.         i += 1
  69.         user.smv = ceil((i / total) * 10)
  70.         current_flair = None
  71.         try:
  72.             for flair in reddit.subreddit("TheBluePill").flair(redditor=user.name):
  73.                 current_flair = flair["flair_css_class"]
  74.         except praw.exceptions.PRAWException:       #Not sure why Reddit doesn't like this API call and too lazy to run Wireshark
  75.             praw_fucked_up()
  76.             continue
  77.        
  78.         if any(reddit.subreddit("TheBluePill").banned(redditor=user.name)):
  79.             if current_flair != "purged":
  80.                 print("Marking user: {0} purged".format(user.name))
  81.                 reddit.subreddit("TheBluePill").flair.set(user.name, "PURGED", "purged")
  82.             else:
  83.                 print("User: {0} is purged".format(user.name))
  84.         else:
  85.             print("User: {0}, SMV: {1}, score: {2} (current flair {3})".format(user.name, user.smv, user.good_karma + user.bad_karma, current_flair))
  86.  
  87.             if current_flair in IMMUTABLE_FLAIRS:
  88.                 print("Not changing user: {0} (immutable flair {1})".format(user.name, current_flair))
  89.             elif current_flair != "hb{0}".format(user.smv):
  90.                 print("Updating user: {0} flair to hb{1}".format(user.name, user.smv))
  91.                 reddit.subreddit("TheBluePill").flair.set(user.name, "Hβ{0}".format(user.smv), "hb{0}".format(user.smv))
  92.                 if user.smv > 7:
  93.                     if user.name not in reddit.subreddit("TheBluePill").contributor():
  94.                         print("Adding approved contributor: {0}".format(user.name))
  95.                         reddit.subreddit("TheBluePill").contributor.add(user.name)
  96.                 elif user.smv < 4:
  97.                     if user.name in reddit.subreddit("TheBluePill").contributor():
  98.                         print("Removing approved contributor: {0}".format(user.name))
  99.                         reddit.subreddit("TheBluePill").contributor.remove(user.name)
  100.             else:
  101.                 print("User: {0} still an HB{1}".format(user.name, user.smv))
  102.     pickle.dump(users, open("users.pickle", "wb"))
  103.    
  104. def botloop():
  105.     next_recalc = datetime.now() + timedelta(minutes=20)
  106.     for comment in reddit.subreddit("TheBluePill").stream.comments():
  107.         if datetime.now() > next_recalc:
  108.             update_flairs()
  109.             print("Next refresh: {0}".format(next_recalc))
  110.         if comment.author != None:
  111.             name = comment.author.name
  112.             if not name in users.keys():
  113.                 good_karma, bad_karma = calc_score(name)
  114.                 users[name] = Tracker(name, good_karma, bad_karma)
  115.                 print("New user: {0}".format(name))
  116.             elif datetime.now() > users[name].next_refresh:
  117.                 good_karma, bad_karma = calc_score(name)
  118.                 users[name].update(good_karma, bad_karma)
  119.                 print("User: {0} scanned {1} times".format(name, users[name].scan_count))
  120.             else:
  121.                 print("Skipping user:{0}, next refresh {1}".format(name, users[name].next_refresh))
  122.  
  123.  
  124. try:
  125.     users = pickle.load(open("users.pickle", "rb"))
  126.     print("Re-loading database")
  127. except IOError:
  128.     users = {}
  129.     print("I/O error accessing database, starting fresh")
  130.  
  131. try:
  132.     botloop()
  133. except praw.exceptions.PRAWException:
  134.     praw_fucked_up()
  135.     botloop()
  136. except KeyboardInterrupt:
  137.     print("VirtuteTron going off-line")
  138.     pickle.dump(users, open("users.pickle", "wb"))
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement