File: dispatch_apps.rst

package info (click to toggle)
hypercorn 0.17.3-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 908 kB
  • sloc: python: 7,839; makefile: 24; sh: 6
file content (38 lines) | stat: -rw-r--r-- 1,358 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
.. _dispatch_apps:

Dispatch to multiple ASGI applications
======================================

It is often useful serve multiple ASGI applications at once, under
differing root paths. Hypercorn does not support this directly, but
the ``DispatcherMiddleware`` included with Hypercorn can. This
middleware allows multiple applications to be served on different
mounts.

The ``DispatcherMiddleware`` takes a dictionary of applications keyed
by the root path. The order of entry in this dictionary is important,
as the root paths will be checked in this order. Hence it is important
to add ``/a/b`` before ``/a`` or the latter will match everything
first. Also note that the root path should not include the trailing
slash.

An example usage is to to serve a graphql application alongside a
static file serving application. Using the graphql app is called
``graphql_app`` serving everything with the root path ``/graphql`` and
a static file app called ``static_app`` serving everything else i.e. a
root path of ``/`` the ``DispatcherMiddleware`` can be setup as,

.. code-block:: python

    from hypercorn.middleware import DispatcherMiddleware

    dispatcher_app = DispatcherMiddleware({
        "/graphql": graphql_app,
        "/": static_app,
    })

which can then be served by hypercorn,

.. code-block:: shell

    $ hypercorn module:dispatcher_app