Permissions Endpoint
For an extensive explanation on how DSP permissions are implemented, see here.
Permission Operations
Note: For the following operations, the requesting user must be either a systemAdmin
or a projectAdmin
.
Getting Permissions
-
GET: /admin/permissions/<projectIri>
: return all permissions for a project. As a response, the IRI and the type of allpermissions
of a project are returned. -
GET: /admin/permissions/ap/<projectIri>
: return all administrative permissions for a project. As a response, alladministrative_permissions
of a project are returned. -
GET: /admin/permissions/ap/<projectIri>/<groupIri>
: return the administrative permissions for a project group. As a response, theadministrative_permission
defined for the group is returned. -
GET: /admin/permissions/doap/<projectIri>
: return all default object access permissions for a project. As a response, alldefault_object_acces_permissions
of a project are returned.
Creating New Administrative Permissions
POST: /admin/permissions/ap
: create a new administrative permission. The type of permissions, the project and group to which the permission should be added must be included in the request body, for example:
{
"forGroup":"http://rdfh.ch/groups/0001/thing-searcher",
"forProject":"http://rdfh.ch/projects/0001",
"hasPermissions":[
{
"additionalInformation":null,
"name":"ProjectAdminGroupAllPermission",
"permissionCode":null
}
]
}
In addition, in the body of the request, it is possible to specify a custom IRI (of
DSP IRI form) for a permission through
the @id
attribute which will then be assigned to the permission; otherwise the permission will get a unique random IRI.
A custom permission IRI must be http://rdfh.ch/permissions/PROJECT_SHORTCODE/
(where PROJECT_SHORTCODE
is the shortcode of the project that the permission belongs to), plus a custom ID string. For example:
"id": "http://rdfh.ch/permissions/0001/jKIYuaEUETBcyxpenUwRzQ",
As a response, the created administrative permission and its IRI are returned as below:
{
"administrative_permission": {
"forGroup": "http://rdfh.ch/groups/0001/thing-searcher",
"forProject": "http://rdfh.ch/projects/0001",
"hasPermissions": [
{
"additionalInformation": null,
"name": "ProjectAdminGroupAllPermission",
"permissionCode": null
}
],
"iri": "http://rdfh.ch/permissions/0001/mFlyBEiMQtGzwy_hK0M-Ow"
}
}
hasPermissions
contains permission types that must be granted. See the complete description of administrative
permission types.
In summary, each permission should contain followings:
additionalInformation
: should be left empty, otherwise will be ignored.name
: indicates the type of the permission that can be one of the followings:ProjectAdminAllPermission
: gives the user the permission to do anything on project level, i.e. create new groups, modify all existing groupsProjectAdminGroupAllPermission
: gives the user the permission to modify group info and group membership on all groups belonging to the project.ProjectAdminGroupRestrictedPermission
: gives the user the permission to modify group info and group membership on certain groups belonging to the project.ProjectAdminRightsAllPermission
: gives the user the permission to change the permissions on all objects belonging to the project (e.g., default permissions attached to groups and permissions on objects).ProjectResourceCreateAllPermission
: gives the permission to create resources inside the project.ProjectResourceCreateRestrictedPermission
: gives restricted resource creation permission inside the project.
permissionCode
: should be left empty, otherwise will be ignored.
Note that during the creation of a new project, a default set of administrative permissions are added to its ProjectAdmin and ProjectMember groups (See Default set of permissions for a new project). Therefore, it is not possible to create new administrative permissions for the ProjectAdmin and ProjectMember groups of a project. However, the default permissions set for these groups can be modified (See update permission).
Creating New Default Object Access Permissions
POST: /admin/permissions/doap
: create a new default object access permission. A single instance ofknora-admin:DefaultObjectAccessPermission
must always reference a project, but can only reference either a group (knora-admin:forGroup
property), a resource class (knora-admin:forResourceClass
), a property (knora-admin:forProperty
), or a combination of resource class and property. For example, to create a new default object access permission for a group of a project the request body would be
{
"forGroup":"http://rdfh.ch/groups/0001/thing-searcher",
"forProject":"http://rdfh.ch/projects/0001",
"forProperty":null,
"forResourceClass":null,
"hasPermissions":[
{
"additionalInformation":"http://www.knora.org/ontology/knora-admin#ProjectMember",
"name":"D",
"permissionCode":7
}
]
}
hasPermissions
contains permission types that must be granted. See a complete description of object access
permission types.
In summary, each permission should contain followings:
additionalInformation
: To whom the permission should be granted: project members, known users, unknown users, etc.name
: indicates the type of the permission that can be one of the followings.RV
: restricted view permission (least privileged)V
: view permissionM
modify permissionD
: delete permissionCR
: change rights permission (most privileged)
permissionCode
: The code assigned to a permission indicating its hierarchical level. These codes are as below:1
: for restricted view permission (least privileged)2
: for view permission6
: for modify permission7
: for delete permission8
: for change rights permission (most privileged)
Note that, at least either name
or permissionCode
must be provided. If one is missing, it will be extrapolated from the other.
For example, if permissionCode= 1
is given but name
was left empty, its value will be set to name = RV
.
Similar to the previous case a custom IRI can be assigned to a permission specified by the id
in the request body.
The example below shows the request body to create a new default object access permission with a custom IRI defined for
a resource class of a specific project:
{
"id": "http://rdfh.ch/permissions/00FF/fSw7w1sI5IwDjEfFi1jOeQ",
"forGroup":null,
"forProject":"http://rdfh.ch/projects/00FF",
"forProperty":null,
"forResourceClass":"http://www.knora.org/ontology/00FF/images#bild",
"hasPermissions":[
{
"additionalInformation":"http://www.knora.org/ontology/knora-admin#ProjectMember",
"name":"D",
"permissionCode":7
}
]
}
The response contains the newly created permission and its IRI, as:
{
"default_object_access_permission": {
"forGroup": null,
"forProject": "http://rdfh.ch/projects/00FF",
"forProperty": null,
"forResourceClass": "http://www.knora.org/ontology/00FF/images#bild",
"hasPermissions": [
{
"additionalInformation": "http://www.knora.org/ontology/knora-admin#ProjectMember",
"name": "D",
"permissionCode": 7
}
],
"iri": "http://rdfh.ch/permissions/00FF/fSw7w1sI5IwDjEfFi1jOeQ"
}
}
Note that during the creation of a new project, a set of default object access permissions are created for its ProjectAdmin and ProjectMember groups (See Default set of permissions for a new project). Therefore, it is not possible to create new default object access permissions for the ProjectAdmin and ProjectMember groups of a project. However, the default permissions set for these groups can be modified; see below for more information.
Updating a Permission's Group
PUT: /admin/permissions/<permissionIri>/group
to change the group for which an administrative or a default object access permission, identified by its IRI<permissionIri>
, is defined. The request body must contain the IRI of the new group as below:
{
"forGroup": "http://www.knora.org/ontology/knora-admin#ProjectMember"
}
forGroup
value will be replaced with the new one.
When updating a default object access permission, if it originally had a forGroup
value defined, it will be replaced
with the new group. Otherwise, if the default object access permission was defined for a resource class or a property or
the combination of both, the permission will be defined for the newly specified group and its previous
forResourceClass
and forProperty
values will be deleted.
Updating a Permission's Scope
PUT: /admin/permissions/<permissionIri>/hasPermissions
to change the scope of permissions assigned to an administrative or a default object access permission identified by it IRI,<permissionIri>
. The request body must contain the new set of permission types as below:
{
"hasPermissions":[
{
"additionalInformation":"http://www.knora.org/ontology/knora-admin#ProjectMember",
"name":"D",
"permissionCode":7
}
]
}
Each permission item given in hasPermissions
, must contain the necessary parameters with respect to the type of the
permission. For example, if you wish to change the scope of an administrative permission, follow the
guidelines for the
content of its hasPermissions
property. Similarly, if you wish to change the scope of a default object access permission,
follow the guidelines given about the content of its hasPermissions
property.
Either the name
or the permissionCode
must be present; it is not necessary to provide both.
The previous permission set is replaced by the new permission set. In order to remove a permission for a group entirely, you can provide a new set of permissions, leaving out the permission specification for the group.
Updating a Default Object Access Permission's Resource Class
PUT: /admin/permissions/<doap_permissionIri>/resourceClass
to change the resource class for which a default object access permission, identified by it IRI<doap_permissionIri>
, is defined. This operation is only valid for updating a default object acceess permission. The IRI of the new resource class must be given in the request body as:
{
"forResourceClass": "http://www.knora.org/ontology/0803/incunabula#book"
}
Note that if the default object access permission was originally defined for a group, with this operation, the permission
will be defined for the given resource class instead of the group. That means the value of the forGroup
will
be deleted.
Updating a Default Object Access Permission's Property
PUT: /admin/permissions/<doap_permissionIri>/property
to change the property for which a default object access permission, identified by it IRI<doap_permissionIri>
, is defined. This operation is only valid for updating a default object access permission. The IRI of the new property must be given in the request body as:
{
"forProperty":"http://www.knora.org/ontology/00FF/images#titel"
}
forGroup
will
be deleted.
Deleting a Permission
DELETE: /admin/permissions/<permissionIri>
to delete an administrative, or a default object access permission. The IRI of the permission must be given in encoded form.