2023-05-17 21:13:08 -04:00
|
|
|
Permissions
|
|
|
|
===========
|
2023-05-20 20:05:41 -04:00
|
|
|
|
|
|
|
Sachet offers a selection of permissions that can be assigned to users,
|
|
|
|
which manage their access to certain endpoints.
|
|
|
|
|
2023-06-15 12:46:26 -04:00
|
|
|
.. _permissions_serialization:
|
|
|
|
|
2023-05-20 20:05:41 -04:00
|
|
|
Serialization
|
|
|
|
-------------
|
|
|
|
In Sachet's JSON API, permissions are serialized as an array of string codes.
|
|
|
|
These codes are documented in :ref:`permissions_table`.
|
|
|
|
|
|
|
|
For instance, here is an example output for ``GET /users/user``:
|
|
|
|
|
|
|
|
.. code-block:: json
|
|
|
|
|
|
|
|
{
|
|
|
|
"permissions": [
|
|
|
|
"CREATE",
|
|
|
|
"DELETE",
|
|
|
|
"LIST",
|
|
|
|
"READ"
|
|
|
|
],
|
|
|
|
"register_date": "2023-05-08T18:57:27.982479",
|
|
|
|
"username": "user"
|
|
|
|
}
|
|
|
|
|
|
|
|
.. _permissions_table:
|
|
|
|
|
|
|
|
Table of permissions
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
The following is a table of permissions Sachet offers, and what they do:
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:widths: 25 25 50
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Permission
|
|
|
|
- Code
|
|
|
|
- Description
|
|
|
|
* - Create shares
|
|
|
|
- ``CREATE``
|
|
|
|
- Allows uploading files to Sachet.
|
|
|
|
* - Modify shares
|
|
|
|
- ``MODIFY``
|
|
|
|
- Allows users to modify their own shares' contents and metadata.
|
|
|
|
* - Delete shares
|
|
|
|
- ``DELETE``
|
|
|
|
- Allows users to delete any share.
|
|
|
|
* - Lock shares
|
|
|
|
- ``LOCK``
|
2023-05-21 12:56:44 -04:00
|
|
|
- Allows users to lock and unlock shares (see :ref:`files_lock_api`).
|
2023-05-20 20:05:41 -04:00
|
|
|
* - List shares
|
|
|
|
- ``LIST``
|
|
|
|
- Allows users to list all shares from all users.
|
|
|
|
* - Read shares
|
|
|
|
- ``READ``
|
|
|
|
- Allows users to read any share.
|
|
|
|
* - Administration
|
|
|
|
- ``ADMIN``
|
|
|
|
- Allows creating users and managing their permissions.
|
2023-06-15 12:46:26 -04:00
|
|
|
|
|
|
|
Whoami API
|
|
|
|
----------
|
|
|
|
|
|
|
|
Information about the current user and their permissions can be obtained through this API.
|
|
|
|
``GET /whoami`` will return a result like this:
|
|
|
|
|
|
|
|
.. code-block:: json
|
|
|
|
|
|
|
|
{
|
|
|
|
"username": "user",
|
|
|
|
"permissions": ["READ", "CREATE"]
|
|
|
|
}
|
|
|
|
|
|
|
|
``permissions`` will be serialized as in :ref:`permissions_serialization`.
|
|
|
|
If the user is not currently signed in, ``username`` will be ``null``.
|