mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-16 09:51:59 +03:00
66 lines
2.4 KiB
Plaintext
66 lines
2.4 KiB
Plaintext
Authorization modes
|
|
===================
|
|
|
|
You can run Hasura's GraphQL Engine in three modes:
|
|
|
|
1. No Authentication mode
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
- When ``--access-key`` and ``--auth-hook`` are not set
|
|
|
|
- It is useful when you're developing . It is not recommended to use in production but however you can have proxy gateway that will set (``X-Hasura-Access-Key``) header and other required ``X-Hasura-*`` headers.
|
|
|
|
Run server in this mode using following docker command.
|
|
|
|
.. code-block:: bash
|
|
|
|
docker run --name hasura-graphql-engine -p 9000:9000 \
|
|
--link hasura-postgres:postgres \
|
|
-d hasura/graphql-engine:latest graphql-engine \
|
|
--database-url \
|
|
postgres://postgres:mysecretpassword@postgres:5432/postgres \
|
|
serve --server-port 9000 --cors-domain "*"
|
|
|
|
|
|
2. Access key mode
|
|
^^^^^^^^^^^^^^^^^^
|
|
|
|
- When only ``--access-key`` is set. See :doc:`GraphQL Server Options <../deployment/options>`
|
|
|
|
- Server authenticates based on ``X-Hasura-Access-Key`` header and expects all other required ``X-Hasura-*`` headers.
|
|
|
|
Run server in this mode using following docker command.
|
|
|
|
.. code-block:: bash
|
|
|
|
docker run --name hasura-graphql-engine -p 9000:9000 \
|
|
--link hasura-postgres:postgres \
|
|
-d hasura/graphql-engine:latest graphql-engine \
|
|
--database-url \
|
|
postgres://postgres:mysecretpassword@postgres:5432/postgres \
|
|
serve --server-port 9000 --access-key myAccKey \
|
|
--cors-domain "*"
|
|
|
|
|
|
3. Access key and Authorization webhook mode
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
- When both ``--access-key`` and ``--auth-hook`` are set
|
|
|
|
- This mode is useful in production. When server founds ``X-Hasura-Access-Key`` header it ignores webhook and expects all other required ``X-Hasura*`` headers
|
|
|
|
- If ``X-Hasura-Access-key`` header not found then server authenticaters through webhook. See :doc:`Authorization
|
|
Webhook <webhook>`
|
|
|
|
Run server in this mode using following docker command.
|
|
|
|
.. code-block:: bash
|
|
|
|
docker run --name hasura-graphql-engine -p 9000:9000 \
|
|
--link hasura-postgres:postgres \
|
|
-d hasura/graphql-engine:latest graphql-engine \
|
|
--database-url \
|
|
postgres://postgres:mysecretpassword@postgres:5432/postgres \
|
|
serve --server-port 9000 --access-key myAccKey \
|
|
--auth-hook http://myAuthhook/ --cors-domain "*"
|