2023-11-29 22:12:55 +13:00
|
|
|
from flask import redirect, url_for, flash, request, make_response, session, Markup, current_app, abort
|
|
|
|
from flask_login import login_user, logout_user, current_user, login_required
|
|
|
|
from flask_babel import _
|
|
|
|
|
|
|
|
from app import db, constants
|
2024-01-01 11:38:24 +13:00
|
|
|
from app.models import Post, Domain, Community
|
2023-11-29 22:12:55 +13:00
|
|
|
from app.domain import bp
|
|
|
|
from app.utils import get_setting, render_template
|
|
|
|
from sqlalchemy import desc
|
|
|
|
|
|
|
|
|
|
|
|
@bp.route('/d/<domain_id>', methods=['GET'])
|
|
|
|
def show_domain(domain_id):
|
|
|
|
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:
|
2024-01-01 11:38:24 +13:00
|
|
|
posts = Post.query.join(Community, Community.id == Post.community_id).\
|
|
|
|
filter(Post.from_bot == False, Post.domain_id == domain.id, Community.banned == False).\
|
|
|
|
order_by(desc(Post.last_active)).all()
|
2023-11-29 22:12:55 +13:00
|
|
|
else:
|
2024-01-01 11:38:24 +13:00
|
|
|
posts = Post.query.join(Community).filter(Post.domain_id == domain.id, Community.banned == False).order_by(desc(Post.last_active)).all()
|
|
|
|
# todo: pagination
|
2023-11-29 22:12:55 +13:00
|
|
|
return render_template('domain/domain.html', domain=domain, title=domain.name, posts=posts,
|
|
|
|
POST_TYPE_IMAGE=constants.POST_TYPE_IMAGE, POST_TYPE_LINK=constants.POST_TYPE_LINK)
|
|
|
|
else:
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
|
|
|
|
@bp.route('/domains', methods=['GET'])
|
|
|
|
def domains():
|
|
|
|
domains = Domain.query.filter_by(banned=False).order_by(Domain.name).all()
|
|
|
|
|
|
|
|
return render_template('domain/domains.html', title='All known domains', domains=domains)
|