diff --git a/app/admin/routes.py b/app/admin/routes.py index e4978f38..f458464e 100644 --- a/app/admin/routes.py +++ b/app/admin/routes.py @@ -1192,92 +1192,69 @@ def admin_users(): ) -@bp.route('/content/trash', methods=['GET']) +@bp.route('/content', methods=['GET']) @login_required @permission_required('administer all users') -def admin_content_trash(): - - page = request.args.get('page', 1, type=int) - - posts = Post.query.filter(Post.posted_at > utcnow() - timedelta(days=3), Post.deleted == False, Post.down_votes > 0).order_by(Post.score) - posts = posts.paginate(page=page, per_page=100, error_out=False) - - next_url = url_for('admin.admin_content_trash', page=posts.next_num) if posts.has_next else None - prev_url = url_for('admin.admin_content_trash', page=posts.prev_num) if posts.has_prev and page != 1 else None - - return render_template('admin/posts.html', title=_('Bad posts'), next_url=next_url, prev_url=prev_url, posts=posts, - moderating_communities=moderating_communities(current_user.get_id()), - joined_communities=joined_communities(current_user.get_id()), - menu_topics=menu_topics(), - site=g.site - ) - - -@bp.route('/content/spam', methods=['GET']) -@login_required -@permission_required('administer all users') -def admin_content_spam(): - # Essentially the same as admin_content_trash() except only shows heavily downvoted posts by new users - who are usually spammers +def admin_content(): page = request.args.get('page', 1, type=int) replies_page = request.args.get('replies_page', 1, type=int) + posts_replies = request.args.get('posts_replies', '') + show = request.args.get('show', 'trash') + days = request.args.get('days', 3, type=int) + + posts = Post.query.join(User, User.id == Post.user_id).filter(Post.deleted == False) + post_replies = PostReply.query.join(User, User.id == PostReply.user_id).filter(PostReply.deleted == False) + if show == 'trash': + title = _('Bad / Most downvoted') + posts = posts.filter(Post.down_votes > 1, Post.score < 10) + if days > 0: + posts = posts.filter(Post.posted_at > utcnow() - timedelta(days=days)) + posts = posts.order_by(Post.score) + post_replies = post_replies.filter(PostReply.down_votes > 1, PostReply.score < 10) + if days > 0: + post_replies = post_replies.filter(PostReply.posted_at > utcnow() - timedelta(days=days)) + post_replies = post_replies.order_by(PostReply.score) + elif show == 'spammy': + title = _('Likely spam') + posts = posts.filter(Post.score <= 0) + if days > 0: + posts = posts.filter(Post.posted_at > utcnow() - timedelta(days=days), + User.created > utcnow() - timedelta(days=days)) + posts = posts.order_by(Post.score) + post_replies = post_replies.filter(PostReply.score <= 0) + if days > 0: + post_replies = post_replies.filter(PostReply.posted_at > utcnow() - timedelta(days=days), + User.created > utcnow() - timedelta(days=days)) + post_replies = post_replies.order_by(PostReply.score) + elif show == 'deleted': + title = _('Deleted content') + posts = Post.query.filter(Post.deleted == True) + if days > 0: + posts = posts.filter(Post.posted_at > utcnow() - timedelta(days=days)) + posts = posts.order_by(desc(Post.posted_at)) + post_replies = PostReply.query.filter(PostReply.deleted == True) + if days > 0: + post_replies = post_replies.filter(PostReply.posted_at > utcnow() - timedelta(days=days)) + post_replies = post_replies.order_by(desc(PostReply.posted_at)) + + if posts_replies == 'posts': + post_replies = post_replies.filter(False) + elif posts_replies == 'replies': + posts = posts.filter(False) - posts = Post.query.join(User, User.id == Post.user_id).\ - filter(User.created > utcnow() - timedelta(days=3)).\ - filter(Post.posted_at > utcnow() - timedelta(days=3)).\ - filter(Post.deleted == False).\ - filter(Post.score <= 0).order_by(Post.score) posts = posts.paginate(page=page, per_page=100, error_out=False) - - post_replies = PostReply.query.join(User, User.id == PostReply.user_id). \ - filter(User.created > utcnow() - timedelta(days=3)). \ - filter(PostReply.posted_at > utcnow() - timedelta(days=3)). \ - filter(PostReply.deleted == False). \ - filter(PostReply.score <= 0).order_by(PostReply.score) post_replies = post_replies.paginate(page=replies_page, per_page=100, error_out=False) - next_url = url_for('admin.admin_content_spam', page=posts.next_num) if posts.has_next else None - prev_url = url_for('admin.admin_content_spam', page=posts.prev_num) if posts.has_prev and page != 1 else None - next_url_replies = url_for('admin.admin_content_spam', replies_page=post_replies.next_num) if post_replies.has_next else None - prev_url_replies = url_for('admin.admin_content_spam', replies_page=post_replies.prev_num) if post_replies.has_prev and replies_page != 1 else None + next_url = url_for('admin.admin_content', page=posts.next_num, replies_page=replies_page, posts_replies=posts_replies, show=show, days=days) if posts.has_next else None + prev_url = url_for('admin.admin_content', page=posts.prev_num, replies_page=replies_page, posts_replies=posts_replies, show=show, days=days) if posts.has_prev and page != 1 else None + next_url_replies = url_for('admin.admin_content', replies_page=post_replies.next_num, page=page, posts_replies=posts_replies, show=show, days=days) if post_replies.has_next else None + prev_url_replies = url_for('admin.admin_content', replies_page=post_replies.prev_num, page=page, posts_replies=posts_replies, show=show, days=days) if post_replies.has_prev and replies_page != 1 else None - return render_template('admin/spam_posts.html', title=_('Likely spam'), - next_url=next_url, prev_url=prev_url, - next_url_replies=next_url_replies, prev_url_replies=prev_url_replies, - posts=posts, post_replies=post_replies, - moderating_communities=moderating_communities(current_user.get_id()), - joined_communities=joined_communities(current_user.get_id()), - menu_topics=menu_topics(), - site=g.site - ) - - -@bp.route('/content/deleted', methods=['GET']) -@login_required -@permission_required('administer all users') -def admin_content_deleted(): - # Shows all soft deleted posts - page = request.args.get('page', 1, type=int) - replies_page = request.args.get('replies_page', 1, type=int) - - posts = Post.query.\ - filter(Post.deleted == True).\ - order_by(desc(Post.posted_at)) - posts = posts.paginate(page=page, per_page=100, error_out=False) - - post_replies = PostReply.query. \ - filter(PostReply.deleted == True). \ - order_by(desc(PostReply.posted_at)) - post_replies = post_replies.paginate(page=replies_page, per_page=100, error_out=False) - - next_url = url_for('admin.admin_content_deleted', page=posts.next_num) if posts.has_next else None - prev_url = url_for('admin.admin_content_deleted', page=posts.prev_num) if posts.has_prev and page != 1 else None - next_url_replies = url_for('admin.admin_content_deleted', replies_page=post_replies.next_num) if post_replies.has_next else None - prev_url_replies = url_for('admin.admin_content_deleted', replies_page=post_replies.prev_num) if post_replies.has_prev and replies_page != 1 else None - - return render_template('admin/deleted_posts.html', title=_('Deleted content'), + return render_template('admin/content.html', title=title, next_url=next_url, prev_url=prev_url, next_url_replies=next_url_replies, prev_url_replies=prev_url_replies, posts=posts, post_replies=post_replies, + posts_replies=posts_replies, show=show, days=days, moderating_communities=moderating_communities(current_user.get_id()), joined_communities=joined_communities(current_user.get_id()), menu_topics=menu_topics(), diff --git a/app/templates/admin/_nav.html b/app/templates/admin/_nav.html index addf534b..c9bf00b7 100644 --- a/app/templates/admin/_nav.html +++ b/app/templates/admin/_nav.html @@ -6,6 +6,7 @@ {{ _('Communities') }} | {{ _('Topics') }} | {{ _('Users') }} | + {{ _('Content') }} | {% if site.registration_mode == 'RequireApplication' %} {{ _('Registration applications') }} | {% endif %} @@ -13,7 +14,7 @@ {{ _('Federation') }} | {{ _('Newsletter') }} | {{ _('Permissions') }} | - {{ _('Activities') }} + {{ _('Activities') }} | {{ _('Modlog') }} {% if debug_mode %} | {{ _('Dev Tools') }} diff --git a/app/templates/admin/content.html b/app/templates/admin/content.html new file mode 100644 index 00000000..97205579 --- /dev/null +++ b/app/templates/admin/content.html @@ -0,0 +1,94 @@ +{% if theme() and file_exists('app/templates/themes/' + theme() + '/base.html') %} + {% extends 'themes/' + theme() + '/base.html' %} +{% else %} + {% extends "base.html" %} +{% endif %} +{% from 'bootstrap/form.html' import render_form %} +{% set active_child = 'admin_content' %} + +{% block app_content %} +
+
+

{{ _('Content') }}

+
+
+ + + +
+
+
+ + + + +
+
+

{{ title }}

+ {% if posts_replies != 'replies' %} + {% if post_replies %}

Posts

{% endif %} +
+ {% for post in posts.items %} + {% with disable_voting=True %} + {% include 'post/_post_teaser.html' %} + {% endwith %} + {% else %} +

{{ _('No posts.') }}

+ {% endfor %} +
+ + {% endif %} + {% if posts_replies != 'posts' %} + {% if posts %}

Comments

{% endif %} +
+ {% for post_reply in post_replies.items %} + {% with teaser=True, disable_voting=True, no_collapse=True, show_deleted=True %} + {% include 'post/_post_reply_teaser.html' %} + {% endwith %} +
+ {% else %} +

{{ _('No comments.') }}

+ {% endfor %} +
+ + {% endif %} +
+
+
+
+
+ {% include 'admin/_nav.html' %} +
+
+
+{% endblock %} diff --git a/app/templates/admin/deleted_posts.html b/app/templates/admin/deleted_posts.html deleted file mode 100644 index 218dead8..00000000 --- a/app/templates/admin/deleted_posts.html +++ /dev/null @@ -1,68 +0,0 @@ -{% if theme() and file_exists('app/templates/themes/' + theme() + '/base.html') %} - {% extends 'themes/' + theme() + '/base.html' %} -{% else %} - {% extends "base.html" %} -{% endif %} -{% from 'bootstrap/form.html' import render_form %} -{% set active_child = 'admin_content_deleted' %} - -{% block app_content %} -
-
-

{{ _('Deleted posts') }}

-
- {% for post in posts.items %} - {% include 'post/_post_teaser.html' %} - {% else %} -

{{ _('No deleted posts.') }}

- {% endfor %} -
- - {% if post_replies %} -

Deleted comments

-
- {% for post_reply in post_replies.items %} - {% with teaser=True, disable_voting=True, no_collapse=True, show_deleted=True %} - {% include 'post/_post_reply_teaser.html' %} - {% endwith %} -
- {% else %} -

{{ _('No deleted comments.') }}

- {% endfor %} -
- - {% else %} -

{{ _('No comments yet.') }}

- {% endif %} -
-
-
-
-
- {% include 'admin/_nav.html' %} -
-
-
-{% endblock %} diff --git a/app/templates/admin/posts.html b/app/templates/admin/posts.html deleted file mode 100644 index 69d8aa8d..00000000 --- a/app/templates/admin/posts.html +++ /dev/null @@ -1,39 +0,0 @@ -{% if theme() and file_exists('app/templates/themes/' + theme() + '/base.html') %} - {% extends 'themes/' + theme() + '/base.html' %} -{% else %} - {% extends "base.html" %} -{% endif %} -{% from 'bootstrap/form.html' import render_form %} -{% set active_child = 'admin_content_trash' %} - -{% block app_content %} -
-
-

{{ _('Most downvoted posts in the last 3 days') }}

-
- {% for post in posts.items %} - {% include 'post/_post_teaser.html' %} - {% endfor %} -
- -
-
-
-
-
- {% include 'admin/_nav.html' %} -
-
-
-{% endblock %} \ No newline at end of file diff --git a/app/templates/admin/spam_posts.html b/app/templates/admin/spam_posts.html deleted file mode 100644 index c7222352..00000000 --- a/app/templates/admin/spam_posts.html +++ /dev/null @@ -1,40 +0,0 @@ -{% if theme() and file_exists('app/templates/themes/' + theme() + '/base.html') %} - {% extends 'themes/' + theme() + '/base.html' %} -{% else %} - {% extends "base.html" %} -{% endif %} -{% from 'bootstrap/form.html' import render_form %} -{% set active_child = 'admin_content_spam' %} - -{% block app_content %} -
-
-

{{ _('Most downvoted posts in the last 3 days') }}

-
- {% for post in posts.items %} - {% include 'post/_post_teaser.html' %} - {% endfor %} -
- {% if post_replies %} -

Downvoted comments

-
- {% for post_reply in post_replies.items %} - {% with teaser=True, disable_voting=True, no_collapse=True, show_deleted=True %} - {% include 'post/_post_reply_teaser.html' %} - {% endwith %} -
- {% endfor %} -
- {% else %} -

{{ _('No comments yet.') }}

- {% endif %} -
-
-
-
-
- {% include 'admin/_nav.html' %} -
-
-
-{% endblock %} diff --git a/app/templates/admin/users.html b/app/templates/admin/users.html index 89acc5fa..af7d5223 100644 --- a/app/templates/admin/users.html +++ b/app/templates/admin/users.html @@ -32,7 +32,7 @@ - + diff --git a/app/templates/base.html b/app/templates/base.html index a63781d4..fa066b25 100644 --- a/app/templates/base.html +++ b/app/templates/base.html @@ -229,9 +229,7 @@
  • {{ _('Communities') }}
  • {{ _('Topics') }}
  • {{ _('Users') }}
  • -
  • {{ _('Monitoring - content') }}
  • -
  • {{ _('Monitoring - spammy content') }}
  • -
  • {{ _('Deleted content') }}
  • +
  • {{ _('Content') }}
  • {% if g.site.registration_mode == 'RequireApplication' %}
  • {{ _('Registration applications') }}
  • {% endif %}