/usr/share/doc/python3-hug-doc/EXTENDING.md is in python3-hug-doc 2.3.0-1.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | Building hug extensions
=========
Want to extend hug to tackle new problems? Integrate a new form of authentication? Add new useful types?
Awesome! Here are some guidlines to help you get going and make a world class hug extension
that you will be proud to have showcased to all hug users.
How are extensions built?
=========
hug extensions should be built like any other python project and uploaded to PYPI. What makes a hug extension a *hug* extension is simply it's name and the fact it contains within its Python code utilities and classes that extend hugs capabilties.
Naming your extension
=========
All hug extensions should be prefixed with `hug_` for easy disscovery on PYPI. Additionally, there are a few more exact prefixes that can be optionally be added to help steer users to what your extensions accomplishes:
- `hug_types_` should be used if your extensions is used primarily to add new types to hug (for example: hug_types_numpy).
- `hug_authentication_` if your extension is used primarily to add a new authentication type to hug (for example: hug_authentication_oath2)
- `hug_output_format_` if your extension is used primarily to add a new output format to hug (for example: hug_output_format_svg)
- `hug_input_format_` if your extension is used primarily to add a new input format to hug (for example: hug_input_format_html)
- `hug_validate_` if your extension is used primarily to add a new overall validator to hug (for example: hug_validate_no_null).
- `hug_transform_` if your extension is used primarily to add a new hug transformer (for example: hug_transform_add_time)
- `hug_middleware_` if your extension is used primarily to add a middleware to hug (for example: hug_middleware_redis_session)
For any more complex or general use case that doesn't fit into these predefined categories or combines many of them, it
is perfectly suitable to simply prefix your extension with `hug_`. For example: hug_geo could combine hug types, hug input formats, and hug output formats making it a good use case for a simply prefixed extension.
Building Recommendations
=========
Ideally, hug extensions should be built in the same manner as hug itself. This means 100% test coverage using pytest, decent performance, pep8 compliance, and built in optional compiling with Cython. None of this is strictly required, but will help give users of your extension faith that it wont slow things down or break their setup unexpectedly.
Registering your extension
=========
Once you have finished developing and testing your extension, you can help increase others ability to discover it by registering it. The first place an extension should be registered is on PYPI, just like any other Python Package. In addition to that you can add your extension to the list of extensions on hug's [github wiki](https://github.com/timothycrosley/hug/wiki/Hug-Extensions).
Thank you
=========
A sincere thanks to anyone that takes the time to develop and register an extension for hug. You are helping to make hug a more complete eco-system for everyuser out there, and paving the way for a solid foundation into the future.
Thanks!
~Timothy Crosley
|