No commit activity in last 3 years
No release in over 3 years
Acts as Soft Delete by Field: Provides soft deletion for ActiveRecord models using a field to flag the datetime of deletion
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

>= 3.0.0
 Project Readme
Soft Delete By Field
===================

Provides mechanism for soft delete functionality. Soft delete means that on
delete, an object is flagged as deleted rather than being removed from the
database. This makes it far easier to recover objects that have
been deleted by mistake.

This soft delete mechanism uses a field in a models table, to flag and
record the date of deletion.

Requirements
------------
This plugin is designed for Rails 3. The syntax of the scope options
will not work with Rails 2.

The model object needs to have a datetime field, that on
delete will be set to the current time. By default, this field should
be :deleted_at, but you can also specify your own field.

Installation
------------
Add this to your Gemfile:

  gem "acts_as_soft_delete_by_field"

Usage
-----

  class Thing < ActiveRecord::Base

    acts_as_soft_delete_by_field

  end

If you wish to use a field other than :deleted_at, for example :soft_deleted_at,
you can do this via the acts_as_soft_delete_by_field declaration:

  class Thing < ActiveRecord::Base

    acts_as_soft_delete_by_field(:soft_deleted_at)

  end

Functionality
-------------
Adds 'extant' and 'deleted' scopes to the model. For example, if added
to a Thing model, would allow you to do the following:

     thing.soft_delete   ---- Soft deletes an instance of thing

     Thing.extant        ---- Finds all things that are not deleted
     Thing.deleted.count ---- Counts how many things have been deleted

     Thing.extant.find(
       :all,
       :conditions => ["colour = ?", 'red']
     )                   ---- Finds all extant things that have colour set as red

     Thing.extant.where(:colour => 'red')      ---- As above using where


Also if Box has_many things

     box.things.deleted ---- Finds all the deleted things in the box

Note that Thing's delete instance method is not effected by this functionality
so:

    thing.soft_delete  --- alters the thing instance to be flagged as deleted
    thing.delete       --- deletes the thing from the database.

If you want delete actions to soft_delete, overwrite delete:

  class Thing

    acts_as_soft_delete_by_field

    def delete
      soft_delete
    end

  end

Callbacks
---------

There are also two callback methods: before_soft_delete and after_soft_delete
Overwrite these methods in the model to use them. For example:

  class Thing
    acts_as_soft_delete_by_field

    def after_soft_delete
      puts "Thing soft deleted"
    end
  end

Now, when a thing is soft deleted, "Thing soft deleted" will printed be to the
console.

Testing
-------

A number of custom assertions are made available when this plugin is installed.
They are held in the module ActsAsSoftDeleteByFieldAssertions. In particular,
assert_soft_delete_working_for works through each of the assertions and can
be used as a test that soft deletion is working correctly on any model where
it is used.

   class ThingTest < ActiveSupport::TestCase

     def test_soft_delete
       assert_soft_delete_by_field_working_for(Thing.first)
     end

   end

Copyright (c) 2011 Rob Nichols, released under the MIT license