diff options
Diffstat (limited to 'newspipe/web/views/admin.py')
-rw-r--r-- | newspipe/web/views/admin.py | 120 |
1 files changed, 71 insertions, 49 deletions
diff --git a/newspipe/web/views/admin.py b/newspipe/web/views/admin.py index 73b2b668..fe1b389b 100644 --- a/newspipe/web/views/admin.py +++ b/newspipe/web/views/admin.py @@ -1,5 +1,5 @@ from datetime import datetime -from flask import (Blueprint, render_template, redirect, flash, url_for) +from flask import Blueprint, render_template, redirect, flash, url_for from flask_babel import gettext, format_timedelta from flask_login import login_required, current_user @@ -8,41 +8,45 @@ from web.views.common import admin_permission from web.controllers import UserController from web.forms import InformationMessageForm, UserForm -admin_bp = Blueprint('admin', __name__, url_prefix='/admin') +admin_bp = Blueprint("admin", __name__, url_prefix="/admin") -@admin_bp.route('/dashboard', methods=['GET', 'POST']) +@admin_bp.route("/dashboard", methods=["GET", "POST"]) @login_required @admin_permission.require(http_exception=403) def dashboard(): last_cons, now = {}, datetime.utcnow() - users = list(UserController().read().order_by('id')) + users = list(UserController().read().order_by("id")) form = InformationMessageForm() for user in users: last_cons[user.id] = format_timedelta(now - user.last_seen) - return render_template('admin/dashboard.html', now=datetime.utcnow(), - last_cons=last_cons, users=users, current_user=current_user, - form=form) - - -@admin_bp.route('/user/create', methods=['GET']) -@admin_bp.route('/user/edit/<int:user_id>', methods=['GET']) + return render_template( + "admin/dashboard.html", + now=datetime.utcnow(), + last_cons=last_cons, + users=users, + current_user=current_user, + form=form, + ) + + +@admin_bp.route("/user/create", methods=["GET"]) +@admin_bp.route("/user/edit/<int:user_id>", methods=["GET"]) @login_required @admin_permission.require(http_exception=403) def user_form(user_id=None): if user_id is not None: user = UserController().get(id=user_id) form = UserForm(obj=user) - message = gettext('Edit the user <i>%(nick)s</i>', nick=user.nickname) + message = gettext("Edit the user <i>%(nick)s</i>", nick=user.nickname) else: form = UserForm() - message = gettext('Add a new user') - return render_template('/admin/create_user.html', - form=form, message=message) + message = gettext("Add a new user") + return render_template("/admin/create_user.html", form=form, message=message) -@admin_bp.route('/user/create', methods=['POST']) -@admin_bp.route('/user/edit/<int:user_id>', methods=['POST']) +@admin_bp.route("/user/create", methods=["POST"]) +@admin_bp.route("/user/edit/<int:user_id>", methods=["POST"]) @login_required @admin_permission.require(http_exception=403) def process_user_form(user_id=None): @@ -53,31 +57,42 @@ def process_user_form(user_id=None): user_contr = UserController() if not form.validate(): - return render_template('/admin/create_user.html', form=form, - message=gettext('Some errors were found')) + return render_template( + "/admin/create_user.html", + form=form, + message=gettext("Some errors were found"), + ) if user_id is not None: # Edit a user - user_contr.update({'id': user_id}, - {'nickname': form.nickname.data, - 'password': form.password.data, - 'automatic_crawling': form.automatic_crawling.data}) + user_contr.update( + {"id": user_id}, + { + "nickname": form.nickname.data, + "password": form.password.data, + "automatic_crawling": form.automatic_crawling.data, + }, + ) user = user_contr.get(id=user_id) - flash(gettext('User %(nick)s successfully updated', - nick=user.nickname), 'success') + flash( + gettext("User %(nick)s successfully updated", nick=user.nickname), "success" + ) else: # Create a new user (by the admin) - user = user_contr.create(nickname=form.nickname.data, - password=form.password.data, - automatic_crawling=form.automatic_crawling.data, - is_admin=False, - is_active=True) - flash(gettext('User %(nick)s successfully created', - nick=user.nickname), 'success') - return redirect(url_for('admin.user_form', user_id=user.id)) + user = user_contr.create( + nickname=form.nickname.data, + password=form.password.data, + automatic_crawling=form.automatic_crawling.data, + is_admin=False, + is_active=True, + ) + flash( + gettext("User %(nick)s successfully created", nick=user.nickname), "success" + ) + return redirect(url_for("admin.user_form", user_id=user.id)) -@admin_bp.route('/delete_user/<int:user_id>', methods=['GET']) +@admin_bp.route("/delete_user/<int:user_id>", methods=["GET"]) @login_required @admin_permission.require(http_exception=403) def delete_user(user_id=None): @@ -86,16 +101,21 @@ def delete_user(user_id=None): """ try: user = UserController().delete(user_id) - flash(gettext('User %(nick)s successfully deleted', - nick=user.nickname), 'success') + flash( + gettext("User %(nick)s successfully deleted", nick=user.nickname), "success" + ) except Exception as error: flash( - gettext('An error occurred while trying to delete a user: %(error)s', - error=error), 'danger') - return redirect(url_for('admin.dashboard')) + gettext( + "An error occurred while trying to delete a user: %(error)s", + error=error, + ), + "danger", + ) + return redirect(url_for("admin.dashboard")) -@admin_bp.route('/toggle_user/<int:user_id>', methods=['GET']) +@admin_bp.route("/toggle_user/<int:user_id>", methods=["GET"]) @login_required @admin_permission.require() def toggle_user(user_id=None): @@ -104,16 +124,18 @@ def toggle_user(user_id=None): """ ucontr = UserController() user = ucontr.get(id=user_id) - user_changed = ucontr.update({'id': user_id}, - {'is_active': not user.is_active}) + user_changed = ucontr.update({"id": user_id}, {"is_active": not user.is_active}) if not user_changed: - flash(gettext('This user does not exist.'), 'danger') - return redirect(url_for('admin.dashboard')) + flash(gettext("This user does not exist."), "danger") + return redirect(url_for("admin.dashboard")) else: - act_txt = 'activated' if user.is_active else 'desactivated' - message = gettext('User %(nickname)s successfully %(is_active)s', - nickname=user.nickname, is_active=act_txt) - flash(message, 'success') - return redirect(url_for('admin.dashboard')) + act_txt = "activated" if user.is_active else "desactivated" + message = gettext( + "User %(nickname)s successfully %(is_active)s", + nickname=user.nickname, + is_active=act_txt, + ) + flash(message, "success") + return redirect(url_for("admin.dashboard")) |