Skip to main content

Framework for middleware for Tartiflette, with context data assignment

Project description

Tartiflette Middleware

Framework to facilitate the creation of middleware for Tartiflette with resolver context variable assignment using python context managers.

Allows for processing of request/response headers, dependent on the http server you're using.

Installation

pip install tartiflette-middleware

Usage

This requires:

  1. Creation of your middleware.
  2. Configuration of your middleware in your application.
  3. Update your resolvers to access your data.

1 - Creation of your middleware

Create a context manager to run on each request.

Example:

from tartiflette_middleware import BaseMiddleware

class MyMiddleware(BaseMiddleware):
    # required short arbitrary unique middleware label
    label = 'MyMware'

    def __init__(self, my_middleware_params):
        BaseMiddleware.__init__(self)
        # do things necessary for repeated use across all of the requests, e.g.
        # configure factories

    async def __aenter__(self):
        # provide the data or method to be used in all queries for a single
        # request. 
        your_method_or_data = ...
        # store the data/method to be reused for this request
        await self.store_request_data(your_method_or_data)

    async def __aexit__(self, exc_type, exc_val, exc_tb):
        # optional: for if you need to do something when the request is
        # completed
        data = await self.get_request_data()
        data.close_or_whatever()

There are more examples in the examples directory including one with access to AIOHTTP request headers.

You can set the response http status using something like:

async def __aenter__(self):
    self.status = 401

2 - Configuration of your middleware in your app

Currently only AIOHTTP is supported but the library is extensible if others would like to submit a pull request to support other servers that Tartiflette supports.

Limited AIOHTTP setup example, imports and configuration kept to middleware specific details:

from tartiflette_middleware import Middleware, server
import MyMiddleware     # your Middleware as defined earlier

my_middleware = Middleware(
    context_manager=MyMiddleware(
        my_middleware_params={},
    ),
    server_middleware=server.aiohttp
)

app = web.Application(middlewares=[
    my_middleware.middleware
])
ctx = {
    'my_session_service': my_middleware.service,
}
web.run_app(
    register_graphql_handlers(
        # your configuration
        executor_context=ctx,
    )
)

3 - Access data in your resolvers' context

Works in queries, mutations, and subscriptions.

@Resolver('Query.whatever')
async def resolve_query_user_login(parent, args, ctx, info):
    my_data = await ctx['my_session_service']()

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tartiflette-middleware-1.1.tar.gz (4.8 kB view details)

Uploaded Source

Built Distribution

tartiflette_middleware-1.1-py3-none-any.whl (6.1 kB view details)

Uploaded Python 3

File details

Details for the file tartiflette-middleware-1.1.tar.gz.

File metadata

  • Download URL: tartiflette-middleware-1.1.tar.gz
  • Upload date:
  • Size: 4.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.5.2

File hashes

Hashes for tartiflette-middleware-1.1.tar.gz
Algorithm Hash digest
SHA256 3fdd8278c4309023b6f0e0b34312a126eac22f81548e6757cf3c6f39337b52db
MD5 e90dd38f0f3166e8f6c20f713944f5eb
BLAKE2b-256 0098e3669679f088b4f578aeb2db585bb8b94e24c59f947bafd0abeabcaf3bc2

See more details on using hashes here.

File details

Details for the file tartiflette_middleware-1.1-py3-none-any.whl.

File metadata

  • Download URL: tartiflette_middleware-1.1-py3-none-any.whl
  • Upload date:
  • Size: 6.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.5.2

File hashes

Hashes for tartiflette_middleware-1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 aa4f1ce5e8e01a386bd2f1f204d7c3ba9aa3f4df1e91364cf021c9b4495d315b
MD5 a962254909109fbefd7ac4121203d6f4
BLAKE2b-256 f176b808251f2aa9a52fcc3b9d0724b8291561c7cc7c2d2fc2e98eecb20491b6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page