2018-09-11 14:11:24 +03:00
|
|
|
Access control basics
|
|
|
|
=====================
|
|
|
|
|
2018-10-19 19:59:18 +03:00
|
|
|
In this section, we're going to set up a simple access control rule for restricting querying on a table.
|
2018-10-10 09:32:03 +03:00
|
|
|
We're working with a simple ``author`` table where users have some information stored about themselves.
|
2018-09-11 14:11:24 +03:00
|
|
|
|
2018-10-20 06:22:13 +03:00
|
|
|
Create an author table
|
2018-10-20 18:41:08 +03:00
|
|
|
----------------------
|
2018-09-11 14:11:24 +03:00
|
|
|
|
2018-10-15 11:47:21 +03:00
|
|
|
Head to your console and create an ``author`` table with the following columns:
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
+----------+--------+
|
|
|
|
| id | integer|
|
|
|
|
+----------+--------+
|
|
|
|
| name | text |
|
|
|
|
+----------+--------+
|
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/auth/author-table.png
|
|
|
|
|
|
|
|
Insert some sample data into the table:
|
|
|
|
|
|
|
|
+-------------+----------+
|
|
|
|
| **id** | **name** |
|
|
|
|
+-------------+----------+
|
|
|
|
| 1 | john |
|
|
|
|
+-------------+----------+
|
|
|
|
| 2 | shruti |
|
|
|
|
+-------------+----------+
|
|
|
|
| 3 | celine |
|
|
|
|
+-------------+----------+
|
|
|
|
| 4 | raj |
|
|
|
|
+-------------+----------+
|
|
|
|
|
|
|
|
Try out a query
|
|
|
|
---------------
|
|
|
|
|
|
|
|
.. code-block:: graphql
|
|
|
|
|
|
|
|
query {
|
|
|
|
author {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
You'll see that this results in a response that contains all the authors because by default the GraphQL query is
|
|
|
|
accepted with admin permissions.
|
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/auth/fetch-authors.png
|
|
|
|
|
|
|
|
|
|
|
|
Add a simple access control rule for a logged in user
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
2018-10-19 19:59:18 +03:00
|
|
|
Let's say that for our app, logged in users are only allowed to fetch their own data.
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
Let's add a **select** permission for the **user** role on the ``author`` table:
|
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/auth/author-select-perms.png
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
:widths: 15 20 25 40
|
|
|
|
|
|
|
|
* - Table
|
|
|
|
- Definition
|
|
|
|
- Condition
|
|
|
|
- Representation
|
|
|
|
|
|
|
|
* - author
|
|
|
|
- user's own row
|
|
|
|
- ``id`` in the row is equal to ``user-id`` from the request session
|
|
|
|
-
|
|
|
|
.. code-block:: json
|
|
|
|
|
|
|
|
{
|
|
|
|
"id": {
|
|
|
|
"_eq": "X-Hasura-User-Id"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-19 19:59:18 +03:00
|
|
|
Now, let's make the same query as above but also include two dynamic authorization variables via request headers.
|
2018-10-10 09:32:03 +03:00
|
|
|
``X-Hasura-Role`` and ``X-Hasura-User-Id`` will automatically get used according to the permission rule we set up.
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/auth/query-with-perms.png
|
|
|
|
|
2018-10-10 09:32:03 +03:00
|
|
|
You can notice above how the same query now only includes the right slice of data.
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
.. _restrict_columns:
|
|
|
|
|
|
|
|
Restrict access to certain columns
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
We can restrict the columns of a table that a particular role has access to.
|
|
|
|
|
|
|
|
Head to the ``Permissions`` tab of the table and edit the ``Select`` permissions for the role:
|
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/auth/restrict-columns.png
|
|
|
|
|
|
|
|
.. _limit_rows:
|
|
|
|
|
|
|
|
Limit number of rows returned in a single request
|
|
|
|
-------------------------------------------------
|
|
|
|
|
2018-10-19 19:59:18 +03:00
|
|
|
We can set a hard limit on the maximum number of rows that will be returned in a single request for a table for a particular role.
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
Head to the ``Permissions`` tab of the table and edit the ``Select`` permissions for the role:
|
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/auth/limit-results.png
|
|
|
|
|
|
|
|
Next, learn more about how permissions work
|
|
|
|
-------------------------------------------
|
|
|
|
|
|
|
|
Next: :doc:`Roles and dynamic variables <roles-variables>`
|
|
|
|
|
|
|
|
|