Sha256: 13fde83cfd48e5194875fb94fae938e717c5b00c816dc1c97a2a0759c66524ef

Contents?: true

Size: 1.36 KB

Versions: 4

Compression:

Stored size: 1.36 KB

Contents

module AutomaticForeignKey::ActiveRecord
  module Base
    def self.included(base) # :nodoc
      base.extend(ClassMethods)
    end

    module ClassMethods
      # Determines referenced table and column.
      # Used in migrations.
      #   references('comments', 'post_id') # => ['posts', 'id']
      #
      # If <tt>column_name</tt> is parent_id it references to the same table
      #   references('pages', 'parent_id')  # => ['pages', 'id']
      #
      # If referenced table cannot be determined properly it may be overriden
      #   references('widgets', 'main_page_id', :references => 'pages')) 
      #   # => ['pages', 'id']
      #
      # Also whole result may be given by hand
      #   references('addresses', 'member_id', :references => ['users', 'uuid'])
      #   # => ['users', 'uuid']
      def references(table_name, column_name, options = {})
        column_name = column_name.to_s
        if options.has_key?(:references)
          references = options[:references]
          references = [references, :id] unless references.nil? || references.is_a?(Array)
          references
        elsif column_name == 'parent_id'
          [table_name, :id]
        elsif column_name =~ /^(.*)_id$/
          determined_table_name = ActiveRecord::Base.pluralize_table_names ? $1.to_s.pluralize : $1
          [determined_table_name, :id]
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
automatic_foreign_key-1.3.0 lib/automatic_foreign_key/active_record/base.rb
automatic_foreign_key-1.2.0 lib/automatic_foreign_key/active_record/base.rb
automatic_foreign_key-1.1.8 lib/automatic_foreign_key/active_record/base.rb
automatic_foreign_key-1.1.7 lib/automatic_foreign_key/active_record/base.rb