Metadata-Version: 2.1
Name: apistar-contrib
Version: 0.0.5
Summary: Contrib packages to add on to API Star.
Home-page: https://github.com/ryananguiano/apistar-contrib
Author: Ryan Anguiano
Author-email: ryan.anguiano@gmail.com
License: MIT license
Keywords: apistar contrib
Platform: UNKNOWN
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Requires-Python: >=3.5
Requires-Dist: apistar (>=0.5)

================
API Star Contrib
================


.. image:: https://img.shields.io/pypi/v/apistar-contrib.svg
        :target: https://pypi.python.org/pypi/apistar-contrib

.. image:: https://img.shields.io/travis/ryananguiano/apistar-contrib.svg
        :target: https://travis-ci.org/ryananguiano/apistar-contrib

.. image:: https://readthedocs.org/projects/api-star-contrib/badge/?version=latest
        :target: https://api-star-contrib.readthedocs.io/en/latest/?badge=latest
        :alt: Documentation Status

.. image:: https://pyup.io/repos/github/ryananguiano/apistar-contrib/shield.svg
     :target: https://pyup.io/repos/github/ryananguiano/apistar-contrib/
     :alt: Updates


Contrib packages to add on to API Star.


* Free software: MIT license
* Documentation: https://api-star-contrib.readthedocs.io.


Features
--------

* CSRF Token Hook
* Local Session Store (Development)
* Timezone Support


TODO
----

* Redis Session Store
* DB Session Store


Usage
-----

Local Session Store
```````````````````

.. code-block:: python

    from apistar import App, Route, http
    from apistar_contrib.sessions import Session, SessionComponent, SessionHook, LocalMemorySessionStore


    def use_session(session: Session, params: http.QueryParams):
        for key, value in params:
            session[key] = value
        return session.data


    def clear_session(session: Session):
        session.clear()
        return session.data


    routes = [
        Route('/', 'GET', use_session),
        Route('/clear', 'GET', clear_session),
    ]

    app = App(
        routes=routes,
        components=[SessionComponent(LocalMemorySessionStore)],
        event_hooks=[SessionHook]
    )


CSRF Token
``````````

.. code-block:: python

    import os
    from apistar import App, Route, http
    from apistar_contrib.csrf import EnforceCsrfHook, rotate_token


    def show_form():
        return app.render_template(
            'form.html',
            show_csrf=True,
        )


    def show_no_csrf_form():
        return app.render_template(
            'form.html',
            show_csrf=False,
        )


    def handle_form(request: http.Request):
        # You should rotate CSRF tokens after successful login/logout
        rotate_token(request)
        return app.render_template(
            'form.html',
            show_csrf=True,
            success=True,
        )


    routes = [
        Route('/', 'GET', show_form),
        Route('/no_csrf', 'GET', show_no_csrf_form),
        Route('/handle', 'POST', handle_form),
    ]

    BASE_DIR = os.path.dirname(__file__)
    TEMPLATE_DIR = os.path.join(BASE_DIR, 'templates')

    app = App(
        routes=routes,
        event_hooks=[EnforceCsrfHook],
        template_dir=TEMPLATE_DIR,
    )


.. code-block:: html

    <!-- templates/form.html -->
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>CSRF Form</title>
    </head>
    <body>
        <ul>
            <li><a href="{{ reverse_url('show_form') }}">Form with CSRF</a></li>
            <li><a href="{{ reverse_url('show_no_csrf_form') }}">Form without CSRF</a></li>
        </ul>
        {% if success %}<h1>Successful POST</h1>{% endif %}
        <form action="{{ reverse_url('handle_form') }}" method="post">
            {% if show_csrf %} {{ csrf_token() }} {% endif %}
            <button type="submit">Submit form {% if show_csrf %}with{% else %}without{% endif %} CSRF</button>
        </form>
    </body>
    </html>



Credits
-------

This package was created with Cookiecutter_ and the `audreyr/cookiecutter-pypackage`_ project template.

.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`audreyr/cookiecutter-pypackage`: https://github.com/audreyr/cookiecutter-pypackage


=======
History
=======

0.0.5 (2018-05-19)
------------------

* Added Redis Session Store
* Created first tests

0.0.4 (2018-05-18)
------------------

* Remove default components

0.0.3 (2018-05-18)
------------------

* Refactor Session component

0.0.2 (2018-05-17)
------------------

* Add CSRF token hook


0.0.1 (2018-05-15)
------------------

* First release on PyPI.


