Skip to content

Commit

Permalink
split up NewDoapTarget
Browse files Browse the repository at this point in the history
  • Loading branch information
jnussbaum committed Aug 13, 2024
1 parent 8a70f20 commit 8019aa1
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 21 deletions.
22 changes: 10 additions & 12 deletions dsp_permissions_scripts/doap/doap_model.py
Original file line number Diff line number Diff line change
Expand Up @@ -50,22 +50,20 @@ def _validate(self) -> Self:
return self


class NewDoapTarget(BaseModel):
class NewGroupDoapTarget(BaseModel):
"""Represents the target of a DOAP that is yet to be created."""

group: Group


class NewEntityDoapTarget(BaseModel):
"""Represents the target of a DOAP that is yet to be created."""

group: Group | None = None
resource_class: str | None = None
property: str | None = None

@model_validator(mode="after")
def assert_correct_combination(self) -> Self:
# asserts that DOAP is only defined for Group or ResourceClass or Property
# or a combination of ResourceClass and Property
match (self.group, self.resource_class, self.property):
case (None, None, None):
raise ValueError("At least one of group, resource_class or property must be set")
case (_, None, None) | (None, _, _):
pass
case _:
raise ValueError("Invalid combination of group, resource_class and property")
def _validate(self) -> Self:
if self.resource_class is None and self.property is None:
raise ValueError("At least one of resource_class or property must be set")
return self
11 changes: 6 additions & 5 deletions dsp_permissions_scripts/doap/doap_set.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,8 @@

from dsp_permissions_scripts.doap.doap_get import create_doap_from_admin_route_response
from dsp_permissions_scripts.doap.doap_model import Doap
from dsp_permissions_scripts.doap.doap_model import NewDoapTarget
from dsp_permissions_scripts.doap.doap_model import NewEntityDoapTarget
from dsp_permissions_scripts.doap.doap_model import NewGroupDoapTarget
from dsp_permissions_scripts.models.errors import ApiError
from dsp_permissions_scripts.models.scope import PermissionScope
from dsp_permissions_scripts.utils.dsp_client import DspClient
Expand Down Expand Up @@ -40,17 +41,17 @@ def apply_updated_scopes_of_doaps_on_server(doaps: list[Doap], host: str, dsp_cl


def create_new_doap_on_server(
target: NewDoapTarget,
target: NewGroupDoapTarget | NewEntityDoapTarget,
shortcode: str,
scope: PermissionScope,
dsp_client: DspClient,
) -> Doap | None:
proj_iri, _ = get_project_iri_and_onto_iris_by_shortcode(shortcode, dsp_client)
payload = {
"forGroup": target.group.full_iri() if target.group else None,
"forGroup": target.group.full_iri() if isinstance(target, NewGroupDoapTarget) else None,
"forProject": proj_iri,
"forProperty": target.property,
"forResourceClass": target.resource_class,
"forProperty": target.property if isinstance(target, NewEntityDoapTarget) else None,
"forResourceClass": target.resource_class if isinstance(target, NewEntityDoapTarget) else None,
"hasPermissions": create_admin_route_object_from_scope(scope),
}
try:
Expand Down
4 changes: 2 additions & 2 deletions dsp_permissions_scripts/template.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
from dsp_permissions_scripts.doap.doap_get import get_doaps_of_project
from dsp_permissions_scripts.doap.doap_model import Doap
from dsp_permissions_scripts.doap.doap_model import GroupDoapTarget
from dsp_permissions_scripts.doap.doap_model import NewDoapTarget
from dsp_permissions_scripts.doap.doap_model import NewGroupDoapTarget
from dsp_permissions_scripts.doap.doap_serialize import serialize_doaps_of_project
from dsp_permissions_scripts.doap.doap_set import apply_updated_scopes_of_doaps_on_server
from dsp_permissions_scripts.doap.doap_set import create_new_doap_on_server
Expand Down Expand Up @@ -113,7 +113,7 @@ def update_doaps(host: str, shortcode: str, dsp_client: DspClient) -> None:
host=host,
)
_ = create_new_doap_on_server(
target=NewDoapTarget(group=group.CREATOR),
target=NewGroupDoapTarget(group=group.CREATOR),
shortcode=shortcode,
scope=PermissionScope.create(CR=[group.SYSTEM_ADMIN]),
dsp_client=dsp_client,
Expand Down
4 changes: 2 additions & 2 deletions tests/test_doap_set.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import pytest

from dsp_permissions_scripts.doap import doap_set
from dsp_permissions_scripts.doap.doap_model import NewDoapTarget
from dsp_permissions_scripts.doap.doap_model import NewGroupDoapTarget
from dsp_permissions_scripts.doap.doap_set import create_new_doap_on_server
from dsp_permissions_scripts.models import group
from dsp_permissions_scripts.models.scope import PermissionScope
Expand Down Expand Up @@ -55,7 +55,7 @@ def test_create_new_doap_on_server(
dsp_client = Mock()
dsp_client.post = Mock(return_value=create_new_doap_response)
_ = create_new_doap_on_server(
target=NewDoapTarget(group=group.KNOWN_USER),
target=NewGroupDoapTarget(group=group.KNOWN_USER),
shortcode="0000",
scope=PermissionScope.create(V={group.UNKNOWN_USER}),
dsp_client=dsp_client,
Expand Down

0 comments on commit 8019aa1

Please sign in to comment.