Skip to main content

A generic functional middleware infrastructure for Python.

Project description

Formation

Build Status Coverage Status

A generic functional middleware infrastructure for Python.

Take a look:

from datetime.datetime import now
from formation import wrap
from requests import get

def log(ctx, call):
    print("started")
    ctx = call(ctx)
    print("ended")
    return ctx

def timeit(ctx, call):
    started = now()
    ctx = call(ctx)
    ended = now() - started
    ctx['duration'] = ended
    return ctx

def to_requests(ctx):
    get(ctx['url'])
    return ctx

fancy_get = wrap(to_requests, middleware=[log, timeit])
fancy_get({'url':'https://google.com'})

Quick Start

Install using pip/pipenv/etc. (we recommend poetry for sane dependency management):

$ poetry add formation

Best Practices

A context object is a loose bag of objects. With that freedom comes responsibility and opinion.

For example, this is how Formation models a requests integration, with data flowing inside context:

  • It models a FormationHttpRequest which abstracts the essentials of making an HTTP request (later shipped to requests itself in the way that it likes)
  • It tucks FormationHttpRequest under the fmtn.req key.
  • Additional information regarding such a request is kept alongside fmtn.req. For example a request id is kept in the req.id key. This creates a flat (good thing) dict to probe. The reason additional data does not have the fmtn prefix is that you can always build your own that uses a different prefix (which you cant say about internal Formation inner workings).

Thanks:

To all Contributors - you make this happen, thanks!

Copyright

Copyright (c) 2018 @jondot. See LICENSE for further details.

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

formation-0.1.37.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

formation-0.1.37-py2.py3-none-any.whl (10.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file formation-0.1.37.tar.gz.

File metadata

  • Download URL: formation-0.1.37.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.3 CPython/3.8.1 Darwin/18.7.0

File hashes

Hashes for formation-0.1.37.tar.gz
Algorithm Hash digest
SHA256 3af48848c34ea07505ba9e70c4842c94d26e5d5501d05dc83818798721ff3c97
MD5 4f117975ed33f9af11f44e31d5ed4217
BLAKE2b-256 47e02b4d69cf516c746f6a2a05d360d81953b648cab08b4d7ed1db65674d0e98

See more details on using hashes here.

File details

Details for the file formation-0.1.37-py2.py3-none-any.whl.

File metadata

  • Download URL: formation-0.1.37-py2.py3-none-any.whl
  • Upload date:
  • Size: 10.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.3 CPython/3.8.1 Darwin/18.7.0

File hashes

Hashes for formation-0.1.37-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8a533b15566a9b5c04e3a43e6a162b1e4b84a6580c1c1b217b60caecc4ae4c4f
MD5 3195aedd0a991117d47abb7561569c71
BLAKE2b-256 6e009f84ff306d6159112a2177fa9eb0166a00b0f851b49c227377cc989d806e

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