Metadata-Version: 2.1
Name: waspy
Version: 0.45.4
Summary: Async Microservices Framework
Home-page: https://github.com/wasp/waspy
License: Apache-2.0
Keywords: wasp,async,asyncio,rest framework,rabbitmq,microservices
Author: Nick Humrich
Author-email: nhumrich@canopytax.com
Requires-Python: >=3.7,<4.0
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Natural Language :: English
Classifier: Operating System :: POSIX
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Requires-Dist: PyYAML
Requires-Dist: aenum (==1.4.5)
Requires-Dist: aioamqp
Requires-Dist: httptools
Project-URL: Repository, https://github.com/wasp/waspy
Description-Content-Type: text/markdown

# WASPy

Waspy is the python framework for the [WASP project](https://github.com/wasp/wasp). 
    In other words its an asynchronous "transport-agnostic" web framework.

## Language agnostic concepts
While this framework is for python, the patterns used in wasp are language
agnostic. You should be able to call other services in different languages
assuming they all follow the same patterns. This framework has a pluggable
architecture for the transport layer, which allows you to switch from
http to using a message bus, or vice-versa. You could even listen on both
at the same time without having to modify your code at all.

## Example
Look at `examples/` folder for some quick examples, or there is an entire example repo at https://github.com/wasp/waspy-example

## Alpha
This project is currently in alpha state. 
There are a lot of features missing.

Features for beta:
- [x] HTTP Transport
- [x] Routing
- [x] RabbitMQ transporty
- [x] Support middlewares
- [x] Client library (for calling other services)
- [x] HTTP client transport (with envvar service discovery)
- [x] RabbitMQ client transport
- [ ] Test everything

note: all alpha features are complete, but I am still in the process of adding more robusts tests. Until that is done, waspy will remain in alpha and api's might change.
 
Wish List:
- [ ] Transport classes for nats (nats.io)
- [ ] Transport classes for kafka
- [ ] Transport classes for gRPC 
- [ ] pattern for synchronous "worker-tier"
- [x] configuration package
- [ ] auto-reloading when in debug mode
- [x] sentry integration
- [ ] jwt handling

Features for GA (1.0):
- [ ] High level "Falcon-like" api for writing RESTFUL endpoints even easier!
- [ ] High level can be overridden by lower level for control/performance reasons
- [ ] Stable/proven API

## License
Apache-2.0

## Installing
To install, just run `pip install waspy`

## Developing
`python setup.py develop`

