pyfedi/app/domain/routes.py

161 lines
7.2 KiB
Python
Raw Permalink Normal View History

2024-02-01 20:10:48 -08:00
from random import randint
from flask import redirect, url_for, flash, request, make_response, session, Markup, current_app, abort, g
2023-11-29 01:12:55 -08:00
from flask_login import login_user, logout_user, current_user, login_required
from flask_babel import _
2024-02-01 20:22:32 -08:00
from app import db, constants, cache
2024-02-01 20:10:48 -08:00
from app.inoculation import inoculation
2024-09-29 17:49:06 -07:00
from app.models import Post, Domain, Community, DomainBlock, read_posts
2023-11-29 01:12:55 -08:00
from app.domain import bp
from app.utils import render_template, permission_required, joined_communities, moderating_communities, \
user_filters_posts, blocked_domains, blocked_instances, menu_topics
2024-03-12 00:06:24 -07:00
from sqlalchemy import desc, or_
2023-11-29 01:12:55 -08:00
@bp.route('/d/<domain_id>', methods=['GET'])
def show_domain(domain_id):
2024-02-01 19:52:23 -08:00
page = request.args.get('page', 1, type=int)
2023-11-29 01:12:55 -08:00
if '.' in domain_id:
domain = Domain.query.filter_by(name=domain_id, banned=False).first()
else:
domain = Domain.query.get_or_404(domain_id)
if domain.banned:
domain = None
if domain:
if current_user.is_anonymous or current_user.ignore_bots == 1:
2023-12-31 14:38:24 -08:00
posts = Post.query.join(Community, Community.id == Post.community_id).\
filter(Post.from_bot == False, Post.domain_id == domain.id, Community.banned == False, Post.deleted == False).\
2024-02-22 23:23:59 -08:00
order_by(desc(Post.posted_at))
2023-11-29 01:12:55 -08:00
else:
posts = Post.query.join(Community).filter(Post.domain_id == domain.id, Community.banned == False, Post.deleted == False).order_by(desc(Post.posted_at))
2024-02-01 20:10:48 -08:00
if current_user.is_authenticated:
2024-03-12 15:17:04 -07:00
instance_ids = blocked_instances(current_user.id)
if instance_ids:
posts = posts.filter(or_(Post.instance_id.not_in(instance_ids), Post.instance_id == None))
2024-02-01 20:10:48 -08:00
content_filters = user_filters_posts(current_user.id)
else:
content_filters = {}
# don't show posts a user has already interacted with
2024-09-29 19:52:13 -07:00
if current_user.is_authenticated and current_user.hide_read_posts:
2024-09-29 17:49:06 -07:00
posts = posts.outerjoin(read_posts, (Post.id == read_posts.c.read_post_id) & (read_posts.c.user_id == current_user.id))
posts = posts.filter(read_posts.c.read_post_id.is_(None)) # Filter where there is no corresponding read post for the current user
2024-02-01 19:52:23 -08:00
# pagination
posts = posts.paginate(page=page, per_page=100, error_out=False)
2024-02-01 20:00:12 -08:00
next_url = url_for('domain.show_domain', domain_id=domain_id, page=posts.next_num) if posts.has_next else None
prev_url = url_for('domain.show_domain', domain_id=domain_id, page=posts.prev_num) if posts.has_prev and page != 1 else None
2023-11-29 01:12:55 -08:00
return render_template('domain/domain.html', domain=domain, title=domain.name, posts=posts,
2024-02-01 19:52:23 -08:00
POST_TYPE_IMAGE=constants.POST_TYPE_IMAGE, POST_TYPE_LINK=constants.POST_TYPE_LINK,
2024-04-16 01:59:58 -07:00
POST_TYPE_VIDEO=constants.POST_TYPE_VIDEO,
2024-02-01 20:10:48 -08:00
next_url=next_url, prev_url=prev_url,
content_filters=content_filters,
moderating_communities=moderating_communities(current_user.get_id()),
joined_communities=joined_communities(current_user.get_id()),
menu_topics=menu_topics(), site=g.site,
inoculation=inoculation[randint(0, len(inoculation) - 1)] if g.site.show_inoculation_block else None
2024-02-01 20:10:48 -08:00
)
2023-11-29 01:12:55 -08:00
else:
abort(404)
@bp.route('/domains', methods=['GET'])
def domains():
2024-02-01 19:52:23 -08:00
page = request.args.get('page', 1, type=int)
search = request.args.get('search', '')
2024-03-10 12:17:16 -07:00
domains = Domain.query.filter_by(banned=False)
2024-02-01 19:52:23 -08:00
if search != '':
domains = domains.filter(Domain.name.ilike(f'%{search}%'))
domains = domains.order_by(Domain.name)
domains = domains.paginate(page=page, per_page=100, error_out=False)
2024-03-10 12:17:16 -07:00
ban_visibility_permission = False
if not current_user.is_anonymous:
if not current_user.created_recently() and current_user.reputation > 100 or current_user.is_admin():
ban_visibility_permission = True
2024-02-01 19:58:30 -08:00
next_url = url_for('domain.domains', page=domains.next_num) if domains.has_next else None
prev_url = url_for('domain.domains', page=domains.prev_num) if domains.has_prev and page != 1 else None
2024-02-01 19:52:23 -08:00
return render_template('domain/domains.html', title='All known domains', domains=domains,
2024-03-10 12:17:16 -07:00
next_url=next_url, prev_url=prev_url, search=search, ban_visibility_permission=ban_visibility_permission)
2024-03-10 12:17:16 -07:00
@bp.route('/domains/banned', methods=['GET'])
@login_required
def domains_blocked_list():
if not current_user.trustworthy():
abort(404)
2024-03-10 12:17:16 -07:00
page = request.args.get('page', 1, type=int)
search = request.args.get('search', '')
domains = Domain.query.filter_by(banned=True)
if search != '':
domains = domains.filter(Domain.name.ilike(f'%{search}%'))
domains = domains.order_by(Domain.name)
domains = domains.paginate(page=page, per_page=100, error_out=False)
next_url = url_for('domain.domains', page=domains.next_num) if domains.has_next else None
prev_url = url_for('domain.domains', page=domains.prev_num) if domains.has_prev and page != 1 else None
return render_template('domain/domains_blocked.html', title='Domains blocked on this instance', domains=domains,
next_url=next_url, prev_url=prev_url, search=search)
2024-02-01 19:52:23 -08:00
@bp.route('/d/<int:domain_id>/block')
@login_required
def domain_block(domain_id):
domain = Domain.query.get_or_404(domain_id)
block = DomainBlock.query.filter_by(user_id=current_user.id, domain_id=domain_id).first()
if not block:
block = DomainBlock(user_id=current_user.id, domain_id=domain_id)
db.session.add(block)
db.session.commit()
2024-02-01 20:22:32 -08:00
cache.delete_memoized(blocked_domains, current_user.id)
2024-02-01 19:52:23 -08:00
flash(_('%(name)s blocked.', name=domain.name))
return redirect(url_for('domain.show_domain', domain_id=domain.id))
2023-11-29 01:12:55 -08:00
2024-02-01 19:52:23 -08:00
@bp.route('/d/<int:domain_id>/unblock')
@login_required
def domain_unblock(domain_id):
domain = Domain.query.get_or_404(domain_id)
block = DomainBlock.query.filter_by(user_id=current_user.id, domain_id=domain_id).first()
2024-02-01 20:22:32 -08:00
if block:
2024-02-01 19:52:23 -08:00
db.session.delete(block)
db.session.commit()
2024-02-01 20:22:32 -08:00
cache.delete_memoized(blocked_domains, current_user.id)
2024-02-01 19:52:23 -08:00
flash(_('%(name)s un-blocked.', name=domain.name))
return redirect(url_for('domain.show_domain', domain_id=domain.id))
@bp.route('/d/<int:domain_id>/ban')
@login_required
@permission_required('manage users')
def domain_ban(domain_id):
domain = Domain.query.get_or_404(domain_id)
if domain:
domain.banned = True
db.session.commit()
domain.purge_content()
flash(_('%(name)s banned for all users and all content deleted.', name=domain.name))
return redirect(url_for('domain.domains'))
@bp.route('/d/<int:domain_id>/unban')
@login_required
@permission_required('manage users')
def domain_unban(domain_id):
domain = Domain.query.get_or_404(domain_id)
if domain:
2024-02-01 20:22:32 -08:00
domain.banned = False
2024-02-01 19:52:23 -08:00
db.session.commit()
flash(_('%(name)s un-banned for all users.', name=domain.name))
return redirect(url_for('domain.show_domain', domain_id=domain.id))