mirror of
https://github.com/aljazceru/CTFd.git
synced 2025-12-18 14:34:21 +01:00
5ce3003b Merge pull request #47 from aCursedComrade/patch-1 c9887cb1 Fix team template git-subtree-dir: CTFd/themes/core-beta git-subtree-split: 5ce3003b4d68352e629ee2d390bc999e7d6b071e
83 lines
2.0 KiB
Python
83 lines
2.0 KiB
Python
from flask import Blueprint, render_template, request, url_for
|
|
|
|
from CTFd.models import Users
|
|
from CTFd.utils import config
|
|
from CTFd.utils.decorators import authed_only
|
|
from CTFd.utils.decorators.visibility import (
|
|
check_account_visibility,
|
|
check_score_visibility,
|
|
)
|
|
from CTFd.utils.helpers import get_errors, get_infos
|
|
from CTFd.utils.user import get_current_user
|
|
|
|
users = Blueprint("users", __name__)
|
|
|
|
|
|
@users.route("/users")
|
|
@check_account_visibility
|
|
def listing():
|
|
q = request.args.get("q")
|
|
field = request.args.get("field", "name")
|
|
if field not in ("name", "affiliation", "website"):
|
|
field = "name"
|
|
|
|
filters = []
|
|
if q:
|
|
filters.append(getattr(Users, field).like("%{}%".format(q)))
|
|
|
|
users = (
|
|
Users.query.filter_by(banned=False, hidden=False)
|
|
.filter(*filters)
|
|
.order_by(Users.id.asc())
|
|
.paginate(per_page=50)
|
|
)
|
|
|
|
args = dict(request.args)
|
|
args.pop("page", 1)
|
|
|
|
return render_template(
|
|
"users/users.html",
|
|
users=users,
|
|
prev_page=url_for(request.endpoint, page=users.prev_num, **args),
|
|
next_page=url_for(request.endpoint, page=users.next_num, **args),
|
|
q=q,
|
|
field=field,
|
|
)
|
|
|
|
|
|
@users.route("/profile")
|
|
@users.route("/user")
|
|
@authed_only
|
|
def private():
|
|
infos = get_infos()
|
|
errors = get_errors()
|
|
|
|
user = get_current_user()
|
|
|
|
if config.is_scoreboard_frozen():
|
|
infos.append("Scoreboard has been frozen")
|
|
|
|
return render_template(
|
|
"users/private.html",
|
|
user=user,
|
|
account=user.account,
|
|
infos=infos,
|
|
errors=errors,
|
|
)
|
|
|
|
|
|
@users.route("/users/<int:user_id>")
|
|
@check_account_visibility
|
|
@check_score_visibility
|
|
def public(user_id):
|
|
infos = get_infos()
|
|
errors = get_errors()
|
|
user = Users.query.filter_by(id=user_id, banned=False, hidden=False).first_or_404()
|
|
|
|
if config.is_scoreboard_frozen():
|
|
infos.append("Scoreboard has been frozen")
|
|
|
|
return render_template(
|
|
"users/public.html", user=user, account=user.account, infos=infos, errors=errors
|
|
)
|