Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xrmx/django-denis
Denis helps you recovering accidentally deleted data from a django project
https://github.com/xrmx/django-denis
Last synced: about 1 month ago
JSON representation
Denis helps you recovering accidentally deleted data from a django project
- Host: GitHub
- URL: https://github.com/xrmx/django-denis
- Owner: xrmx
- License: mit
- Created: 2015-09-21T16:19:46.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2019-05-27T15:19:35.000Z (over 5 years ago)
- Last Synced: 2024-10-14T12:21:37.398Z (about 1 month ago)
- Language: Python
- Homepage:
- Size: 33.2 KB
- Stars: 10
- Watchers: 3
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
django-denis
==============.. image:: https://travis-ci.org/xrmx/django-denis.svg
:target: https://travis-ci.org/xrmx/django-denisDenis helps you recovering accidentally deleted data from a django project.
Rationale
---------Humans make mistakes, sometimes they delete data accidentally from the ``django admin``
and you have to spend your afternoon recovering data from a db dump. Sometimes the human
is called Denis.Requirements
------------- Django >= ``1.6``
Installation
------------- ``pip install django-denis``
Usage
-----Given a queryset ``django-denis`` finds what the django admin would delete and recover
them from a backup database.Here's an example session:
::
$ python manage.py shell
>>> from denis import Denis
>>> from django.contrib.auth.models import User
>>> User.objects.filter(pk=40182)
[]
>>> qs = User.objects.using('backup').filter(pk=40182)
>>> denis = Denis(qs, using='backup')
>>> denis.recover(using='default')
>>> User.objects.using('default').filter(pk=40182)
The code above assumes a configuration entry called ``backup`` for ``DATABASES`` in ``settings.py``
that should point to a database containing the data you want to recover.Be cautious
-----------Please always test (and test again) recovery on a copy of your database so you can double check
that everything works fine before doing it on your production db.Of course we don't take any responsibility with this code. Use at your own risk!