Skip to content

Commit

Permalink
permissions: add generator for handling groups enabled feature flag
Browse files Browse the repository at this point in the history
  • Loading branch information
anikachurilova committed Apr 24, 2024
1 parent 4c31af2 commit 9f1ca10
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 6 deletions.
3 changes: 3 additions & 0 deletions invenio_users_resources/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -240,3 +240,6 @@ class OrgPropsSchema(Schema):

USERS_RESOURCES_DOMAINS_ORG_SCHEMA = OrgPropsSchema
"""Domains organisation schema config."""

USERS_RESOURCES_GROUPS_ENABLED = True
"""Config to enable features related to existence of groups."""
27 changes: 27 additions & 0 deletions invenio_users_resources/services/generators.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@
"""Permission generators for users and groups."""


from flask import current_app
from invenio_access.permissions import any_user
from invenio_records.dictutils import dict_lookup
from invenio_records_permissions.generators import (
ConditionalGenerator,
Expand Down Expand Up @@ -123,3 +125,28 @@ def query_filter(self, **kwargs):
return q_all & else_query

return q_not_managed & then_query


class GroupsEnabled(Generator):
"""Generator to restrict if the groups are not enabled.
If the groups are not enabled, exclude any user for adding members of the
param member type.
A system process is allowed to do anything.
"""

def __init__(self, *need_groups_enabled_types):
"""Types that need the groups enabled."""
self.need_groups_enabled_types = need_groups_enabled_types

def excludes(self, member_types=None, **kwargs):
"""Preventing needs."""
member_types = member_types or {"group"}
for m in member_types:
if (
m in self.need_groups_enabled_types
and not current_app.config["USERS_RESOURCES_GROUPS_ENABLED"]
):
return [any_user]
return []
22 changes: 16 additions & 6 deletions invenio_users_resources/services/permissions.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,13 @@

from invenio_users_resources.permissions import user_management_action

from .generators import IfGroupNotManaged, IfPublicEmail, IfPublicUser, Self
from .generators import (
GroupsEnabled,
IfGroupNotManaged,
IfPublicEmail,
IfPublicUser,
Self,
)

UserManager = AdminAction(user_management_action)

Expand Down Expand Up @@ -53,14 +59,18 @@ class UsersPermissionPolicy(BasePermissionPolicy):
class GroupsPermissionPolicy(BasePermissionPolicy):
"""Permission policy for users and user groups."""

can_create = [SystemProcess()]
can_read = [
can_any = [
GroupsEnabled("group"),
SystemProcess(),
]
can_create = can_any + [SystemProcess()]
can_read = can_any + [
IfGroupNotManaged([AuthenticatedUser()], [UserManager]),
SystemProcess(),
]
can_search = [AuthenticatedUser(), SystemProcess()]
can_update = [SystemProcess()]
can_delete = [SystemProcess()]
can_search = can_any + [AuthenticatedUser(), SystemProcess()]
can_update = can_any + [SystemProcess()]
can_delete = can_any + [SystemProcess()]


class DomainPermissionPolicy(BasePermissionPolicy):
Expand Down
2 changes: 2 additions & 0 deletions tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,8 @@ def app_config(app_config):
# setting preferences schema to test notifications
app_config["ACCOUNTS_USER_PREFERENCES_SCHEMA"] = UserPreferencesNotificationsSchema

app_config["USERS_RESOURCES_GROUPS_ENABLED"] = True

return app_config


Expand Down

0 comments on commit 9f1ca10

Please sign in to comment.