A mini-framework providing tools to help you make complex APIs with serverless
Project description
[![PyPI pyversions](https://img.shields.io/pypi/pyversions/pyverless.svg)](https://pypi.python.org/pypi/pyverless/)
[![PyPI license](https://img.shields.io/pypi/l/pyverless.svg)](https://pypi.python.org/pypi/pyverless/)
[![PyPI status](https://img.shields.io/pypi/status/pyverless.svg)](https://pypi.python.org/pypi/pyverless/)
# Pyverless
Developing complex APIs within AWS lambdas can be somewhat of a messy task. Lambdas are independent functions that have to work together in order to create a full-blown app, like atoms to a complex organism.
In order to define the infrastructure you may use a framework like [Serverless](https://serverless.com/), but you may find yourself copying and pasting blobs of code within your handler functions, namely for authentication, data validation, error handling and response creation to name a few.
**Enter Pyverless**
Pyverless is a mini-framework with a bunch of utilities that aims to help you create APIs using AWS Lambdas fast and in a consistent way. Pyverless provides the following.
- Class-Based Handlers
- Serializers
- Authentication handling
- JWT and cryptography
- Exceptions
- Configuration
- Warmup handling
Bring more consistency and development speed to your lambda-based APIs!
## Class-Based Handlers
Class based handlers (CBH) use the approach of Django's Class-Based Views to provide code reuse, consistency and generally abstract simple and common tasks. The aim of class-based handlers is to suit a wide range of applications by providing generic Handler classes and mixins.
Within AWS Lambda, a handler is a function that takes an event and a context and returns a response.
Generic CBH are based off the following base handler
### BaseHandler
This class provides the `as_handler()` method that returns a handler function (taking `event` and `context` as arguments).
Usage:
```python
class MyHandler(BaseHandler):
pass
_myHandler = MyHandler.as_handler()
```
There is a set of generic CBHs to handle basic CRUD operations within an API:
### CreateHandler
**TODO**
### RetrieveHandler
**TODO**
### UpdateHandler
**TODO**
### DeleteHandler
**TODO**
### ListHandler
There are also a set of **mixins** available:
### RequestBodyMixin
This mixin provides the `get_body()` method which is in charge of gathering the request body dictionary. Define `required_body_keys` and `optinal_body_keys` as follows. Within the handler, you can access the body via `self.body` or by calling `get_body()`
```python
class MyHandler(RequestBodyHandler, BaseHandler):
required_body_keys = ['name', 'email']
optinal_body_keys = ['phone']
_myHandler = MyHandler.as_handler()
```
### AuthorizationMixin
This mixin provides the `get_user()` method in charge of getting the user out of an authenticated API call. Within the handler, you can access the body via `self.body` or by calling `get_user()`
### ObjectMixin
This mixin provides the `get_object()` method in charge of gathering a particular object.
### ListMixin
**TODO**
## Serializers
**TODO**
[![PyPI license](https://img.shields.io/pypi/l/pyverless.svg)](https://pypi.python.org/pypi/pyverless/)
[![PyPI status](https://img.shields.io/pypi/status/pyverless.svg)](https://pypi.python.org/pypi/pyverless/)
# Pyverless
Developing complex APIs within AWS lambdas can be somewhat of a messy task. Lambdas are independent functions that have to work together in order to create a full-blown app, like atoms to a complex organism.
In order to define the infrastructure you may use a framework like [Serverless](https://serverless.com/), but you may find yourself copying and pasting blobs of code within your handler functions, namely for authentication, data validation, error handling and response creation to name a few.
**Enter Pyverless**
Pyverless is a mini-framework with a bunch of utilities that aims to help you create APIs using AWS Lambdas fast and in a consistent way. Pyverless provides the following.
- Class-Based Handlers
- Serializers
- Authentication handling
- JWT and cryptography
- Exceptions
- Configuration
- Warmup handling
Bring more consistency and development speed to your lambda-based APIs!
## Class-Based Handlers
Class based handlers (CBH) use the approach of Django's Class-Based Views to provide code reuse, consistency and generally abstract simple and common tasks. The aim of class-based handlers is to suit a wide range of applications by providing generic Handler classes and mixins.
Within AWS Lambda, a handler is a function that takes an event and a context and returns a response.
Generic CBH are based off the following base handler
### BaseHandler
This class provides the `as_handler()` method that returns a handler function (taking `event` and `context` as arguments).
Usage:
```python
class MyHandler(BaseHandler):
pass
_myHandler = MyHandler.as_handler()
```
There is a set of generic CBHs to handle basic CRUD operations within an API:
### CreateHandler
**TODO**
### RetrieveHandler
**TODO**
### UpdateHandler
**TODO**
### DeleteHandler
**TODO**
### ListHandler
There are also a set of **mixins** available:
### RequestBodyMixin
This mixin provides the `get_body()` method which is in charge of gathering the request body dictionary. Define `required_body_keys` and `optinal_body_keys` as follows. Within the handler, you can access the body via `self.body` or by calling `get_body()`
```python
class MyHandler(RequestBodyHandler, BaseHandler):
required_body_keys = ['name', 'email']
optinal_body_keys = ['phone']
_myHandler = MyHandler.as_handler()
```
### AuthorizationMixin
This mixin provides the `get_user()` method in charge of getting the user out of an authenticated API call. Within the handler, you can access the body via `self.body` or by calling `get_user()`
### ObjectMixin
This mixin provides the `get_object()` method in charge of gathering a particular object.
### ListMixin
**TODO**
## Serializers
**TODO**
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pyverless-0.0.2.tar.gz
(10.7 kB
view details)
Built Distribution
pyverless-0.0.2-py3-none-any.whl
(12.1 kB
view details)
File details
Details for the file pyverless-0.0.2.tar.gz
.
File metadata
- Download URL: pyverless-0.0.2.tar.gz
- Upload date:
- Size: 10.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/40.6.2 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d03883ec73596e614c3296695a4ede9bb7f253f8aceb2f4d76334cee8c12e96e |
|
MD5 | 0b1cff0e19c68bb0d03949a4039591f6 |
|
BLAKE2b-256 | 595bab9d00f61cb74d0b28947d1a89e3fe2d1448dc0cb8866200ae2975290c2a |
File details
Details for the file pyverless-0.0.2-py3-none-any.whl
.
File metadata
- Download URL: pyverless-0.0.2-py3-none-any.whl
- Upload date:
- Size: 12.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/40.6.2 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5bc8f57ba343e2ea2558d314de9eeab91499dd68d09e7e01523db843e6447470 |
|
MD5 | f14791201c39e0bcb335590e0375db83 |
|
BLAKE2b-256 | 6c0fcf332848364f41f03c42f5e6a8d7153def6ae9b68584bb9d346f4b7af284 |