Class: Octopus::RelationProxy
Instance Attribute Summary collapse
#current_shard
Instance Method Summary
collapse
included, #set_current_shard
Constructor Details
#initialize(shard, ar_relation) ⇒ RelationProxy
Returns a new instance of RelationProxy.
7
8
9
10
|
# File 'lib/octopus/relation_proxy.rb', line 7
def initialize(shard, ar_relation)
@current_shard = shard
@ar_relation = ar_relation
end
|
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method, *args, &block) ⇒ Object
12
13
14
|
# File 'lib/octopus/relation_proxy.rb', line 12
def method_missing(method, *args, &block)
run_on_shard { @ar_relation.send(method, *args, &block) }
end
|
Instance Attribute Details
#ar_relation ⇒ Object
Returns the value of attribute ar_relation.
5
6
7
|
# File 'lib/octopus/relation_proxy.rb', line 5
def ar_relation
@ar_relation
end
|
Instance Method Details
#==(other) ⇒ Object
Also known as:
eql?
34
35
36
37
38
39
40
41
|
# File 'lib/octopus/relation_proxy.rb', line 34
def ==(other)
case other
when Octopus::RelationProxy
method_missing(:==, other.ar_relation)
else
method_missing(:==, other)
end
end
|
#as_json(options = nil) ⇒ Object
30
31
32
|
# File 'lib/octopus/relation_proxy.rb', line 30
def as_json(options = nil)
method_missing(:as_json, options)
end
|
#inspect ⇒ Object
26
27
28
|
# File 'lib/octopus/relation_proxy.rb', line 26
def inspect
method_missing(:inspect)
end
|
#respond_to?(*args) ⇒ Boolean
16
17
18
|
# File 'lib/octopus/relation_proxy.rb', line 16
def respond_to?(*args)
super || @ar_relation.respond_to?(*args)
end
|
#select(*args, &block) ⇒ Object
these methods are not normally sent to method_missing
22
23
24
|
# File 'lib/octopus/relation_proxy.rb', line 22
def select(*args, &block)
method_missing(:select, *args, &block)
end
|