Repository is archived
No commit activity in last 3 years
No release in over 3 years
Model plugin making it easy to define callbacks on modification of specific attributes in the database
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 0
~> 10.0
~> 2.12

Runtime

< 5.0, >= 3.44
 Project Readme

Sequel::AttributeCallbacks

This plugin for Sequel::Record allows to easily hook in callbacks watching specific model attribute changes. The hooks are defined with conventionally named instance methods for maximum DRYness.

There's special support for callbacks involving array fields (as in Postgres array types with :pg_array extension) and hashes (HStore), so that they can be used similarly to associations, with add and remove callbacks.

Installation

Add this line to your application's Gemfile:

gem 'sequel-attribute_callbacks'

And then execute:

$ bundle

Or install it yourself as:

$ gem install sequel-attribute_callbacks

Synopsis

# people table has (name text) column
class Person < Sequel::Model
  plugin :attribute_callbacks
  
  def before_name_change old, new_name
    return true unless Dictionary.is_offensive? new_name
  end
  
  def after_name_change old, new
    NameChangeRecord.create self.id, old, new
  end
end

Special support for arrays (with pg_array extension):

# widgets table has (colors text[]) column
class Widget < Sequel::Model
  plugin :attribute_callbacks
  
  def before_colors_add color
    return false unless Paint.color_available? color
  end
  
  def after_colors_add color
    Paint.order color
  end
  
  def before_colors_remove color
    # this is our company color, we need it!
    return true unless color == 'fuchsia'
  end
  
  def after_colors_remove color
    Paint.reduce_consumption color
  end
end

Special support for hashes (with pg_hstore extension):

# robots table has (parts hstore) column
class Robot < Sequel::Model
  plugin :attribute_callbacks
  
  def before_parts_add place, part
    return false unless Part[part].fits_in? place
  end
  
  def after_parts_add place, part
    Part.order part
  end
  
  def before_parts_remove place, part
    # if you want a different skeleton go make a new robot
    return true unless place == 'skeleton'
  end
  
  def after_parts_remove place, part
    Part.reduce_consumption part
  end
end

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request