3
0
Fork 0

fix: fix behavior when editing Roles for a User

per proper UUID fields i guess
This commit is contained in:
Lance Edgar 2024-12-12 20:07:49 -06:00
parent e952e1031e
commit d72a2a15ec
4 changed files with 26 additions and 8 deletions

View file

@ -453,16 +453,24 @@ class RoleRefs(WuttaSet):
if 'values' not in kwargs: if 'values' not in kwargs:
model = self.app.model model = self.app.model
auth = self.app.get_auth_handler() auth = self.app.get_auth_handler()
# avoid built-ins which cannot be assigned to users
avoid = { avoid = {
auth.get_role_authenticated(self.session), auth.get_role_authenticated(self.session),
auth.get_role_anonymous(self.session), auth.get_role_anonymous(self.session),
} }
avoid = set([role.uuid for role in avoid]) avoid = set([role.uuid for role in avoid])
# also avoid admin unless current user is root
if not self.request.is_root:
avoid.add(auth.get_role_administrator(self.session).uuid)
# everything else can be (un)assigned for users
roles = self.session.query(model.Role)\ roles = self.session.query(model.Role)\
.filter(~model.Role.uuid.in_(avoid))\ .filter(~model.Role.uuid.in_(avoid))\
.order_by(model.Role.name)\ .order_by(model.Role.name)\
.all() .all()
values = [(role.uuid, role.name) for role in roles] values = [(role.uuid.hex, role.name) for role in roles]
kwargs['values'] = values kwargs['values'] = values
return widgets.RoleRefsWidget(self.request, **kwargs) return widgets.RoleRefsWidget(self.request, **kwargs)

View file

@ -134,9 +134,8 @@ class UserView(MasterView):
# roles # roles
f.append('roles') f.append('roles')
f.set_node('roles', RoleRefs(self.request)) f.set_node('roles', RoleRefs(self.request))
if not self.creating: if not self.creating:
f.set_default('roles', [role.uuid for role in user.roles]) f.set_default('roles', [role.uuid.hex for role in user.roles])
def unique_username(self, node, value): def unique_username(self, node, value):
""" """ """ """

View file

@ -332,13 +332,21 @@ class TestRoleRefs(DataTestCase):
self.session.add(blokes) self.session.add(blokes)
self.session.commit() self.session.commit()
# default values for widget includes all but: authed, anon # with root access, default values include: admin, blokes
self.request.is_root = True
typ = mod.RoleRefs(self.request, session=self.session) typ = mod.RoleRefs(self.request, session=self.session)
widget = typ.widget_maker() widget = typ.widget_maker()
self.assertEqual(len(widget.values), 2) self.assertEqual(len(widget.values), 2)
self.assertEqual(widget.values[0][1], "Administrator") self.assertEqual(widget.values[0][1], "Administrator")
self.assertEqual(widget.values[1][1], "Blokes") self.assertEqual(widget.values[1][1], "Blokes")
# without root, default values include: blokes
self.request.is_root = False
typ = mod.RoleRefs(self.request, session=self.session)
widget = typ.widget_maker()
self.assertEqual(len(widget.values), 1)
self.assertEqual(widget.values[0][1], "Blokes")
class TestPermissions(DataTestCase): class TestPermissions(DataTestCase):

View file

@ -210,14 +210,17 @@ class TestRoleRefsWidget(WebTestCase):
# editable values list *excludes* admin (by default) # editable values list *excludes* admin (by default)
html = widget.serialize(field, {admin.uuid, blokes.uuid}) html = widget.serialize(field, {admin.uuid, blokes.uuid})
self.assertNotIn(str(admin.uuid), html) self.assertNotIn(str(admin.uuid.hex), html)
self.assertIn(str(blokes.uuid), html) self.assertIn(str(blokes.uuid.hex), html)
# but admin is included for root user # but admin is included for root user
self.request.is_root = True self.request.is_root = True
node = colander.SchemaNode(RoleRefs(self.request, session=self.session))
field = self.make_field(node)
widget = field.widget
html = widget.serialize(field, {admin.uuid, blokes.uuid}) html = widget.serialize(field, {admin.uuid, blokes.uuid})
self.assertIn(str(admin.uuid), html) self.assertIn(str(admin.uuid.hex), html)
self.assertIn(str(blokes.uuid), html) self.assertIn(str(blokes.uuid.hex), html)
class TestUserRefsWidget(WebTestCase): class TestUserRefsWidget(WebTestCase):