Create skeleton of a python AWS Lambda function
Project description
=============
lambda-pyskel
=============
Create python AWS Lambda skeleton from templates.
.. image:: https://img.shields.io/pypi/v/lambda-pyskel.svg
:target: https://pypi-hypernode.com/project/lambda-pyskel/
.. image:: https://circleci.com/gh/vincentsarago/lambda-pyskel.svg?style=svg
:target: https://circleci.com/gh/vincentsarago/lambda-pyskel
.. image:: https://codecov.io/gh/vincentsarago/lambda-pyskel/branch/master/graph/badge.svg
:target: https://codecov.io/gh/vincentsarago/lambda-pyskel
Shameless inspiration from @sgillies https://github.com/mapbox/pyskel
Install
=======
You can install lambda-pyskel using pip
.. code-block:: console
$ pip install -U pip
$ pip install lambda-pyskel
or install from source:
.. code-block:: console
$ git clone https://github.com/vincentsarago/lambda-pyskel.git
$ cd lambda-pyskel
$ pip install -U pip
$ pip install -e .
Templates
=========
**Three** different templates are available:
- **simple**: simple python lambda function
- **rasterio**: include rasterio wheels
- **gdal**: include gdal shared libraries and configuration
Each templates has the following structure::
pyskel/ : main module
__init__.py
handler.py : handler function
tests/ : python tests
test_handler.py
test_mod.py
Dockerfile : Dockerfile to create the package.zip
LICENSE : BSD-2 license file
Makefile : make commands to create/tests the packages
README.rst : Readme
setup.py : Python setup
tox.ini : tox template
Deployement Toolkit
===================
In addition to python module templates, lambda-pyskel can also add
configuration files for **serverless** or **kes** toolkit.
**kes**: http://devseed.com/kes/
**serverless**: https://serverless.com
Usage
=====
.. code-block:: console
$ Usage: lps [OPTIONS] NAME
Create new python AWS Lambda skeleton.
Options:
--template [simple|rasterio|gdal] Use specific template (default: 'simple')
--serverless-toolkit [kes|serverless] add deployement toolkit
--help Show this message and exit.
Create a python lambda function with rasterio
.. code-block:: console
$ lps yo --template rasterio
$ ls -1 yo
Dockerfile
LICENSE
Makefile
README.rst
setup.py
tests/
tox.ini
yo/
# edit yo/handler.py and setup.py
$ make build
Contribution & Devellopement
============================
Issues and pull requests are more than welcome.
**Dev install & Pull-Request**
.. code-block:: console
$ git clone https://github.com/vincentsarago/lambda-pyskel.git
$ cd lambda-pyskel
$ pip install -e .[dev]
*Python3.6 only*
This repo is set to use `pre-commit` to run *flake8*, *pydocstring* and *black* ("uncompromising Python code formatter") when committing new code.
.. code-block:: console
$ pre-commit install
$ git add .
$ git commit -m'my change'
black....................................................................Passed
Flake8...................................................................Passed
Verifying PEP257 Compliance..............................................Passed
$ git push origin
lambda-pyskel
=============
Create python AWS Lambda skeleton from templates.
.. image:: https://img.shields.io/pypi/v/lambda-pyskel.svg
:target: https://pypi-hypernode.com/project/lambda-pyskel/
.. image:: https://circleci.com/gh/vincentsarago/lambda-pyskel.svg?style=svg
:target: https://circleci.com/gh/vincentsarago/lambda-pyskel
.. image:: https://codecov.io/gh/vincentsarago/lambda-pyskel/branch/master/graph/badge.svg
:target: https://codecov.io/gh/vincentsarago/lambda-pyskel
Shameless inspiration from @sgillies https://github.com/mapbox/pyskel
Install
=======
You can install lambda-pyskel using pip
.. code-block:: console
$ pip install -U pip
$ pip install lambda-pyskel
or install from source:
.. code-block:: console
$ git clone https://github.com/vincentsarago/lambda-pyskel.git
$ cd lambda-pyskel
$ pip install -U pip
$ pip install -e .
Templates
=========
**Three** different templates are available:
- **simple**: simple python lambda function
- **rasterio**: include rasterio wheels
- **gdal**: include gdal shared libraries and configuration
Each templates has the following structure::
pyskel/ : main module
__init__.py
handler.py : handler function
tests/ : python tests
test_handler.py
test_mod.py
Dockerfile : Dockerfile to create the package.zip
LICENSE : BSD-2 license file
Makefile : make commands to create/tests the packages
README.rst : Readme
setup.py : Python setup
tox.ini : tox template
Deployement Toolkit
===================
In addition to python module templates, lambda-pyskel can also add
configuration files for **serverless** or **kes** toolkit.
**kes**: http://devseed.com/kes/
**serverless**: https://serverless.com
Usage
=====
.. code-block:: console
$ Usage: lps [OPTIONS] NAME
Create new python AWS Lambda skeleton.
Options:
--template [simple|rasterio|gdal] Use specific template (default: 'simple')
--serverless-toolkit [kes|serverless] add deployement toolkit
--help Show this message and exit.
Create a python lambda function with rasterio
.. code-block:: console
$ lps yo --template rasterio
$ ls -1 yo
Dockerfile
LICENSE
Makefile
README.rst
setup.py
tests/
tox.ini
yo/
# edit yo/handler.py and setup.py
$ make build
Contribution & Devellopement
============================
Issues and pull requests are more than welcome.
**Dev install & Pull-Request**
.. code-block:: console
$ git clone https://github.com/vincentsarago/lambda-pyskel.git
$ cd lambda-pyskel
$ pip install -e .[dev]
*Python3.6 only*
This repo is set to use `pre-commit` to run *flake8*, *pydocstring* and *black* ("uncompromising Python code formatter") when committing new code.
.. code-block:: console
$ pre-commit install
$ git add .
$ git commit -m'my change'
black....................................................................Passed
Flake8...................................................................Passed
Verifying PEP257 Compliance..............................................Passed
$ git push origin
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
lambda_pyskel-2.0.0.tar.gz
(9.6 kB
view details)
File details
Details for the file lambda_pyskel-2.0.0.tar.gz
.
File metadata
- Download URL: lambda_pyskel-2.0.0.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.6.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a7a38e527bd2f9d134b262366578fa1a04db05f83a3e5b72bfa9eb249b49bcc2 |
|
MD5 | 6809459fc047a4b2e380a6cb4e1f637c |
|
BLAKE2b-256 | b3d89ea15d0777c60968b9cca780b4e2a67b5f84374b860fceb34b6ffdb57428 |