Permissions Endpoint
Permission Operations:
Note: For the following operations, the requesting user must be either a systemAdminor 
a projectAdmin.
Getting Permissions:
- 
GET: /admin/permissions/<projectIri>: return all permissions for a project. As a response, the IRI and the type of allpermissionsof a project are returned.
- 
GET: /admin/permissions/ap/<projectIri>: return all administrative permissions for a project. As a response, alladministrative_permissionsof a project are returned.
- 
GET: /admin/permissions/ap/<projectIri>/<groupIri>: return the administrative permissions for a project group. As a response, theadministrative_permissiondefined 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_permissionsof 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 Knora 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:
- 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 groups
- ProjectAdminGroupAllPermission: 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.
- 
additionalInformation: should be left empty, otherwise will be ignored.
- 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 of- knora-admin:DefaultObjectAccessPermissionmust always reference a project, but can only reference either a group (- knora-admin:forGroupproperty), 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 permission
- Mmodify permission
- D: delete permission
- CR: 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 permission
- 6: for modify permission
- 7: for delete permission
- 8: 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>/groupto change the group for which an administrative or a default object access permission, identified by it 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"
}
When updating an administrative permission, its previous 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>/hasPermissionsto 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.
Updating a Default Object Access Permission's Resource Class:
- PUT: /admin/permissions/<doap_permissionIri>/resourceClassto 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>/propertyto 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"
}
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 property instead of the group. That means the value of the 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.