Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mozilla/mozilla-django-oidc
A django OpenID Connect library
https://github.com/mozilla/mozilla-django-oidc
Last synced: 1 day ago
JSON representation
A django OpenID Connect library
- Host: GitHub
- URL: https://github.com/mozilla/mozilla-django-oidc
- Owner: mozilla
- License: mpl-2.0
- Created: 2016-10-11T09:37:45.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2024-07-05T17:41:38.000Z (7 months ago)
- Last Synced: 2024-10-29T11:03:01.518Z (3 months ago)
- Language: Python
- Homepage: https://mozilla-django-oidc.readthedocs.io
- Size: 606 KB
- Stars: 448
- Watchers: 21
- Forks: 168
- Open Issues: 80
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- Contributing: CONTRIBUTING.rst
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Authors: AUTHORS.rst
Awesome Lists containing this project
- starred-awesome - mozilla-django-oidc - A django OpenID Connect library (Python)
README
===================
mozilla-django-oidc
===================.. image:: https://badge.fury.io/py/mozilla-django-oidc.svg
:target: https://badge.fury.io/py/mozilla-django-oidc.. image:: https://codecov.io/gh/mozilla/mozilla-django-oidc/branch/main/graph/badge.svg
:target: https://codecov.io/gh/mozilla/mozilla-django-oidc.. image:: https://circleci.com/gh/mozilla/mozilla-django-oidc/tree/main.svg?style=svg
:target: https://circleci.com/gh/mozilla/mozilla-django-oidc/tree/mainA lightweight authentication and access management library for integration with OpenID Connect enabled authentication services.
Documentation
-------------The full documentation is at ``_.
Design principles
-----------------* Keep it as minimal/lightweight as possible
* Store as few authn/authz artifacts as possible
* Allow custom functionality by overriding the authentication backend
* Mainly support OIDC authorization code flow
* Allow shipping Mozilla-centric authn/authz features
* Test against all supported Python/Django version
* E2E tested and audited by `Mozilla InfoSec `_Running Unit Tests
-------------------Use ``tox`` to run as many different versions of Python you have. If you
don't have ``tox`` installed (and executable) already you can either
install it in your system Python or ``_.
Once installed, simply execute in the project root directory... code-block:: shell
$ tox
``tox`` will do the equivalent of installing virtual environments for every
combination mentioned in the ``tox.ini`` file. If your system, for example,
doesn't have ``python3.4`` those ``tox`` tests will be skipped.For a faster test-rinse-repeat cycle you can run tests in a specific
environment with a specific version of Python and specific version of
Django of your choice. Here is such an example:.. code-block:: shell
$ virtualenv -p /path/to/bin/python3.8 venv
$ source venv
(venv) $ pip install -r requirements/requirements_dev.txt
(venv) $ DJANGO_SETTINGS_MODULE=tests.settings django-admin testMeasuring code coverage, continuing the steps above:
.. code-block:: shell
(venv) $ pip install coverage
(venv) $ DJANGO_SETTINGS_MODULE=tests.settings coverage run --source mozilla_django_oidc `which django-admin` test
(venv) $ coverage report
(venv) $ coverage html
(venv) $ open htmlcov/index.htmlLocal development
-----------------The local development setup is based on Docker so you need the following installed in your system:
* `docker`
* `docker-compose`You will also need to edit your ``hosts`` file to resolve ``testrp`` and ``testprovider`` hostnames to ``127.0.0.1``.
Running test services
=====================To run the `testrp` and `testprovider` instances run the following:
.. code-block:: shell
(venv) $ docker-compose up -d testprovider testrp
Then visit the testing django app on: ``http://testrp:8081``.
The library source code is mounted as a docker volume and source code changes are reflected directly in.
In order to test a change you need to restart the ``testrp`` service... code-block:: shell
(venv) $ docker-compose stop testrp
(venv) $ docker-compose up -d testrpRunning integration tests
=========================Integration tests are mounted as a volume to the docker containers. Tests can be run using the following command:
.. code-block:: shell
(venv) $ docker-compose run --service-ports testrunner
Linting
-------All code is checked with ``_ in
continuous integration. To make sure your code still passes all style guides
install ``flake8`` and check:.. code-block:: shell
$ flake8 mozilla_django_oidc tests
.. note::
When you run ``tox`` it also does a ``flake8`` run on the main package
files and the tests.You can also run linting with ``tox``:
.. code-block:: shell
$ tox -e lint
Finally you can use pre-commit hooks to run linting and formatting before you commit your code:
.. code-block:: shell
(venv) $ pre-commit install
Releasing a new version
------------------------``mozilla-django-oidc`` releases are hosted in `PyPI `_.
Here are the steps you need to follow in order to push a new release:* Make sure that ``HISTORY.rst`` is up-to-date focusing mostly on backwards incompatible changes.
Security vulnerabilities should be clearly marked in a "Security issues" section along with
a level indicator of:* High: vulnerability facilitates data loss, data access, impersonation of admin, or allows access
to other sites or componentsUsers should upgrade immediately.
* Medium: vulnerability endangers users by sending them to malicious sites or stealing browser
data.Users should upgrade immediately.
* Low: vulnerability is a nuissance to site staff and/or users
Users should upgrade.
* Bump the project version and create a commit for the new version.
* You can use ``bumpversion`` for that. It is a tool to automate this procedure following the `semantic versioning scheme `_.
* For a patch version update (eg 0.1.1 to 0.1.2) you can run ``bumpversion patch``.
* For a minor version update (eg 0.1.0 to 0.2.0) you can run ``bumpversion minor``.
* For a major version update (eg 0.1.0 to 1.0.0) you can run ``bumpversion major``.* Create a `signed tag `_ for that version
Example::
git tag -s 0.1.1 -m "Bump version: 0.1.0 to 0.1.1"
* Push the signed tag to Github
Example::
git push origin 0.1.1
The release is pushed automatically to PyPI using a travis deployment hook on every new tag.
License
-------This software is licensed under the MPL 2.0 license. For more info check the LICENSE file.
Credits
-------Tools used in rendering this package:
* Cookiecutter_
* `cookiecutter-djangopackage`_.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`cookiecutter-djangopackage`: https://github.com/pydanny/cookiecutter-djangopackage