Metadata-Version: 2.0
Name: pyhttpstatus-utils
Version: 0.3.3
Summary: Extension of Python Standard Library http.HTTPStatus providing addtional utilities.
Home-page: https://github.com/TuneLab/pyhttpstatus-utils
Author: TUNE Inc.
Author-email: jefft@tune.com
License: MIT License
Download-URL: https://github.com/TuneLab/pyhttpstatus-utils/archive/v0.3.3.tar.gz
Description-Content-Type: UNKNOWN
Keywords: http httpstatus utilities tune
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Natural Language :: English
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3.0
Classifier: Programming Language :: Python :: 3.1
Classifier: Programming Language :: Python :: 3.2
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: Implementation :: PyPy
Requires-Dist: httpstatus35
Requires-Dist: pprintpp (>=0.3.0)
Requires-Dist: pytest (>=3.2.5)
Requires-Dist: pytest-mock (>=1.6.3)
Requires-Dist: pytest-cov (>=2.5.1)
Requires-Dist: repoze.lru (>=0.7)
Requires-Dist: wheel (>=0.30.0)

.. -*- mode: rst -*-

pyhttpstatus-utils
------------------

Extension of Python Standard Library's `http.HTTPStatus <https://docs.python.org/3/library/http.html>`_ providing mapping of HTTP statuses.

Badges
------

.. start-badges

.. list-table::
    :stub-columns: 1

    * - docs
      - |docs| |license|
    * - info
      - |hits| |contributors|
    * - tests
      - |travis| |coveralls|
    * - package
      - |version| |supported-versions|
    * - other
      - |requires|

.. |docs| image:: https://readthedocs.org/projects/pyhttpstatus-utils/badge/?style=flat
    :alt: Documentation Status
    :target: http://pyhttpstatus-utils.readthedocs.io

.. |hits| image:: http://hits.dwyl.io/TuneLab/pyhttpstatus-utils.svg
    :alt: Hit Count
    :target: http://hits.dwyl.io/TuneLab/pyhttpstatus-utils

.. |contributors| image:: https://img.shields.io/github/contributors/TuneLab/pyhttpstatus-utils.svg
    :alt: Contributors
    :target: https://github.com/TuneLab/pyhttpstatus-utils/graphs/contributors

.. |license| image:: https://img.shields.io/badge/License-MIT-yellow.svg
    :alt: License Status
    :target: https://opensource.org/licenses/MIT

.. |travis| image:: https://travis-ci.org/TuneLab/pyhttpstatus-utils.svg?branch=master
    :alt: Travis-CI Build Status
    :target: https://travis-ci.org/TuneLab/pyhttpstatus-utils

.. |coveralls| image:: https://coveralls.io/repos/TuneLab/pyhttpstatus-utils/badge.svg?branch=master&service=github
    :alt: Code Coverage Status
    :target: https://coveralls.io/r/TuneLab/pyhttpstatus-utils

.. |version| image:: https://img.shields.io/pypi/v/pyhttpstatus-utils.svg?style=flat
    :alt: PyPI Package latest release
    :target: https://pypi.python.org/pypi/pyhttpstatus-utils

.. |supported-versions| image:: https://img.shields.io/pypi/pyversions/pyhttpstatus-utils.svg?style=flat
    :alt: Supported versions
    :target: https://pypi.python.org/pypi/pyhttpstatus-utils

.. |requires| image:: https://requires.io/github/TuneLab/pyhttpstatus-utils/requirements.svg?branch=master
    :alt: Requirements Status
    :target: https://requires.io/github/TuneLab/pyhttpstatus-utils/requirements/?branch=master

.. end-badges


Install
-------

.. code-block:: bash

    pip install pyhttpstatus-utils

Functions
---------

- ``create_http_status_dict(override_dict=None)``: Create HTTP Status Dictionary with Overrides if provided.
- ``get_http_status_desc(http_status_code)``: Get HTTP status code description.
- ``get_http_status_name(http_status_code)``: Get HTTP status code name.
- ``get_http_status_phrase(http_status_code)``: Get HTTP status code phrase.
- ``get_http_status_type(http_status_code)``: Get HTTP status code type.
- ``is_http_status_successful(http_status_code)``: Check if HTTP Status Code is type Successful
- ``is_http_status_type(http_status_code)``: Match if provided HTTP Status Code is expected HTTP Status Code Type.
- ``validate_http_code(http_code, minimum=100, maximum=599, strict=True, default_http_code=0)``: Validate HTTP code. If strict, throw, else just return default_http_code.

Dictionaries
------------

- ``HTTP_STATUS_DICT``: Extracted from ``http.HTTPStatus``, a dictionary of each HTTP Status' name, code, phrase, and description.
- ``HTTP_STATUS_PHRASE_DICT``: Phrases of HTTP status codes.
- ``HTTP_STATUS_DESC_DICT``: Description of HTTP status codes.
- ``HTTP_STATUS_TYPE_DICT``: Types of HTTP status codes.

Enum Classes
------------

- ``HttpStatusCode``: Static enumeration of HTTP status mapping names to codes
- ``HttpStatusType``: Static enumeration of HTTP status mapping types to phrase
- ``HttpStatusCodeType``: Int enumeration of HTTP status mapping types to codes

HTTP Status Code Types
----------------------

- 100: HttpStatusType.INFORMATIONAL,
- 200: HttpStatusType.SUCCESSFUL,
- 300: HttpStatusType.REDIRECTION,
- 400: HttpStatusType.CLIENT_ERROR,
- 500: HttpStatusType.SERVER_ERROR


Requirements
------------

``pyhttpstatus-utils`` module is built upon Python 3 and has dependencies upon
several Python modules available within `Python Package Index PyPI <https://pypi.python.org/pypi>`_.

.. code-block:: bash

    make install-requirements

or

.. code-block:: bash

    python3 -m pip uninstall --yes --no-input -r requirements.txt
    python3 -m pip install --upgrade -r requirements.txt



.. :changelog:

Release History
===============

0.3.3 (2018-02-20)
------------------
- Python 2.7 supported
- Travis CI testing both Python 2.7 and 3.6.
- Backport Python 3.6 http.HttpStatus for support in Python 2.7 to Python 3.4.

0.3.2 (2018-02-16)
------------------
- migrate to github/TuneLab

0.3.1 (2018-01-25)
------------------
- migrate to github/tuneinc

0.2.2 (2017-12-10)
------------------
- readthedocs.org

0.2.0 (2017-12-05)
------------------
- README.rst
- Tests
- Travis CI

0.1.1 (2016-11-22)
------------------
- Makefile and yapf cleanup

0.1.0 (2016-11-17)
------------------
- Initial Code
- Code pulled from TuneLab/tune-mv-integration-python

0.0.1 (2016-11-17)
------------------
- Initial commit


