Advertisement
Guest User

VirtueTron9000 v0.1.4a

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