Skip to content

Provides a model mixin to allow objects to be "trashed" before finally deleted.

Notifications You must be signed in to change notification settings

bitniftee/django-undelete

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 

Repository files navigation

django-undelete

UnDelete is a simple project that gives you access to a TrashableMixin meta model and some useful managers as well.

Much of the work is heavily derivative of Nathan Ostgard's post on the same topic.

Installation

In three easy steps!

  1. Place 'undelete' in your installed apps.

  2. Add:

     from undelete.models import TrashableMixin
    
  3. Make sure your model inherits the mixin:

     class YourMode(TrashableMixin): ...
    

And you're done. You should now be able to query trashed items with the "trash" manager and non-trashed items with the usual objects manager.

You can now install django-undelete using pip, for example:

    pip install git+https://github.com/cpbotha/django-undelete.git

See the section below for a more through explanation.

Usage

With the steps above taken, managing trashed items is fairly straightforward:

>>> YourModel.objects.count()
10
>>> YourModel.trash.count()
0
>>> obj = YourModel.objects.get(pk=1)
>>> obj
< YourModel: u'Test object' >
>>> obj.delete()
>>> obj
< YourModel: u'Test object (trashed)' >
>>> YourModel.objects.count()
9
>>> YourModel.trash.count()
1
>>> obj.restore()
>>> obj
< YourModel: u'Test object' >
# Call delete twice and she's gone...
>>> obj.delete()
>>> obj.delete()
# You can also skip the trash entierely
>>> obj = YourModel.objects.get(pk=1)
>>> obj.delete(trash=False)

Future plans also call for a management command to delete everything trashed a certain period of time ago. Stay tuned!

Changelist from v0.0.0 to v1.0.0

  • Implemented TrashableQuerySet so that also bulk deletes of QuerySets will trigger the special TrashableMixin delete() for soft deletion.
  • Created setup.py file so that this can be easily installed with pip or easy_install.
  • Number of smaller code fixes.

About

Provides a model mixin to allow objects to be "trashed" before finally deleted.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%