Metadata-Version: 2.1
Name: django-anonymizable-model
Version: 0.1.8
Summary: Your project description goes here
Home-page: https://github.com/frankhood/django-anonymizable-model
Author: FrankHood Business Solutions srl
Author-email: info@frankhood.it
License: MIT
Keywords: django-anonymizable-model
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Framework :: Django :: 2.2
Classifier: Framework :: Django :: 3.2
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
License-File: LICENSE
License-File: AUTHORS.rst

=============================
Django Anonymizable Model
=============================

.. image:: https://badge.fury.io/py/django-anonymizable-model.svg/?style=flat-square
    :target: https://badge.fury.io/py/django-anonymizable-model

.. image:: https://readthedocs.org/projects/pip/badge/?version=latest&style=flat-square
    :target: https://django-anonymizable-model.readthedocs.io/en/latest/

.. image:: https://img.shields.io/coveralls/github/frankhood/django-anonymizable-model/master?style=flat-square
    :target: https://coveralls.io/github/frankhood/django-anonymizable-model?branch=master
    :alt: Coverage Status

Your project description goes here

Documentation
-------------

The full documentation is at https://django-anonymizable-model.readthedocs.io.

Quickstart
----------

Install django-anonymizable-model::

    pip install django-anonymizable-model

Add it to your `INSTALLED_APPS`::

    INSTALLED_APPS = (
        ...
        'anonymizable_model',
        ...
    )

Use on your models like this::

    @anonymizable(
        db_label_prefix="pa_",
        anonymizable_fields=["first_name", "last_name", "phone_number"]
    )
    class ExampleGDPRModel(models.Model):
        objects = ExampleGDPRModelManager.from_queryset(ExampleGDPRModelQuerySet)()

        first_name = models.CharField("First name", max_length=255)
        last_name = models.CharField("Last name", max_length=255)
        phone_number = models.CharField("Phone number", max_length=255, blank=True, default="")
        description = models.TextField("Description", blank=True, default="")

It is possible to change db_label_prefix with your own label
and assign anonymizable fields from the model for export and visualization features.

And then run migrations::

    $ python manage.py makemigrations
    $ python manage.py migrate

For the admin visualization use AnonymizableAdminMixin class::

    @admin.register(ExampleGDPRModel)
    class ExampleGDPRModelAdmin(AnonymizableAdminMixin, admin.ModelAdmin):
        list_display = (
            "__str__",
            "first_name",
            "last_name",
            "phone_number",
            "description",
        )

        fieldsets = (
            (None, {"fields": (
                ("first_name", "last_name"),
                ("phone_number", "description"),
            )}),
        )

The admin can view all anonymized data in fields. If a staff user does not have can_view_anonymized_fields permission
all the data in anonymizable_fields will be substituted with "...".


Anonymize DATABASE
------------------

It is possible to anonymize data directly in database using::

    $ python manage.py anonymize_database



Features
--------

* Remove or override __str__ method to display "..." if user does not have permission

Running Tests
-------------

Does the code actually work?

::

    source <YOURVIRTUALENV>/bin/activate
    (myenv) $ pip install tox
    (myenv) $ tox


Development commands
---------------------

::

    pip install -r requirements_dev.txt
    invoke -l


Credits
-------

Tools used in rendering this package:

*  Cookiecutter_
*  `cookiecutter-djangopackage`_

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




History
-------

0.1.7 (2021-10-11)
++++++++++++++++++

* First release on PyPI.


0.1.8 (2021-10-12)
++++++++++++++++++

* Updated version for github actions


