/nameko-serializer

a extended serializer to help nameko rpc call with dates and namedtuple

Primary LanguagePythonOtherNOASSERTION

nameko-serializer

enhenced json serializer for nameko micro-services.

  1. it allow to pass datetime.date and datetime.datetime to rpc calls and event arguments. get ride of datetime.datetime not JSON serializable errors messages in nameko.
  2. add support for namedtuple in service transmissions. you return a namedtuple instance, you get the same namedtuple in the other side, which is retro-comatible and support either res.attr or res['attr']

Stable branch

https://readthedocs.org/projects/nameko-serializer/badge/?version=latest https://coveralls.io/repos/github/Yupeek/nameko-serializer/badge.svg?branch=master Latest PyPI version Requirements Status

Development status

https://coveralls.io/repos/github/Yupeek/nameko-serializer/badge.svg?branch=develop Requirements Status

Installation

  1. Install using pip:

    pip install nameko-serializers

  2. Alternatively, you can download or clone this repo and install with :

    pip install -e ..

Requirements

work with nameko up to 1.12.*

Examples

  1. install: pip install nameko-serializers
  2. configure: add in your config.yaml the folowing line: serializer: nameko-serializer
  3. enjoy

datetime support (with timezone)

Documentation

this Readme is currently the full documentation. it's not a library this big...

features

date and datetime serializing

this serializer will handle datetime and date serializing. if a datetime is timezone naive, it will be made aware using the detected current timezone (via tzlocal.get_localzone())

all received dates will be timezone aware, but the timezone will be fixed to UTC.

NamedTulpe support

this serializer allow to transmit namedtuple as dict, and will deserialize it as special namedtuple, supporting dict index

Requirements

  • Python 2.7, 3.6, 3.7

Note

this serializer use the builtin ordered dict feature to unserialize namedtuple with correct attributes order. if you use python2.7 or 3.6 without cPython, you must exclusively use argument's names and not indice.

Contributions and pull requests are welcome.

Bugs and requests

If you found a bug or if you have a request for additional feature, please use the issue tracker on GitHub.

https://github.com/Yupeek/nameko-serializer/issues

known limitations

  • if you pass some objects with keys __type__, it will be converted.
  • all unserialized dates will be tz aware, and tzinfo will be set to UTC. (this is a good practice to change tz at display time)
  • for python < 3.7, the order in the namedtuple is not garanteed, use exclusively kwargs and attrs by names

License

You can use this under GPLv3.

Author

Original author: Darius BERNARD.

Thanks

Thanks to Nameko for this amazing framework.