A mini-framework providing tools to help you make complex APIs with serverless
Project description
[![Build Status](https://travis-ci.org/QuantumBA/pyverless.svg?branch=master)](https://travis-ci.org/QuantumBA/pyverless)
[![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
Handler that reads the request body and creates the object with each (key, value) pair as a parameter for the constructor.
The `model` attribute must be set on the handler and the `create_object` method can be overwritten.
Usage:
```python
class UserCreateHandler(CreateHandler):
model = MyUserClass # MyUserClass(k1=v1, k2=v2, ...) for each k,v on body
required_body_keys = ['email', 'password']
```
### RetrieveHandler
Handler that returns a serialized Object.
The `model` attribute must be set and `id` must be present on the pathParameters.
The user must overwrite either the `serializer` attribute or the `serialize` method.
Usage:
```python
class UserRetrieveHandler(RetrieveHandler):
model = MyUserClass
serializer = serialize_user
```
### UpdateHandler
Handler that sets self.object and for each (key, value) pair of the body
sets self.object.key = value.
The `model` attribute must be set and `id` must be present on the pathParameters.
Returns the serialized node and sets the HTTP status code to 200
Usage:
```python
class UserUpdateHandler(UpdateHandler):
model = MyUserClass
required_body_keys = ['title', 'body']
serializer = serialize_user
```
### DeleteHandler
Handler that sets self.object, calls its delete() method and sets the HTTP status code to 204.
The `model` attribute must be set and `id` must be present on the pathParameters.
The user can also overwrite the `get_queryset` method to limit the search.
Usage:
```python
class UserDeleteHandler(DeleteHandler):
model = MyUserClass
```
### ListHandler
Handler that returns a list of serialized nodes and sets the HTTP status code to 200.
The `model` attribute must be set and the user must overwrite either the `serializer` attribute
or the `serialize` method.
```python
class UserListHandler(ListHandler):
model = MyUserClass
serializer = user_serializer
def get_queryset(self):
return only_some_users
```
## Mixins
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(RequestBodyMixin, 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()`. The user will be a object
of the class specified on pyverless settings as `USER_MODEL`.
### RequestBodyMixin
This mixin provides the `get_object()` method in charge of gathering a particular object,
you can access the object via `self.object`.
The `id` of the object will be taken from the pathParameters and
the user must set the `model` attribute on the handler.
### ListMixin
This mixin provides the `get_queryset()` method in charge of getting a list of objects,
you can access the list via `self.queryset`. The user must set the `model` attribute
and either the `serializer` attribute or `serialize()` method on the handler.
### S3FileMixin
This mixin provides the `get_file()` and `get_message_part()` methods in charge of
reading an event from aws S3, you can access the file via `self.file`.
The file will be a `dict()` with the following keys: bucket, owner, file_name, size.
***Warning: Only tested with objectCreated!!!!***
### SQSMessagesMixin
This mixin provides the `get_messages()` method in charge of reading an SQS event from aws.
You can access the list of messages via `self.messages`.
Each message will be a `dict()` with the following keys: attributes, text_message, queue_source, region.
## Serializers
**TODO**
[![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
Handler that reads the request body and creates the object with each (key, value) pair as a parameter for the constructor.
The `model` attribute must be set on the handler and the `create_object` method can be overwritten.
Usage:
```python
class UserCreateHandler(CreateHandler):
model = MyUserClass # MyUserClass(k1=v1, k2=v2, ...) for each k,v on body
required_body_keys = ['email', 'password']
```
### RetrieveHandler
Handler that returns a serialized Object.
The `model` attribute must be set and `id` must be present on the pathParameters.
The user must overwrite either the `serializer` attribute or the `serialize` method.
Usage:
```python
class UserRetrieveHandler(RetrieveHandler):
model = MyUserClass
serializer = serialize_user
```
### UpdateHandler
Handler that sets self.object and for each (key, value) pair of the body
sets self.object.key = value.
The `model` attribute must be set and `id` must be present on the pathParameters.
Returns the serialized node and sets the HTTP status code to 200
Usage:
```python
class UserUpdateHandler(UpdateHandler):
model = MyUserClass
required_body_keys = ['title', 'body']
serializer = serialize_user
```
### DeleteHandler
Handler that sets self.object, calls its delete() method and sets the HTTP status code to 204.
The `model` attribute must be set and `id` must be present on the pathParameters.
The user can also overwrite the `get_queryset` method to limit the search.
Usage:
```python
class UserDeleteHandler(DeleteHandler):
model = MyUserClass
```
### ListHandler
Handler that returns a list of serialized nodes and sets the HTTP status code to 200.
The `model` attribute must be set and the user must overwrite either the `serializer` attribute
or the `serialize` method.
```python
class UserListHandler(ListHandler):
model = MyUserClass
serializer = user_serializer
def get_queryset(self):
return only_some_users
```
## Mixins
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(RequestBodyMixin, 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()`. The user will be a object
of the class specified on pyverless settings as `USER_MODEL`.
### RequestBodyMixin
This mixin provides the `get_object()` method in charge of gathering a particular object,
you can access the object via `self.object`.
The `id` of the object will be taken from the pathParameters and
the user must set the `model` attribute on the handler.
### ListMixin
This mixin provides the `get_queryset()` method in charge of getting a list of objects,
you can access the list via `self.queryset`. The user must set the `model` attribute
and either the `serializer` attribute or `serialize()` method on the handler.
### S3FileMixin
This mixin provides the `get_file()` and `get_message_part()` methods in charge of
reading an event from aws S3, you can access the file via `self.file`.
The file will be a `dict()` with the following keys: bucket, owner, file_name, size.
***Warning: Only tested with objectCreated!!!!***
### SQSMessagesMixin
This mixin provides the `get_messages()` method in charge of reading an SQS event from aws.
You can access the list of messages via `self.messages`.
Each message will be a `dict()` with the following keys: attributes, text_message, queue_source, region.
## 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.4.tar.gz
(14.2 kB
view details)
Built Distribution
pyverless-0.0.4-py3-none-any.whl
(13.5 kB
view details)
File details
Details for the file pyverless-0.0.4.tar.gz
.
File metadata
- Download URL: pyverless-0.0.4.tar.gz
- Upload date:
- Size: 14.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/3.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 29c69411ef325b04d4646d350fcf04b6f589be37e637e8c27571c1698251c4bf |
|
MD5 | de90f0bfc3ea7d05d48c98de588a4b09 |
|
BLAKE2b-256 | b3c34403ea7517ea01a3d4febad00a8b829cbc67d4776ee1322ea016c68cb7d5 |
File details
Details for the file pyverless-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: pyverless-0.0.4-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/3.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | edba37055662df8c9a730ec1312b24749e7e6cd3aa446996c2dbf6d227b329cb |
|
MD5 | 6c4392bf14240356613e9529de26a369 |
|
BLAKE2b-256 | 95a6e57b0c17b7587ba20b2e133fcd5514d2d861490c38ba517ef51e04500433 |