rDrama/files/routes/reporting.py

90 lines
2.5 KiB
Python
Raw Normal View History

2021-08-04 15:35:10 +00:00
from files.helpers.wrappers import *
from files.helpers.get import *
2021-07-21 01:12:26 +00:00
from flask import g
2021-10-07 06:04:29 +00:00
from files.__main__ import app, limiter
2021-10-01 20:06:56 +00:00
from os import path
2021-07-21 01:12:26 +00:00
2021-07-31 04:48:47 +00:00
@app.post("/flag/post/<pid>")
2021-10-08 01:41:25 +00:00
@limiter.limit("1/second")
2021-07-21 01:12:26 +00:00
@auth_desired
def api_flag_post(pid, v):
post = get_post(pid)
2021-10-05 19:15:48 +00:00
if v and not v.shadowbanned:
2021-09-17 08:29:05 +00:00
existing = g.db.query(Flag).options(lazyload('*')).filter_by(user_id=v.id, post_id=post.id).first()
2021-07-21 01:12:26 +00:00
2021-08-02 14:39:59 +00:00
if existing: return "", 409
2021-08-15 03:17:45 +00:00
2021-09-19 13:11:34 +00:00
reason = request.values.get("reason", "").strip()[:100]
2021-08-19 16:10:44 +00:00
if "<" in reason: return {"error": f"Reasons can't contain <"}
2021-08-15 03:17:45 +00:00
for i in re.finditer(':(.{1,30}?):', reason):
2021-09-29 15:42:28 +00:00
if path.isfile(f'./files/assets/images/emojis/{i.group(1)}.webp'):
reason = reason.replace(f':{i.group(1)}:', f'<img loading="lazy" data-bs-toggle="tooltip" title="{i.group(1)}" delay="0" height=20 src="https://{site}/assets/images/emojis/{i.group(1)}.webp">')
2021-08-02 14:39:59 +00:00
2021-07-21 01:12:26 +00:00
flag = Flag(post_id=post.id,
user_id=v.id,
2021-07-24 18:15:26 +00:00
reason=reason,
2021-07-21 01:12:26 +00:00
)
g.db.add(flag)
2021-09-16 17:15:07 +00:00
g.db.commit()
2021-09-16 17:02:58 +00:00
2021-09-12 06:41:19 +00:00
return {"message": "Post reported!"}
2021-07-21 01:12:26 +00:00
2021-07-31 04:48:47 +00:00
@app.post("/flag/comment/<cid>")
2021-10-08 01:41:25 +00:00
@limiter.limit("1/second")
2021-07-21 01:12:26 +00:00
@auth_desired
def api_flag_comment(cid, v):
comment = get_comment(cid)
2021-10-05 19:15:48 +00:00
if v and not v.shadowbanned:
2021-09-17 08:29:05 +00:00
existing = g.db.query(CommentFlag).options(lazyload('*')).filter_by(
2021-08-01 04:25:26 +00:00
user_id=v.id, comment_id=comment.id).first()
2021-07-21 01:12:26 +00:00
2021-08-02 14:39:59 +00:00
if existing: return "", 409
2021-09-19 13:11:34 +00:00
reason = request.values.get("reason", "").strip()[:100]
2021-08-19 16:10:44 +00:00
if "<" in reason: return {"error": f"Reasons can't contain <"}
2021-08-15 03:17:45 +00:00
for i in re.finditer(':(.{1,30}?):', reason):
2021-09-29 15:42:28 +00:00
if path.isfile(f'./files/assets/images/emojis/{i.group(1)}.webp'):
reason = reason.replace(f':{i.group(1)}:', f'<img loading="lazy" data-bs-toggle="tooltip" title="{i.group(1)}" delay="0" height=20 src="https://{site}/assets/images/emojis/{i.group(1)}.webp">')
2021-07-21 01:12:26 +00:00
2021-08-15 22:37:35 +00:00
flag = CommentFlag(comment_id=comment.id,
2021-08-15 22:35:54 +00:00
user_id=v.id,
reason=reason,
)
2021-07-21 01:12:26 +00:00
g.db.add(flag)
2021-09-16 17:15:07 +00:00
g.db.commit()
2021-09-16 17:02:58 +00:00
2021-09-12 06:41:19 +00:00
return {"message": "Comment reported!"}
2021-08-25 12:15:53 +00:00
2021-08-25 12:22:20 +00:00
@app.post('/del_report/<report_fn>')
2021-10-08 01:41:25 +00:00
@limiter.limit("1/second")
2021-08-25 12:15:53 +00:00
@auth_required
@validate_formkey
def remove_report(report_fn, v):
if v.admin_level < 6:
return {"error": "go outside"}, 403
if report_fn.startswith('c'):
2021-09-17 08:29:05 +00:00
report = g.db.query(CommentFlag).options(lazyload('*')).filter_by(id=int(report_fn.lstrip('c'))).first()
2021-08-25 12:15:53 +00:00
elif report_fn.startswith('p'):
2021-09-17 08:29:05 +00:00
report = g.db.query(Flag).options(lazyload('*')).filter_by(id=int(report_fn.lstrip('p'))).first()
2021-08-25 12:15:53 +00:00
else:
return {"error": "Invalid report ID"}, 400
g.db.delete(report)
2021-09-16 17:02:58 +00:00
g.db.commit()
2021-09-03 13:52:37 +00:00
return {"message": "Removed report"}