Module: ConcernsOnRails::Models::SoftDeletable

Extended by:
ActiveSupport::Concern
Defined in:
lib/concerns_on_rails/models/soft_deletable.rb

Instance Method Summary collapse

Instance Method Details

#after_restoreObject



81
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 81

def after_restore; end

#after_soft_deleteObject



79
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 79

def after_soft_delete; end

#before_restoreObject



80
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 80

def before_restore; end

#before_soft_deleteObject

Soft delete hooks



78
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 78

def before_soft_delete; end

#deleted?Boolean Also known as: is_soft_deleted?, soft_deleted?

Returns:

  • (Boolean)


123
124
125
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 123

def deleted?
  self[self.class.soft_delete_field].present?
end

#is_really_deleted?Boolean

Returns:

  • (Boolean)


132
133
134
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 132

def is_really_deleted?
  !self.class.unscoped.exists?(id)
end

#really_delete!Object

bypasses AR callbacks and validations — use when you want a true hard delete



118
119
120
121
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 118

def really_delete!
  self.class.unscoped.where(self.class.primary_key => id).delete_all
  freeze
end

#restore!Object



101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 101

def restore!
  return true unless deleted?

  result = false
  transaction do
    before_restore
    result = if self.class.soft_delete_touch
               update(self.class.soft_delete_field => nil)
             else
               update_column(self.class.soft_delete_field, nil)
             end
    after_restore if result
  end
  result
end

#soft_delete!Object



83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# File 'lib/concerns_on_rails/models/soft_deletable.rb', line 83

def soft_delete!
  return true if deleted?

  result = false
  # Wrap the timestamp change and its hooks in a transaction so a raising
  # before/after hook rolls the change back instead of leaving a half-applied state.
  transaction do
    before_soft_delete
    result = if self.class.soft_delete_touch
               update(self.class.soft_delete_field => Time.zone.now)
             else
               update_column(self.class.soft_delete_field, Time.zone.now)
             end
    after_soft_delete if result
  end
  result
end