Module: Sequel::Plugins::Sharding::ClassMethods

Defined in:
lib/sequel/plugins/sharding.rb

Instance Method Summary collapse

Instance Method Details

#create_using_server(s, values = {}, &block) ⇒ Object

Create a new object on the given shard s.



23
24
25
# File 'lib/sequel/plugins/sharding.rb', line 23

def create_using_server(s, values={}, &block)
  new_using_server(s, values, &block).save
end

#eager_load_results(opts, eo, &block) ⇒ Object

Eager load the association with the given eager loader options.



28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/sequel/plugins/sharding.rb', line 28

def eager_load_results(opts, eo, &block)
  if (s = eo[:self]) && (server = s.opts[:server])
    eb = eo[:eager_block]
    set_server = proc do |ds|
      ds = eb.call(ds) if eb
      ds = ds.server?(server)
      ds
    end
    eo = eo.merge(:eager_block=>set_server)
  end

  super
end

#new_using_server(s, values = {}, &block) ⇒ Object

Return a newly instantiated object that is tied to the given shard s. When the object is saved, a record will be inserted on shard s.



45
46
47
# File 'lib/sequel/plugins/sharding.rb', line 45

def new_using_server(s, values={}, &block)
  new(values, &block).set_server(s)
end