Sha256: 1a9551a6aaa90091a1101598ebd62a83e20487e4c838e72d4130aaa334f39fc3

Contents?: true

Size: 1.61 KB

Versions: 8

Compression:

Stored size: 1.61 KB

Contents

module Octopus
  module ShardTracking
    def self.included(base)
      base.extend(ClassMethods)
    end

    module ClassMethods
      # If the class which includes this module responds to the class
      # method sharded_methods, then automagically alias_method_chain
      # a sharding-friendly version of each of those methods into existence
      def sharded_methods(*methods)
        methods.each { |m| create_sharded_method(m) }
      end

      def create_sharded_method(name)
        name.to_s =~ /([^!?]+)([!?])?/
        method, punctuation = [Regexp.last_match[1], Regexp.last_match[2]]
        with = :"#{method}_with_octopus#{punctuation}"
        without = :"#{method}_without_octopus#{punctuation}"
        define_method with do |*args, &block|
          run_on_shard { send(without, *args, &block) }
        end
        alias_method without.to_sym, name.to_sym
        alias_method name.to_sym, with.to_sym
      end
    end

    # Adds run_on_shard method, but does not implement current_shard method
    def run_on_shard(&block)
      if (cs = current_shard)
        r = ActiveRecord::Base.connection_proxy.run_queries_on_shard(cs, &block)
        # Use a case statement to avoid any path through ActiveRecord::Delegation's
        # respond_to? code. We want to avoid the respond_to? code because it can have
        # the side effect of causing a call to load_target

        if (ActiveRecord::Relation === r || ActiveRecord::QueryMethods::WhereChain === r) && !(Octopus::RelationProxy === r)
          Octopus::RelationProxy.new(cs, r)
        else
          r
        end
      else
        yield
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 3 rubygems

Version Path
ar-octopus-ruby-3-0.11.3 lib/octopus/shard_tracking.rb
ar-octopus-ruby-3-0.11.2 lib/octopus/shard_tracking.rb
ar-octopus-0.10.2 lib/octopus/shard_tracking.rb
ar-octopus-0.10.1 lib/octopus/shard_tracking.rb
ar-octopus-0.10.0 lib/octopus/shard_tracking.rb
ar-octopus-master-0.9.2.1 lib/octopus/shard_tracking.rb
ar-octopus-0.9.2 lib/octopus/shard_tracking.rb
ar-octopus-0.9.1 lib/octopus/shard_tracking.rb