2021-10-15 14:08:27 +00:00
import time
from os import remove
from PIL import Image as IMAGE
2022-01-12 05:04:24 +00:00
2021-10-15 14:08:27 +00:00
from files . helpers . wrappers import *
from files . helpers . alerts import *
from files . helpers . sanitize import *
from files . helpers . security import *
from files . helpers . get import *
from files . helpers . images import *
from files . helpers . const import *
from files . classes import *
from flask import *
2022-01-12 05:04:24 +00:00
from files . __main__ import app , cache , limiter
2021-10-15 14:08:27 +00:00
from . front import frontlist
from files . helpers . discord import add_role
2021-12-20 20:03:59 +00:00
from datetime import datetime
2021-12-31 13:02:54 +00:00
import requests
2021-10-15 14:08:27 +00:00
SITE_NAME = environ . get ( " SITE_NAME " , " " ) . strip ( )
2021-12-28 04:47:02 +00:00
GUMROAD_ID = environ . get ( " GUMROAD_ID " , " tfcvri " ) . strip ( )
2021-12-31 12:54:58 +00:00
GUMROAD_TOKEN = environ . get ( " GUMROAD_TOKEN " , " " ) . strip ( )
2021-12-28 04:47:02 +00:00
2022-01-09 15:15:02 +00:00
CF_KEY = environ . get ( " CF_KEY " , " " ) . strip ( )
CF_ZONE = environ . get ( " CF_ZONE " , " " ) . strip ( )
CF_HEADERS = { " Authorization " : f " Bearer { CF_KEY } " , " Content-Type " : " application/json " }
2021-11-16 21:21:53 +00:00
if SITE_NAME == ' PCM ' : cc = " splash mountain "
else : cc = " country club "
2021-12-20 20:03:59 +00:00
month = datetime . now ( ) . strftime ( ' % B ' )
2021-10-15 14:08:27 +00:00
2022-01-09 15:15:02 +00:00
2022-01-03 10:32:31 +00:00
@app.post ( " /@<username>/make_admin " )
@limiter.limit ( " 1/second " )
@admin_level_required ( 3 )
def make_admin ( v , username ) :
if request . host == ' rdrama.net ' : abort ( 403 )
user = get_user ( username )
if not user : abort ( 404 )
user . admin_level = 2
g . db . add ( user )
g . db . commit ( )
return { " message " : " User has been made admin! " }
@app.post ( " /@<username>/remove_admin " )
@limiter.limit ( " 1/second " )
@admin_level_required ( 3 )
def remove_admin ( v , username ) :
user = get_user ( username )
if not user : abort ( 404 )
user . admin_level = 0
g . db . add ( user )
g . db . commit ( )
return { " message " : " Admin removed! " }
2021-12-23 18:59:49 +00:00
@app.post ( " /distribute/<comment> " )
2021-12-23 18:40:30 +00:00
@limiter.limit ( " 1/second " )
2021-12-11 03:32:43 +00:00
@admin_level_required ( 3 )
2021-12-23 18:46:07 +00:00
def distribute ( v , comment ) :
2021-12-23 18:48:57 +00:00
try : comment = int ( comment )
2021-12-11 03:18:14 +00:00
except : abort ( 400 )
2022-01-02 00:06:46 +00:00
post = g . db . query ( Comment ) . filter_by ( id = comment ) . one_or_none ( ) . post
2021-12-23 18:18:25 +00:00
pool = 0
for option in post . bet_options : pool + = option . upvotes
2021-12-23 18:30:34 +00:00
pool * = 200
2021-12-23 18:43:52 +00:00
votes = g . db . query ( CommentVote ) . filter_by ( comment_id = comment )
2021-12-23 18:18:25 +00:00
coinsperperson = int ( pool / votes . count ( ) )
2021-12-23 18:28:20 +00:00
cid = notif_comment ( f " You won { coinsperperson } coins betting on [ { post . permalink } ]( { post . permalink } ) :marseyparty: " )
2021-12-11 03:07:51 +00:00
for vote in votes :
u = vote . user
u . coins + = coinsperperson
2021-12-20 20:03:59 +00:00
add_notif ( cid , u . id )
2021-12-11 03:07:51 +00:00
2022-01-02 00:06:46 +00:00
autobetter = g . db . query ( User ) . filter_by ( id = AUTOBETTER_ID ) . one_or_none ( )
2021-12-23 18:18:25 +00:00
autobetter . coins - = pool
2021-12-23 19:02:54 +00:00
if autobetter . coins < 0 : return { " error " : " Not enough coins in bool " } , 400
2021-12-11 03:07:51 +00:00
g . db . add ( autobetter )
2021-12-23 18:18:25 +00:00
2021-12-23 18:28:20 +00:00
cid = notif_comment ( f " You lost the 200 coins you bet on [ { post . permalink } ]( { post . permalink } ) :marseylaugh: " )
2021-12-23 18:39:39 +00:00
cids = [ x . id for x in post . bet_options ]
2021-12-23 18:43:52 +00:00
cids . remove ( comment )
2021-12-23 18:28:20 +00:00
votes = g . db . query ( CommentVote ) . filter ( CommentVote . comment_id . in_ ( cids ) ) . all ( )
2021-12-23 18:29:38 +00:00
for vote in votes : add_notif ( cid , vote . user . id )
2021-12-23 18:28:20 +00:00
2021-12-11 03:07:51 +00:00
g . db . commit ( )
2021-12-23 18:59:49 +00:00
return { " message " : f " Each winner has received { coinsperperson } coins! " }
2021-12-11 03:07:51 +00:00
2021-10-15 14:08:27 +00:00
@app.post ( " /@<username>/revert_actions " )
@limiter.limit ( " 1/second " )
2021-12-17 03:25:05 +00:00
@admin_level_required ( 3 )
2021-10-15 14:08:27 +00:00
def revert_actions ( v , username ) :
2021-12-17 03:25:05 +00:00
user = get_user ( username )
if not user : abort ( 404 )
cutoff = int ( time . time ( ) ) - 86400
2021-12-17 03:44:26 +00:00
posts = [ x [ 0 ] for x in g . db . query ( ModAction . target_submission_id ) . filter ( ModAction . user_id == user . id , ModAction . created_utc > cutoff , ModAction . kind == ' ban_post ' ) . all ( ) ]
2021-12-17 03:52:05 +00:00
posts = g . db . query ( Submission ) . filter ( Submission . id . in_ ( posts ) ) . all ( )
2021-12-17 03:50:55 +00:00
2021-12-17 03:44:26 +00:00
comments = [ x [ 0 ] for x in g . db . query ( ModAction . target_comment_id ) . filter ( ModAction . user_id == user . id , ModAction . created_utc > cutoff , ModAction . kind == ' ban_comment ' ) . all ( ) ]
2021-12-17 03:52:05 +00:00
comments = g . db . query ( Comment ) . filter ( Comment . id . in_ ( comments ) ) . all ( )
2021-12-17 03:50:55 +00:00
2021-12-17 03:25:05 +00:00
for item in posts + comments :
item . is_banned = False
g . db . add ( item )
2021-12-17 03:48:44 +00:00
users = ( x [ 0 ] for x in g . db . query ( ModAction . target_user_id ) . filter ( ModAction . user_id == user . id , ModAction . created_utc > cutoff , ModAction . kind . in_ ( ( ' shadowban ' , ' ban_user ' ) ) ) . all ( ) )
2021-12-17 03:51:21 +00:00
users = g . db . query ( User ) . filter ( User . id . in_ ( users ) ) . all ( )
2021-12-17 03:50:55 +00:00
2021-12-17 03:25:05 +00:00
for user in users :
user . shadowbanned = None
user . is_banned = 0
user . unban_utc = 0
user . ban_evade = 0
g . db . add ( user )
for u in user . alts :
u . shadowbanned = None
u . is_banned = 0
u . unban_utc = 0
u . ban_evade = 0
g . db . add ( u )
2021-10-15 14:08:27 +00:00
2021-12-17 03:25:05 +00:00
g . db . commit ( )
2021-10-15 14:08:27 +00:00
return { " message " : " Admin actions reverted! " }
@app.post ( " /@<username>/club_allow " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def club_allow ( v , username ) :
u = get_user ( username , v = v )
if not u : abort ( 404 )
if u . admin_level > = v . admin_level : return { " error " : " noob " }
u . club_allowed = True
g . db . add ( u )
for x in u . alts_unique :
x . club_allowed = True
g . db . add ( x )
g . db . commit ( )
2021-11-16 21:21:53 +00:00
return { " message " : f " @ { username } has been allowed into the { cc } ! " }
2021-10-15 14:08:27 +00:00
@app.post ( " /@<username>/club_ban " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def club_ban ( v , username ) :
u = get_user ( username , v = v )
if not u : abort ( 404 )
if u . admin_level > = v . admin_level : return { " error " : " noob " }
u . club_allowed = False
for x in u . alts_unique :
u . club_allowed = False
g . db . add ( x )
g . db . commit ( )
2021-11-16 21:21:53 +00:00
return { " message " : f " @ { username } has been kicked from the { cc } . Deserved. " }
2021-10-15 14:08:27 +00:00
2021-11-26 19:28:55 +00:00
@app.post ( " /@<username>/make_meme_admin " )
2021-10-15 14:08:27 +00:00
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-11-26 19:28:55 +00:00
def make_meme_admin ( v , username ) :
2022-01-01 22:06:53 +00:00
if request . host == ' pcmemes.net ' or ( SITE_NAME == ' Drama ' and v . admin_level > 2 ) or ( request . host != ' rdrama.net ' and request . host != ' pcmemes.net ' ) :
2021-10-15 14:08:27 +00:00
user = get_user ( username )
if not user : abort ( 404 )
user . admin_level = 1
g . db . add ( user )
g . db . commit ( )
2021-11-26 19:28:55 +00:00
return { " message " : " User has been made meme admin! " }
2021-10-15 14:08:27 +00:00
2021-11-26 19:28:55 +00:00
@app.post ( " /@<username>/remove_meme_admin " )
2021-10-15 14:08:27 +00:00
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-11-26 19:28:55 +00:00
def remove_meme_admin ( v , username ) :
2022-01-01 22:06:53 +00:00
if request . host == ' pcmemes.net ' or ( SITE_NAME == ' Drama ' and v . admin_level > 2 ) or ( request . host != ' rdrama.net ' and request . host != ' pcmemes.net ' ) :
2021-10-15 14:08:27 +00:00
user = get_user ( username )
if not user : abort ( 404 )
user . admin_level = 0
g . db . add ( user )
g . db . commit ( )
2021-11-26 19:28:55 +00:00
return { " message " : " Meme admin removed! " }
2021-10-15 14:08:27 +00:00
@app.post ( " /admin/monthly " )
2021-12-31 12:56:59 +00:00
@limiter.limit ( " 1/day " )
2021-12-31 12:56:47 +00:00
@admin_level_required ( 3 )
2021-10-15 14:08:27 +00:00
def monthly ( v ) :
2022-01-07 21:44:38 +00:00
if request . host == ' rdrama.net ' and v . id != AEVANN_ID : abort ( 403 )
2022-01-01 22:06:53 +00:00
2022-01-02 00:26:34 +00:00
thing = g . db . query ( AwardRelationship ) . order_by ( AwardRelationship . id . desc ( ) ) . first ( ) . id
2022-01-01 22:06:53 +00:00
data = { ' access_token ' : GUMROAD_TOKEN }
emails = [ x [ ' email ' ] for x in requests . get ( f ' https://api.gumroad.com/v2/products/ { GUMROAD_ID } /subscribers ' , data = data , timeout = 5 ) . json ( ) [ " subscribers " ] ]
2022-01-12 04:24:05 +00:00
for u in g . db . query ( User ) . filter ( User . patron > 0 ) . all ( ) :
2022-01-01 22:06:53 +00:00
if u . patron == 5 or u . email and u . email . lower ( ) in emails or u . id == 1379 :
if u . patron == 1 : procoins = 2500
elif u . patron == 2 : procoins = 5000
elif u . patron == 3 : procoins = 10000
elif u . patron == 4 : procoins = 25000
elif u . patron == 5 : procoins = 50000
2022-01-01 22:37:55 +00:00
else :
print ( u . username )
u . patron = 0
g . db . add ( u )
continue
2022-01-01 22:06:53 +00:00
u . procoins + = procoins
g . db . add ( u )
send_repeatable_notification ( u . id , f " You were given { procoins } Marseybux for the month of { month } ! You can use them to buy awards in the [shop](/shop). " )
g . db . commit ( )
2021-10-21 22:55:48 +00:00
return { " message " : " Monthly coins granted " }
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
@app.get ( ' /admin/sidebar ' )
2021-12-31 23:45:27 +00:00
@admin_level_required ( 3 )
2021-12-30 05:27:22 +00:00
def get_sidebar ( v ) :
2021-10-15 14:08:27 +00:00
try :
2021-12-30 05:27:22 +00:00
with open ( f ' files/templates/sidebar_ { SITE_NAME } .html ' , ' r ' ) as f : sidebar = f . read ( )
2021-12-31 12:22:55 +00:00
except :
2021-12-30 05:27:22 +00:00
sidebar = None
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
return render_template ( ' admin/sidebar.html ' , v = v , sidebar = sidebar )
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
@app.post ( ' /admin/sidebar ' )
2021-10-15 14:08:27 +00:00
@limiter.limit ( " 1/second " )
2021-12-31 23:45:27 +00:00
@admin_level_required ( 3 )
2021-12-30 05:27:22 +00:00
def post_sidebar ( v ) :
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
text = request . values . get ( ' sidebar ' , ' ' ) . strip ( )
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
with open ( f ' files/templates/sidebar_ { SITE_NAME } .html ' , ' w+ ' ) as f : f . write ( text )
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
with open ( f ' files/templates/sidebar_ { SITE_NAME } .html ' , ' r ' ) as f : sidebar = f . read ( )
2021-10-25 18:08:03 +00:00
ma = ModAction (
2021-12-30 05:27:22 +00:00
kind = " change_sidebar " ,
2021-10-25 18:08:03 +00:00
user_id = v . id ,
)
g . db . add ( ma )
g . db . commit ( )
2021-10-15 14:08:27 +00:00
2021-12-31 12:22:55 +00:00
return render_template ( ' admin/sidebar.html ' , v = v , sidebar = sidebar , msg = ' Sidebar edited successfully! ' )
2021-10-15 14:08:27 +00:00
@app.get ( " /admin/shadowbanned " )
@auth_required
def shadowbanned ( v ) :
2021-11-15 22:13:29 +00:00
if not ( v and v . admin_level > 1 ) : abort ( 404 )
2022-01-03 10:55:35 +00:00
users = [ x for x in g . db . query ( User ) . filter ( User . shadowbanned != None ) . order_by ( User . shadowbanned ) . all ( ) ]
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
2022-01-03 10:33:16 +00:00
return render_template ( f " { template } shadowbanned.html " , v = v , users = users )
2021-10-15 14:08:27 +00:00
@app.get ( " /admin/image_posts " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def image_posts_listing ( v ) :
try : page = int ( request . values . get ( ' page ' , 1 ) )
except : page = 1
2021-11-06 15:52:48 +00:00
posts = g . db . query ( Submission ) . order_by ( Submission . id . desc ( ) )
2021-10-15 14:08:27 +00:00
firstrange = 25 * ( page - 1 )
secondrange = firstrange + 26
posts = [ x . id for x in posts if x . is_image ] [ firstrange : secondrange ]
next_exists = ( len ( posts ) > 25 )
posts = get_posts ( posts [ : 25 ] , v = v )
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/image_posts.html " , v = v , listing = posts , next_exists = next_exists , page = page , sort = " new " )
2021-10-15 14:08:27 +00:00
@app.get ( " /admin/reported/posts " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def reported_posts ( v ) :
page = max ( 1 , int ( request . values . get ( " page " , 1 ) ) )
2022-01-11 22:37:37 +00:00
listing = g . db . query ( Submission ) . filter_by (
2021-10-15 14:08:27 +00:00
is_approved = 0 ,
is_banned = False
2021-12-17 17:55:11 +00:00
) . join ( Submission . reports ) . order_by ( Submission . id . desc ( ) ) . offset ( 25 * ( page - 1 ) ) . limit ( 26 )
2021-10-15 14:08:27 +00:00
2022-01-11 22:40:16 +00:00
listing = [ p . id for p in listing ]
2022-01-11 22:37:37 +00:00
next_exists = len ( listing ) > 25
2021-10-15 14:08:27 +00:00
listing = listing [ : 25 ]
listing = get_posts ( listing , v = v )
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/reported_posts.html " ,
2021-10-15 14:08:27 +00:00
next_exists = next_exists , listing = listing , page = page , v = v )
@app.get ( " /admin/reported/comments " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def reported_comments ( v ) :
page = max ( 1 , int ( request . values . get ( " page " , 1 ) ) )
2022-01-11 22:37:37 +00:00
listing = g . db . query ( Comment
2021-11-06 15:52:48 +00:00
) . filter_by (
2021-10-15 14:08:27 +00:00
is_approved = 0 ,
is_banned = False
2021-12-17 17:55:11 +00:00
) . join ( Comment . reports ) . order_by ( Comment . id . desc ( ) ) . offset ( 25 * ( page - 1 ) ) . limit ( 26 ) . all ( )
2021-10-15 14:08:27 +00:00
2022-01-11 22:40:16 +00:00
listing = [ c . id for c in listing ]
2022-01-11 22:37:37 +00:00
next_exists = len ( listing ) > 25
2021-10-15 14:08:27 +00:00
listing = listing [ : 25 ]
listing = get_comments ( listing , v = v )
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/reported_comments.html " ,
2021-10-15 14:08:27 +00:00
next_exists = next_exists ,
listing = listing ,
page = page ,
v = v ,
standalone = True )
@app.get ( " /admin " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_home ( v ) :
2021-12-31 16:40:03 +00:00
2022-01-09 15:15:02 +00:00
with open ( ' disable_signups ' , ' r ' ) as f : x = f . read ( )
with open ( ' under_attack ' , ' r ' ) as f : x2 = f . read ( )
2021-12-31 16:40:03 +00:00
2022-01-09 15:15:02 +00:00
if not v or v . oldsite : return render_template ( " admin/admin_home.html " , v = v , x = x , x2 = x2 )
2021-12-31 16:40:03 +00:00
2021-12-31 16:51:53 +00:00
actions = g . db . query ( ModAction ) . order_by ( ModAction . id . desc ( ) ) . limit ( 10 ) . all ( )
2021-12-31 16:40:46 +00:00
2022-01-09 15:15:02 +00:00
return render_template ( " CHRISTMAS/admin/admin_home.html " , actions = actions , v = v , x = x , x2 = x2 )
2021-10-15 14:08:27 +00:00
2022-01-09 15:15:02 +00:00
@app.post ( " /admin/disable_signups " )
2022-01-08 06:41:40 +00:00
@admin_level_required ( 3 )
2022-01-09 15:15:02 +00:00
def disable_signups ( v ) :
with open ( ' disable_signups ' , ' r ' ) as f : content = f . read ( )
2021-10-29 17:58:38 +00:00
2022-01-09 15:15:02 +00:00
with open ( ' disable_signups ' , ' w ' ) as f :
2021-10-29 17:58:38 +00:00
if content == " yes " :
2021-10-15 14:08:27 +00:00
f . write ( " no " )
2022-01-08 06:41:40 +00:00
ma = ModAction (
kind = " enable_signups " ,
user_id = v . id ,
)
g . db . add ( ma )
g . db . commit ( )
return { " message " : " Signups enabled! " }
2021-10-15 14:08:27 +00:00
else :
f . write ( " yes " )
2022-01-08 06:41:40 +00:00
ma = ModAction (
kind = " disable_signups " ,
user_id = v . id ,
)
g . db . add ( ma )
g . db . commit ( )
2021-10-15 14:08:27 +00:00
return { " message " : " Signups disabled! " }
2022-01-09 15:15:02 +00:00
2022-01-14 02:33:27 +00:00
@app.post ( " /admin/purge_cache " )
@admin_level_required ( 3 )
def purge_cache ( v ) :
2022-01-14 02:46:27 +00:00
response = str ( requests . post ( f ' https://api.cloudflare.com/client/v4/zones/ { CF_ZONE } /purge_cache ' , headers = CF_HEADERS , data = ' { " purge_everything " :true} ' ) )
2022-01-14 02:33:27 +00:00
if response == " <Response [200]> " : return { " message " : " Cache purged! " }
return { " error " : " Failed to purge cache. " }
2022-01-09 15:15:02 +00:00
@app.post ( " /admin/under_attack " )
@admin_level_required ( 2 )
def under_attack ( v ) :
with open ( ' under_attack ' , ' r ' ) as f : content = f . read ( )
with open ( ' under_attack ' , ' w ' ) as f :
if content == " yes " :
f . write ( " no " )
ma = ModAction (
kind = " disable_under_attack " ,
user_id = v . id ,
)
g . db . add ( ma )
g . db . commit ( )
2022-01-09 15:24:09 +00:00
2022-01-14 02:41:19 +00:00
response = str ( requests . patch ( f ' https://api.cloudflare.com/client/v4/zones/ { CF_ZONE } /settings/security_level ' , headers = CF_HEADERS , data = ' { " value " : " medium " } ' ) )
2022-01-09 15:24:09 +00:00
if response == " <Response [200]> " : return { " message " : " Under attack mode disabled! " }
return { " error " : " Failed to disable under attack mode. " }
2022-01-09 15:15:02 +00:00
else :
f . write ( " yes " )
ma = ModAction (
kind = " enable_under_attack " ,
user_id = v . id ,
)
g . db . add ( ma )
g . db . commit ( )
2022-01-14 02:41:19 +00:00
response = str ( requests . patch ( f ' https://api.cloudflare.com/client/v4/zones/ { CF_ZONE } /settings/security_level ' , headers = CF_HEADERS , data = ' { " value " : " under_attack " } ' ) )
2022-01-09 15:24:09 +00:00
if response == " <Response [200]> " : return { " message " : " Under attack mode enabled! " }
return { " error " : " Failed to enable under attack mode. " }
2022-01-09 15:15:02 +00:00
2021-10-15 14:08:27 +00:00
@app.get ( " /admin/badge_grant " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def badge_grant_get ( v ) :
2021-12-28 19:34:09 +00:00
if not v or v . oldsite : template = ' '
else : template = ' CHRISTMAS/ '
2021-10-15 14:08:27 +00:00
2021-12-28 14:11:50 +00:00
return render_template ( f " { template } admin/badge_grant.html " , v = v , badge_types = BADGES )
2021-10-15 14:08:27 +00:00
@app.post ( " /admin/badge_grant " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def badge_grant_post ( v ) :
2021-12-28 14:11:50 +00:00
if not v or v . oldsite : template = ' '
else : template = ' CHRISTMAS/ '
2021-10-15 14:08:27 +00:00
user = get_user ( request . values . get ( " username " ) . strip ( ) , graceful = True )
2021-12-28 14:11:50 +00:00
if not user :
return render_template ( f " { template } admin/badge_grant.html " , v = v , badge_types = BADGES , error = " User not found. " )
2021-10-15 14:08:27 +00:00
try : badge_id = int ( request . values . get ( " badge_id " ) )
except : abort ( 400 )
2021-12-28 14:11:50 +00:00
if user . has_badge ( badge_id ) :
return render_template ( f " { template } admin/badge_grant.html " , v = v , badge_types = BADGES , error = " User already has that badge. " )
2021-10-15 14:08:27 +00:00
2021-10-23 19:15:50 +00:00
new_badge = Badge ( badge_id = badge_id , user_id = user . id )
2021-10-15 14:08:27 +00:00
desc = request . values . get ( " description " )
if desc : new_badge . description = desc
url = request . values . get ( " url " )
if url : new_badge . url = url
g . db . add ( new_badge )
2022-01-03 10:32:31 +00:00
if v . id != user . id :
text = f " @ { v . username } has given you the following profile badge: \n \n ![]( { new_badge . path } ) \n \n { new_badge . name } "
send_notification ( user . id , text )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
2021-12-28 14:11:50 +00:00
return render_template ( f " { template } admin/badge_grant.html " , v = v , badge_types = BADGES , msg = " Badge granted! " )
2021-10-15 14:08:27 +00:00
2022-01-11 03:28:35 +00:00
@app.get ( " /admin/badge_remove " )
@admin_level_required ( 2 )
def badge_remove_get ( v ) :
if not v or v . oldsite : template = ' '
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/badge_remove.html " , v = v , badge_types = BADGES )
@app.post ( " /admin/badge_remove " )
@limiter.limit ( " 1/second " )
@admin_level_required ( 2 )
def badge_remove_post ( v ) :
if not v or v . oldsite : template = ' '
else : template = ' CHRISTMAS/ '
user = get_user ( request . values . get ( " username " ) . strip ( ) , graceful = True )
if not user :
return render_template ( f " { template } admin/badge_remove.html " , v = v , badge_types = BADGES , error = " User not found. " )
try : badge_id = int ( request . values . get ( " badge_id " ) )
except : abort ( 400 )
badge = user . has_badge ( badge_id )
if badge :
g . db . delete ( badge )
g . db . commit ( )
return render_template ( f " { template } admin/badge_remove.html " , v = v , badge_types = BADGES , msg = " Badge removed! " )
2021-10-15 14:08:27 +00:00
@app.get ( " /admin/users " )
@admin_level_required ( 2 )
def users_list ( v ) :
page = int ( request . values . get ( " page " , 1 ) )
2021-11-06 15:52:48 +00:00
users = g . db . query ( User ) . filter_by ( is_banned = 0
2021-10-15 14:08:27 +00:00
) . order_by ( User . created_utc . desc ( )
) . offset ( 25 * ( page - 1 ) ) . limit ( 26 )
users = [ x for x in users ]
next_exists = ( len ( users ) > 25 )
users = users [ : 25 ]
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/new_users.html " ,
2021-10-15 14:08:27 +00:00
v = v ,
users = users ,
next_exists = next_exists ,
page = page ,
)
@app.get ( " /admin/alt_votes " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def alt_votes_get ( v ) :
if not request . values . get ( " u1 " ) or not request . values . get ( " u2 " ) :
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/alt_votes.html " , v = v )
2021-10-15 14:08:27 +00:00
u1 = request . values . get ( " u1 " )
u2 = request . values . get ( " u2 " )
if not u1 or not u2 :
return redirect ( " /admin/alt_votes " )
u1 = get_user ( u1 )
u2 = get_user ( u2 )
u1_post_ups = g . db . query (
2021-11-06 15:52:48 +00:00
Vote . submission_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u1 . id ,
vote_type = 1 ) . all ( )
u1_post_downs = g . db . query (
2021-11-06 15:52:48 +00:00
Vote . submission_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u1 . id ,
vote_type = - 1 ) . all ( )
u1_comment_ups = g . db . query (
2021-11-06 15:52:48 +00:00
CommentVote . comment_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u1 . id ,
vote_type = 1 ) . all ( )
u1_comment_downs = g . db . query (
2021-11-06 15:52:48 +00:00
CommentVote . comment_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u1 . id ,
vote_type = - 1 ) . all ( )
u2_post_ups = g . db . query (
2021-11-06 15:52:48 +00:00
Vote . submission_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u2 . id ,
vote_type = 1 ) . all ( )
u2_post_downs = g . db . query (
2021-11-06 15:52:48 +00:00
Vote . submission_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u2 . id ,
vote_type = - 1 ) . all ( )
u2_comment_ups = g . db . query (
2021-11-06 15:52:48 +00:00
CommentVote . comment_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u2 . id ,
vote_type = 1 ) . all ( )
u2_comment_downs = g . db . query (
2021-11-06 15:52:48 +00:00
CommentVote . comment_id ) . filter_by (
2021-10-15 14:08:27 +00:00
user_id = u2 . id ,
vote_type = - 1 ) . all ( )
data = { }
data [ ' u1_only_post_ups ' ] = len (
[ x for x in u1_post_ups if x not in u2_post_ups ] )
data [ ' u2_only_post_ups ' ] = len (
[ x for x in u2_post_ups if x not in u1_post_ups ] )
data [ ' both_post_ups ' ] = len ( list ( set ( u1_post_ups ) & set ( u2_post_ups ) ) )
data [ ' u1_only_post_downs ' ] = len (
[ x for x in u1_post_downs if x not in u2_post_downs ] )
data [ ' u2_only_post_downs ' ] = len (
[ x for x in u2_post_downs if x not in u1_post_downs ] )
data [ ' both_post_downs ' ] = len (
list ( set ( u1_post_downs ) & set ( u2_post_downs ) ) )
data [ ' u1_only_comment_ups ' ] = len (
[ x for x in u1_comment_ups if x not in u2_comment_ups ] )
data [ ' u2_only_comment_ups ' ] = len (
[ x for x in u2_comment_ups if x not in u1_comment_ups ] )
data [ ' both_comment_ups ' ] = len (
list ( set ( u1_comment_ups ) & set ( u2_comment_ups ) ) )
data [ ' u1_only_comment_downs ' ] = len (
[ x for x in u1_comment_downs if x not in u2_comment_downs ] )
data [ ' u2_only_comment_downs ' ] = len (
[ x for x in u2_comment_downs if x not in u1_comment_downs ] )
data [ ' both_comment_downs ' ] = len (
list ( set ( u1_comment_downs ) & set ( u2_comment_downs ) ) )
data [ ' u1_post_ups_unique ' ] = 100 * \
data [ ' u1_only_post_ups ' ] / / len ( u1_post_ups ) if u1_post_ups else 0
data [ ' u2_post_ups_unique ' ] = 100 * \
data [ ' u2_only_post_ups ' ] / / len ( u2_post_ups ) if u2_post_ups else 0
data [ ' u1_post_downs_unique ' ] = 100 * \
data [ ' u1_only_post_downs ' ] / / len (
u1_post_downs ) if u1_post_downs else 0
data [ ' u2_post_downs_unique ' ] = 100 * \
data [ ' u2_only_post_downs ' ] / / len (
u2_post_downs ) if u2_post_downs else 0
data [ ' u1_comment_ups_unique ' ] = 100 * \
data [ ' u1_only_comment_ups ' ] / / len (
u1_comment_ups ) if u1_comment_ups else 0
data [ ' u2_comment_ups_unique ' ] = 100 * \
data [ ' u2_only_comment_ups ' ] / / len (
u2_comment_ups ) if u2_comment_ups else 0
data [ ' u1_comment_downs_unique ' ] = 100 * \
data [ ' u1_only_comment_downs ' ] / / len (
u1_comment_downs ) if u1_comment_downs else 0
data [ ' u2_comment_downs_unique ' ] = 100 * \
data [ ' u2_only_comment_downs ' ] / / len (
u2_comment_downs ) if u2_comment_downs else 0
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/alt_votes.html " ,
2021-10-15 14:08:27 +00:00
u1 = u1 ,
u2 = u2 ,
v = v ,
data = data
)
@app.post ( " /admin/link_accounts " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_link_accounts ( v ) :
u1 = int ( request . values . get ( " u1 " ) )
u2 = int ( request . values . get ( " u2 " ) )
new_alt = Alt (
user1 = u1 ,
user2 = u2 ,
is_manual = True
)
g . db . add ( new_alt )
g . db . commit ( )
2021-11-06 15:52:48 +00:00
return redirect ( f " /admin/alt_votes?u1= { g . db . query ( User ) . get ( u1 ) . username } &u2= { g . db . query ( User ) . get ( u2 ) . username } " )
2021-10-15 14:08:27 +00:00
2021-12-17 17:55:11 +00:00
@app.get ( " /admin/removed/posts " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_removed ( v ) :
page = int ( request . values . get ( " page " , 1 ) )
2021-11-06 15:52:48 +00:00
ids = g . db . query ( Submission . id ) . join ( User , User . id == Submission . author_id ) . filter ( or_ ( Submission . is_banned == True , User . shadowbanned != None ) ) . order_by ( Submission . id . desc ( ) ) . offset ( 25 * ( page - 1 ) ) . limit ( 26 ) . all ( )
2021-10-15 14:08:27 +00:00
ids = [ x [ 0 ] for x in ids ]
next_exists = len ( ids ) > 25
ids = ids [ : 25 ]
posts = get_posts ( ids , v = v )
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/removed_posts.html " ,
2021-10-15 14:08:27 +00:00
v = v ,
listing = posts ,
page = page ,
next_exists = next_exists
)
2021-12-17 17:55:11 +00:00
@app.get ( " /admin/removed/comments " )
@admin_level_required ( 2 )
def admin_removed_comments ( v ) :
page = int ( request . values . get ( " page " , 1 ) )
ids = g . db . query ( Comment . id ) . join ( User , User . id == Comment . author_id ) . filter ( or_ ( Comment . is_banned == True , User . shadowbanned != None ) ) . order_by ( Comment . id . desc ( ) ) . offset ( 25 * ( page - 1 ) ) . limit ( 26 ) . all ( )
ids = [ x [ 0 ] for x in ids ]
next_exists = len ( ids ) > 25
ids = ids [ : 25 ]
comments = get_comments ( ids , v = v )
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/removed_comments.html " ,
2021-12-17 17:55:11 +00:00
v = v ,
listing = comments ,
page = page ,
next_exists = next_exists
)
2021-10-15 14:08:27 +00:00
@app.post ( " /agendaposter/<user_id> " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def agendaposter ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
2021-12-30 05:27:22 +00:00
if user . username == ' 911roofer ' : abort ( 403 )
2021-10-15 14:08:27 +00:00
expiry = request . values . get ( " days " , 0 )
if expiry :
2021-12-24 01:19:28 +00:00
expiry = float ( expiry )
2021-10-15 14:08:27 +00:00
expiry = g . timestamp + expiry * 60 * 60 * 24
2021-10-21 17:01:25 +00:00
else : expiry = 0
2021-10-15 14:08:27 +00:00
user . agendaposter = not user . agendaposter
user . agendaposter_expires_utc = expiry
g . db . add ( user )
for alt in user . alts :
2022-01-12 01:19:13 +00:00
if alt . admin_level : break
2021-10-15 14:08:27 +00:00
alt . agendaposter = user . agendaposter
alt . agendaposter_expires_utc = expiry
g . db . add ( alt )
note = None
if not user . agendaposter : kind = " unagendaposter "
else :
kind = " agendaposter "
note = f " for { request . values . get ( ' days ' ) } days " if expiry else " never expires "
ma = ModAction (
kind = kind ,
user_id = v . id ,
target_user_id = user . id ,
note = note
)
g . db . add ( ma )
if user . agendaposter :
if not user . has_badge ( 26 ) :
badge = Badge ( user_id = user . id , badge_id = 26 )
g . db . add ( badge )
2021-12-28 13:51:26 +00:00
send_notification ( user . id , f " @AutoJanny has given you the following profile badge: \n \n ![]( { badge . path } ) \n \n { badge . name } " )
2021-10-15 14:08:27 +00:00
else :
badge = user . has_badge ( 26 )
if badge : g . db . delete ( badge )
2021-12-20 20:03:59 +00:00
if user . agendaposter : send_repeatable_notification ( user . id , f " You have been marked by an admin as an agendaposter ( { note } ). " )
2022-01-07 21:03:14 +00:00
else : send_repeatable_notification ( user . id , " You have been unmarked by an admin as an agendaposter. " )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
if user . agendaposter : return redirect ( user . url )
return { " message " : " Agendaposter theme disabled! " }
@app.post ( " /shadowban/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def shadowban ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if user . admin_level != 0 : abort ( 403 )
user . shadowbanned = v . username
g . db . add ( user )
for alt in user . alts :
2022-01-12 01:19:13 +00:00
if alt . admin_level : break
2021-10-15 14:08:27 +00:00
alt . shadowbanned = v . username
g . db . add ( alt )
ma = ModAction (
kind = " shadowban " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
cache . delete_memoized ( frontlist )
g . db . commit ( )
return { " message " : " User shadowbanned! " }
@app.post ( " /unshadowban/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def unshadowban ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if user . admin_level != 0 : abort ( 403 )
user . shadowbanned = None
2022-01-01 22:51:39 +00:00
user . ban_evade = 0
2021-10-15 14:08:27 +00:00
g . db . add ( user )
for alt in user . alts :
alt . shadowbanned = None
2022-01-01 22:51:39 +00:00
alt . ban_evade = 0
2021-10-15 14:08:27 +00:00
g . db . add ( alt )
ma = ModAction (
kind = " unshadowban " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
cache . delete_memoized ( frontlist )
g . db . commit ( )
return { " message " : " User unshadowbanned! " }
@app.post ( " /admin/verify/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def verify ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
user . verified = " Verified "
g . db . add ( user )
2021-10-25 18:08:03 +00:00
ma = ModAction (
kind = " check " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
return { " message " : " User verfied! " }
@app.post ( " /admin/unverify/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def unverify ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
user . verified = None
g . db . add ( user )
2021-10-25 18:08:03 +00:00
ma = ModAction (
kind = " uncheck " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
return { " message " : " User unverified! " }
@app.post ( " /admin/title_change/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_title_change ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
new_name = request . values . get ( " title " ) . strip ( ) [ : 256 ]
user . customtitleplain = new_name
2022-01-13 04:58:06 +00:00
new_name = filter_emojis_only ( new_name )
2021-10-15 14:08:27 +00:00
2022-01-13 04:58:06 +00:00
user = g . db . query ( User ) . filter_by ( id = user . id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
user . customtitle = new_name
2021-12-31 23:45:27 +00:00
if request . values . get ( " locked " ) : user . flairchanged = int ( time . time ( ) ) + 2629746
2021-10-15 14:08:27 +00:00
g . db . add ( user )
if user . flairchanged : kind = " set_flair_locked "
else : kind = " set_flair_notlocked "
ma = ModAction (
kind = kind ,
user_id = v . id ,
target_user_id = user . id ,
2021-12-10 16:31:38 +00:00
_note = f ' " { user . customtitleplain } " '
2021-10-15 14:08:27 +00:00
)
g . db . add ( ma )
g . db . commit ( )
return redirect ( user . url )
@app.post ( " /ban_user/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def ban_user ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
2022-01-13 23:29:15 +00:00
if not user : abort ( 404 )
2021-10-15 14:08:27 +00:00
if user . admin_level > = v . admin_level : abort ( 403 )
2021-12-03 19:20:52 +00:00
days = float ( request . values . get ( " days " ) ) if request . values . get ( ' days ' ) else 0
2021-10-15 14:08:27 +00:00
2022-01-13 23:29:15 +00:00
reason = request . values . get ( " reason " , " " ) . strip ( ) [ : 256 ]
passed_reason = filter_emojis_only ( reason )
if len ( passed_reason ) > 256 : passed_reason = reason
2021-10-15 14:08:27 +00:00
2022-01-13 23:29:15 +00:00
user . ban ( admin = v , reason = passed_reason , days = days )
2021-10-15 14:08:27 +00:00
2021-12-26 12:53:51 +00:00
if request . values . get ( " alts " ) :
2021-10-15 14:08:27 +00:00
for x in user . alts :
2022-01-12 01:19:13 +00:00
if x . admin_level : break
2022-01-13 23:29:15 +00:00
user . ban ( admin = v , reason = passed_reason , days = days )
2021-10-15 14:08:27 +00:00
2022-01-12 01:19:13 +00:00
if days :
2022-01-13 23:29:15 +00:00
if reason : text = f " Your account has been suspended for { days } days for the following reason: \n \n > { reason } "
2021-12-19 23:31:47 +00:00
else : text = f " Your account has been suspended for { days } days. "
else :
2022-01-13 23:29:15 +00:00
if reason : text = f " Your account has been permanently suspended for the following reason: \n \n > { reason } "
2021-12-19 23:31:47 +00:00
else : text = " Your account has been permanently suspended. "
2021-12-20 20:03:59 +00:00
send_repeatable_notification ( user . id , text )
2021-10-15 14:08:27 +00:00
if days == 0 : duration = " permanent "
elif days == 1 : duration = " 1 day "
else : duration = f " { days } days "
ma = ModAction (
kind = " ban_user " ,
user_id = v . id ,
target_user_id = user . id ,
2021-10-25 18:08:03 +00:00
_note = f ' reason: " { reason } " , duration: { duration } '
2021-10-15 14:08:27 +00:00
)
g . db . add ( ma )
if ' reason ' in request . values :
if reason . startswith ( " /post/ " ) :
2021-11-25 20:54:46 +00:00
post = int ( reason . split ( " /post/ " ) [ 1 ] . split ( None , 1 ) [ 0 ] )
post = get_post ( post )
post . bannedfor = True
g . db . add ( post )
2021-11-25 21:33:00 +00:00
elif reason . startswith ( " /comment/ " ) :
2021-11-25 20:54:46 +00:00
comment = int ( reason . split ( " /comment/ " ) [ 1 ] . split ( None , 1 ) [ 0 ] )
comment = get_comment ( comment )
comment . bannedfor = True
g . db . add ( comment )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
if ' redir ' in request . values : return redirect ( user . url )
else : return { " message " : f " @ { user . username } was banned! " }
@app.post ( " /unban_user/<user_id> " )
@limiter.limit ( " 1/second " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def unban_user ( user_id , v ) :
2022-01-02 00:06:46 +00:00
user = g . db . query ( User ) . filter_by ( id = user_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if not user :
abort ( 400 )
user . is_banned = 0
user . unban_utc = 0
2021-10-21 18:06:57 +00:00
user . ban_evade = 0
2021-12-20 21:04:15 +00:00
user . ban_reason = None
2021-10-15 14:08:27 +00:00
g . db . add ( user )
2021-12-29 13:07:51 +00:00
for x in user . alts :
x . is_banned = 0
x . unban_utc = 0
x . ban_evade = 0
2021-12-29 13:23:21 +00:00
x . ban_reason = None
2021-12-29 13:07:51 +00:00
g . db . add ( x )
2021-10-15 14:08:27 +00:00
2021-12-20 20:03:59 +00:00
send_repeatable_notification ( user . id ,
2021-10-15 14:08:27 +00:00
" Your account has been reinstated. Please carefully review and abide by the [rules](/post/2510) to ensure that you don ' t get suspended again. " )
ma = ModAction (
kind = " unban_user " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
g . db . commit ( )
if " @ " in request . referrer : return redirect ( user . url )
else : return { " message " : f " @ { user . username } was unbanned! " }
@app.post ( " /ban_post/<post_id> " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def ban_post ( post_id , v ) :
2022-01-02 00:06:46 +00:00
post = g . db . query ( Submission ) . filter_by ( id = post_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if not post :
abort ( 400 )
post . is_banned = True
post . is_approved = 0
post . stickied = None
post . is_pinned = False
2021-10-29 02:32:23 +00:00
post . ban_reason = v . username
2021-10-15 14:08:27 +00:00
g . db . add ( post )
ma = ModAction (
kind = " ban_post " ,
user_id = v . id ,
target_submission_id = post . id ,
)
g . db . add ( ma )
cache . delete_memoized ( frontlist )
2021-12-27 01:08:06 +00:00
v . coins + = 1
2021-10-15 14:08:27 +00:00
g . db . add ( v )
g . db . commit ( )
return { " message " : " Post removed! " }
@app.post ( " /unban_post/<post_id> " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def unban_post ( post_id , v ) :
2022-01-02 00:06:46 +00:00
post = g . db . query ( Submission ) . filter_by ( id = post_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if not post :
abort ( 400 )
if post . is_banned :
ma = ModAction (
kind = " unban_post " ,
user_id = v . id ,
target_submission_id = post . id ,
)
g . db . add ( ma )
post . is_banned = False
post . is_approved = v . id
g . db . add ( post )
cache . delete_memoized ( frontlist )
2021-12-27 01:08:06 +00:00
v . coins - = 1
2021-10-15 14:08:27 +00:00
g . db . add ( v )
g . db . commit ( )
return { " message " : " Post approved! " }
@app.post ( " /distinguish/<post_id> " )
@admin_level_required ( 1 )
def api_distinguish_post ( post_id , v ) :
2022-01-02 00:06:46 +00:00
post = g . db . query ( Submission ) . filter_by ( id = post_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if not post :
abort ( 404 )
if not post . author_id == v . id :
abort ( 403 )
if post . distinguish_level :
post . distinguish_level = 0
else :
post . distinguish_level = v . admin_level
g . db . add ( post )
g . db . commit ( )
2021-12-31 16:26:27 +00:00
if post . distinguish_level : return { " message " : " Post distinguished! " }
else : return { " message " : " Post undistinguished! " }
2021-10-15 14:08:27 +00:00
@app.post ( " /sticky/<post_id> " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-12-26 01:03:21 +00:00
def sticky_post ( post_id , v ) :
post = g . db . query ( Submission ) . filter_by ( id = post_id ) . one_or_none ( )
if post and not post . stickied :
pins = g . db . query ( Submission . id ) . filter ( Submission . stickied != None , Submission . is_banned == False ) . count ( )
if pins > 2 :
if v . admin_level > 2 :
post . stickied = v . username
post . stickied_utc = int ( time . time ( ) ) + 3600
else : return { " error " : " Can ' t exceed 3 pinned posts limit! " } , 403
else : post . stickied = v . username
g . db . add ( post )
2021-10-15 14:08:27 +00:00
2021-12-26 01:03:21 +00:00
if v . id != post . author_id :
send_repeatable_notification ( post . author_id , f " @ { v . username } has pinned your [post](/post/ { post_id } )! " )
cache . delete_memoized ( frontlist )
g . db . commit ( )
return { " message " : " Post pinned! " }
@app.post ( " /unsticky/<post_id> " )
@admin_level_required ( 2 )
def unsticky_post ( post_id , v ) :
post = g . db . query ( Submission ) . filter_by ( id = post_id ) . one_or_none ( )
if post and post . stickied :
if post . stickied . endswith ( ' (pin award) ' ) : return { " error " : " Can ' t unpin award pins! " } , 403
post . stickied = None
post . stickied_utc = None
2021-10-15 14:08:27 +00:00
g . db . add ( post )
ma = ModAction (
2021-12-26 01:03:21 +00:00
kind = " unpin_post " ,
2021-10-15 14:08:27 +00:00
user_id = v . id ,
target_submission_id = post . id
)
g . db . add ( ma )
2021-12-26 01:03:21 +00:00
if v . id != post . author_id :
send_repeatable_notification ( post . author_id , f " @ { v . username } has unpinned your [post](/post/ { post_id } )! " )
2021-10-15 14:08:27 +00:00
cache . delete_memoized ( frontlist )
2021-12-26 01:03:21 +00:00
g . db . commit ( )
return { " message " : " Post unpinned! " }
@app.post ( " /sticky_comment/<cid> " )
@admin_level_required ( 2 )
def sticky_comment ( cid , v ) :
comment = get_comment ( cid , v = v )
comment . is_pinned = v . username
g . db . add ( comment )
if v . id != comment . author_id :
message = f " @ { v . username } has pinned your [comment]( { comment . permalink } )! "
send_repeatable_notification ( comment . author_id , message )
g . db . commit ( )
return { " message " : " Comment pinned! " }
@app.post ( " /unsticky_comment/<cid> " )
@admin_level_required ( 2 )
def unsticky_comment ( cid , v ) :
comment = get_comment ( cid , v = v )
if comment . is_pinned . endswith ( " (pin award) " ) : return { " error " : " Can ' t unpin award pins! " } , 403
2021-12-30 15:03:28 +00:00
comment . is_pinned = None
2021-12-26 01:03:21 +00:00
g . db . add ( comment )
ma = ModAction (
kind = " unpin_comment " ,
user_id = v . id ,
target_comment_id = comment . id
)
g . db . add ( ma )
if v . id != comment . author_id :
message = f " @ { v . username } has unpinned your [comment]( { comment . permalink } )! "
send_repeatable_notification ( comment . author_id , message )
g . db . commit ( )
return { " message " : " Comment unpinned! " }
2021-10-15 14:08:27 +00:00
@app.post ( " /ban_comment/<c_id> " )
@limiter.limit ( " 1/second " )
2021-12-13 01:23:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def api_ban_comment ( c_id , v ) :
2022-01-02 00:06:46 +00:00
comment = g . db . query ( Comment ) . filter_by ( id = c_id ) . one_or_none ( )
2021-10-15 14:08:27 +00:00
if not comment :
abort ( 404 )
comment . is_banned = True
comment . is_approved = 0
2021-10-29 02:32:23 +00:00
comment . ban_reason = v . username
2021-10-15 14:08:27 +00:00
g . db . add ( comment )
ma = ModAction (
kind = " ban_comment " ,
user_id = v . id ,
target_comment_id = comment . id ,
)
g . db . add ( ma )
g . db . commit ( )
return { " message " : " Comment removed! " }
@app.post ( " /unban_comment/<c_id> " )
@limiter.limit ( " 1/second " )
2021-12-13 01:23:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def api_unban_comment ( c_id , v ) :
2022-01-02 00:06:46 +00:00
comment = g . db . query ( Comment ) . filter_by ( id = c_id ) . one_or_none ( )
2021-12-01 15:37:36 +00:00
if not comment : abort ( 404 )
2022-01-02 00:05:22 +00:00
if comment . author . agendaposter and ' trans lives matters ' not in comment . body . lower ( ) :
return { " error " : " You can ' t bypass the agendaposter award! " }
2021-10-15 14:08:27 +00:00
if comment . is_banned :
ma = ModAction (
kind = " unban_comment " ,
user_id = v . id ,
target_comment_id = comment . id ,
)
g . db . add ( ma )
comment . is_banned = False
comment . is_approved = v . id
2022-01-02 00:05:22 +00:00
g . db . add ( comment )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
return { " message " : " Comment approved! " }
@app.post ( " /distinguish_comment/<c_id> " )
2021-12-01 15:37:36 +00:00
@admin_level_required ( 1 )
2021-10-15 14:08:27 +00:00
def admin_distinguish_comment ( c_id , v ) :
comment = get_comment ( c_id , v = v )
2021-12-01 15:37:36 +00:00
if comment . author_id != v . id : abort ( 403 )
2021-10-15 14:08:27 +00:00
comment . distinguish_level = 0 if comment . distinguish_level else v . admin_level
g . db . add ( comment )
g . db . commit ( )
2021-12-31 16:26:27 +00:00
if comment . distinguish_level : return { " message " : " Comment distinguished! " }
else : return { " message " : " Comment undistinguished! " }
2021-10-15 14:08:27 +00:00
@app.get ( " /admin/dump_cache " )
2021-11-15 22:13:29 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_dump_cache ( v ) :
cache . clear ( )
return { " message " : " Internal cache cleared. " }
@app.get ( " /admin/banned_domains/ " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_banned_domains ( v ) :
2021-11-06 15:52:48 +00:00
banned_domains = g . db . query ( BannedDomain ) . all ( )
2021-12-20 00:27:25 +00:00
if not v or v . oldsite : template = ' '
2021-12-19 13:01:28 +00:00
else : template = ' CHRISTMAS/ '
return render_template ( f " { template } admin/banned_domains.html " , v = v , banned_domains = banned_domains )
2021-10-15 14:08:27 +00:00
@app.post ( " /admin/banned_domains " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_toggle_ban_domain ( v ) :
domain = request . values . get ( " domain " , " " ) . strip ( )
if not domain : abort ( 400 )
reason = request . values . get ( " reason " , " " ) . strip ( )
2022-01-02 00:06:46 +00:00
d = g . db . query ( BannedDomain ) . filter_by ( domain = domain ) . one_or_none ( )
2021-10-25 18:08:03 +00:00
if d :
g . db . delete ( d )
ma = ModAction (
kind = " unban_domain " ,
user_id = v . id ,
_note = domain
)
g . db . add ( ma )
2021-10-15 14:08:27 +00:00
else :
d = BannedDomain ( domain = domain , reason = reason )
g . db . add ( d )
2021-10-25 18:08:03 +00:00
ma = ModAction (
kind = " ban_domain " ,
user_id = v . id ,
_note = f ' { domain } , reason: { reason } '
)
g . db . add ( ma )
2021-10-15 14:08:27 +00:00
g . db . commit ( )
return redirect ( " /admin/banned_domains/ " )
@app.post ( " /admin/nuke_user " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_nuke_user ( v ) :
user = get_user ( request . values . get ( " user " ) )
2021-11-06 15:52:48 +00:00
for post in g . db . query ( Submission ) . filter_by ( author_id = user . id ) . all ( ) :
2021-10-15 14:08:27 +00:00
if post . is_banned :
continue
post . is_banned = True
g . db . add ( post )
2021-11-06 15:52:48 +00:00
for comment in g . db . query ( Comment ) . filter_by ( author_id = user . id ) . all ( ) :
2021-10-15 14:08:27 +00:00
if comment . is_banned :
continue
comment . is_banned = True
g . db . add ( comment )
ma = ModAction (
kind = " nuke_user " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
g . db . commit ( )
return redirect ( user . url )
@app.post ( " /admin/unnuke_user " )
@limiter.limit ( " 1/second " )
2021-11-16 04:18:36 +00:00
@admin_level_required ( 2 )
2021-10-15 14:08:27 +00:00
def admin_nunuke_user ( v ) :
user = get_user ( request . values . get ( " user " ) )
2021-11-06 15:52:48 +00:00
for post in g . db . query ( Submission ) . filter_by ( author_id = user . id ) . all ( ) :
2021-10-15 14:08:27 +00:00
if not post . is_banned :
continue
post . is_banned = False
g . db . add ( post )
2021-11-06 15:52:48 +00:00
for comment in g . db . query ( Comment ) . filter_by ( author_id = user . id ) . all ( ) :
2021-10-15 14:08:27 +00:00
if not comment . is_banned :
continue
comment . is_banned = False
g . db . add ( comment )
ma = ModAction (
kind = " unnuke_user " ,
user_id = v . id ,
target_user_id = user . id ,
)
g . db . add ( ma )
g . db . commit ( )
2021-09-24 18:37:44 +00:00
return redirect ( user . url )