From 7eb43f133d3df32c4baf75f903a962b124176c12 Mon Sep 17 00:00:00 2001 From: Robbe Sneyders Date: Sun, 22 Oct 2023 22:51:18 +0200 Subject: [PATCH] Add context documentation (#1747) Contributes towards #1531 Fixes #937 --- docs/context.rst | 114 +++++++++++++++++++++++++++++++++++++++++++++++ docs/index.rst | 3 +- 2 files changed, 116 insertions(+), 1 deletion(-) create mode 100644 docs/context.rst diff --git a/docs/context.rst b/docs/context.rst new file mode 100644 index 000000000..288fd56ea --- /dev/null +++ b/docs/context.rst @@ -0,0 +1,114 @@ +Context +======= + +The ``ContextMiddleware`` included in Connexion provides some information about the current request +context as thread-safe request-level global variables. + +You can access them by importing them from ``connexion.context``: + +.. code-block:: python + + from connexion.context import context, operation, receive, request, scope + from connexion import request # alias for connexion.context.request + +Note that when trying to access these context variables outside of the request handling flow, or +without running the ``ContextMiddleware``, the following ``RuntimeError`` will be thrown: + +.. code-block:: text + + RuntimeError: Working outside of operation context. Make sure your app is wrapped in a + ContextMiddleware and you're processing a request while accessing the context. + +See below for an explanation of the different variables. + +request +------- + +A ``Request`` object representing the incoming request. This is an instance of the ``ASGIRequest``. + +.. dropdown:: View a detailed reference of the ``ASGIRequest`` class + :icon: eye + + .. autoclass:: connexion.lifecycle.ASGIRequest + :noindex: + :members: + :undoc-members: + :inherited-members: + +Some of the methods and attributes are coroutines that can only be accessed from an ``async`` +context. When using the ``FlaskApp``, you might want to import the Flask request instead: + +.. code-block:: python + + from flask import request + +operation +--------- + +An ``Operation`` object representing the matched operation from your OpenAPI specification. + +.. tab-set:: + + .. tab-item:: OpenAPI 3 + :sync: OpenAPI 3 + + When using OpenAPI 3, this is an instance of the ``OpenAPIOperation`` class. + + .. dropdown:: View a detailed reference of the ``OpenAPIOperation`` class + :icon: eye + + .. autoclass:: connexion.operations.OpenAPIOperation + :members: + :undoc-members: + :inherited-members: + + .. tab-item:: Swagger 2 + :sync: Swagger 2 + + When using Swagger 2, this is an instance of the ``Swagger2Operation`` class. + + .. dropdown:: View a detailed reference of the ``Swagger2Operation`` class + :icon: eye + + .. autoclass:: connexion.operations.Swagger2Operation + :members: + :undoc-members: + :inherited-members: + +scope +----- + +The ASGI scope as received by the ``ContextMiddleware``, thus containing any changes propagated by +upstream middleware. The ASGI scope is presented as a ``dict``. Please refer to the `ASGI spec`_ +for more information on its contents. + +context.context +--------------- + +A dict containing the following information: + +.. code-block:: python + + { + "api_base_path": ... # The base path of the matched API + "operation_id": ... # The operation id of matched operation + "user": ... # User information from authentication + "token_info": ... # Token information from authentication + } + +Third party or custom middleware might add additional fields to this. + +receive +------- + +.. warning:: Advanced usage + +The receive channel as received by the ``ContextMiddleware``. Note that the receive channel might +already be read by other parts of Connexion (eg. when accessing the body via the ``Request``, or +when it is injected into your Python function), and that reading it yourself might make it +unavailable for those parts of the application. + +The receive channel can only be accessed from an ``async`` context and is therefore not relevant +when using the ``FlaskApp``. + +.. _ASGI spec: https://asgi.readthedocs.io/en/latest/specs/www.html#http-connection-scope \ No newline at end of file diff --git a/docs/index.rst b/docs/index.rst index e788ae98d..35c33b028 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -66,13 +66,14 @@ Documentation middleware routing swagger_ui - cli request response validation security + context cookbook exceptions + cli v3 Recommended resources