mirror of
https://codeberg.org/Mo8it/AdvLabDB.git
synced 2025-01-01 15:39:20 +00:00
Add UserHasRole filter
This commit is contained in:
parent
43983679c8
commit
85f49824ca
1 changed files with 24 additions and 6 deletions
|
@ -6,7 +6,7 @@ import numpy as np
|
||||||
from flask import flash, has_request_context, redirect, request, url_for
|
from flask import flash, has_request_context, redirect, request, url_for
|
||||||
from flask_admin import expose
|
from flask_admin import expose
|
||||||
from flask_admin.contrib.sqla.fields import QuerySelectField, QuerySelectMultipleField
|
from flask_admin.contrib.sqla.fields import QuerySelectField, QuerySelectMultipleField
|
||||||
from flask_admin.contrib.sqla.filters import FilterEqual
|
from flask_admin.contrib.sqla.filters import BooleanEqualFilter, FilterEqual
|
||||||
from flask_admin.helpers import get_form_data
|
from flask_admin.helpers import get_form_data
|
||||||
from flask_admin.menu import MenuLink
|
from flask_admin.menu import MenuLink
|
||||||
from flask_admin.model.template import EndpointLinkRowAction
|
from flask_admin.model.template import EndpointLinkRowAction
|
||||||
|
@ -14,7 +14,7 @@ from flask_security import admin_change_password, current_user, hash_password
|
||||||
from flask_wtf import FlaskForm
|
from flask_wtf import FlaskForm
|
||||||
from flask_wtf.file import FileAllowed, FileField, FileRequired
|
from flask_wtf.file import FileAllowed, FileField, FileRequired
|
||||||
from matplotlib.figure import Figure
|
from matplotlib.figure import Figure
|
||||||
from sqlalchemy import and_, func, or_
|
from sqlalchemy import and_, not_, or_
|
||||||
from werkzeug.utils import secure_filename
|
from werkzeug.utils import secure_filename
|
||||||
from wtforms import Form
|
from wtforms import Form
|
||||||
from wtforms.fields import (
|
from wtforms.fields import (
|
||||||
|
@ -258,13 +258,14 @@ class UserView(SecureAdminModelView):
|
||||||
model, password, notify=False
|
model, password, notify=False
|
||||||
) # Password is automatically hashed with this function
|
) # Password is automatically hashed with this function
|
||||||
|
|
||||||
if model.has_role("assistant") and not model.assistant:
|
if model.has_role("assistant") and model.assistant is None:
|
||||||
semester_experiments = form.semester_experiments.data if form.semester_experiments else []
|
semester_experiments = form.semester_experiments.data if form.semester_experiments else []
|
||||||
|
|
||||||
assistant = Assistant(user=model, semester_experiments=semester_experiments)
|
assistant = Assistant(user=model, semester_experiments=semester_experiments)
|
||||||
self.session.add(assistant)
|
self.session.add(assistant)
|
||||||
|
|
||||||
if model.has_role("admin") and not model.admin:
|
if model.has_role("admin") and model.admin is None:
|
||||||
|
flash("Admin role was assigned!", "danger")
|
||||||
admin = Admin(user=model)
|
admin = Admin(user=model)
|
||||||
self.session.add(admin)
|
self.session.add(admin)
|
||||||
|
|
||||||
|
@ -826,6 +827,17 @@ class SemesterExperimentView(SecureAdminModelView):
|
||||||
return updateSuccessful
|
return updateSuccessful
|
||||||
|
|
||||||
|
|
||||||
|
def userHasRoleFilterFactory(column, role_name):
|
||||||
|
class UserHasRoleFilter(BooleanEqualFilter):
|
||||||
|
def apply(self, query, value, alias=None):
|
||||||
|
if bool(int(value)): # value is string "0" or "1"
|
||||||
|
return query.filter(self.column.user.has(User.roles.any(Role.name == role_name)))
|
||||||
|
else:
|
||||||
|
return query.filter(self.column.user.has(not_(User.roles.any(Role.name == role_name))))
|
||||||
|
|
||||||
|
return UserHasRoleFilter(column, f"Currently has {role_name} role")
|
||||||
|
|
||||||
|
|
||||||
class AssistantView(SecureAdminModelView):
|
class AssistantView(SecureAdminModelView):
|
||||||
class UserEndpointLinkRowAction(CustomIdEndpointLinkRowAction):
|
class UserEndpointLinkRowAction(CustomIdEndpointLinkRowAction):
|
||||||
def customId(self, row):
|
def customId(self, row):
|
||||||
|
@ -854,7 +866,10 @@ class AssistantView(SecureAdminModelView):
|
||||||
"user.last_name",
|
"user.last_name",
|
||||||
"user.email",
|
"user.email",
|
||||||
]
|
]
|
||||||
column_filters = ("user.active",)
|
column_filters = (
|
||||||
|
userHasRoleFilterFactory(Assistant, "assistant"),
|
||||||
|
"user.active",
|
||||||
|
)
|
||||||
form_excluded_columns = [
|
form_excluded_columns = [
|
||||||
"experiment_marks",
|
"experiment_marks",
|
||||||
"appointments",
|
"appointments",
|
||||||
|
@ -900,7 +915,10 @@ class AdminView(SecureAdminModelView):
|
||||||
"user.first_name",
|
"user.first_name",
|
||||||
"user.last_name",
|
"user.last_name",
|
||||||
]
|
]
|
||||||
column_filters = ("user.active",)
|
column_filters = (
|
||||||
|
userHasRoleFilterFactory(Admin, "admin"),
|
||||||
|
"user.active",
|
||||||
|
)
|
||||||
|
|
||||||
column_extra_row_actions = [
|
column_extra_row_actions = [
|
||||||
UserEndpointLinkRowAction(
|
UserEndpointLinkRowAction(
|
||||||
|
|
Loading…
Reference in a new issue