module Sequel::Plugins::InputTransformer

  1. lib/sequel/plugins/input_transformer.rb

InputTransformer is a plugin that allows generic transformations of input values in model column setters. Example:

Album.plugin :input_transformer
Album.add_input_transformer(:reverser){|v| v.is_a?(String) ? v.reverse : v}
album = Album.new(name: 'foo')
album.name # => 'oof'

You can specifically set some columns to skip some input input transformers:

Album.skip_input_transformer(:reverser, :foo)
Album.new(foo: 'bar').foo # => 'bar'

Usage:

# Make all model subclass instances support input transformers (called before loading subclasses)
Sequel::Model.plugin :input_transformer

# Make the Album class support input transformers
Album.plugin :input_transformer

Methods

Public Class

  1. apply
  2. configure

Public Class methods

apply(model, *, &_)
[show source]
   # File lib/sequel/plugins/input_transformer.rb
27 def self.apply(model, *, &_)
28   model.instance_exec do
29     @input_transformers = {}
30     @skip_input_transformer_columns = {}
31   end
32 end
configure(model, transformer_name=nil, &block)

If an input transformer is given in the plugin call, add it as a transformer

[show source]
   # File lib/sequel/plugins/input_transformer.rb
36 def self.configure(model, transformer_name=nil, &block)
37   model.add_input_transformer(transformer_name, &block) if transformer_name || block
38 end