Sha256: b08ed16e7c1dd62cea280e1d7f4bbca8acabe23236aae8e97c3c6bdda497e4a1

Contents?: true

Size: 1.45 KB

Versions: 2

Compression:

Stored size: 1.45 KB

Contents

if RUBY_ENGINE == 'jruby'
  require 'active_record/connection_adapters/jdbcpostgresql_adapter'
else
  require 'pg'
end

module ActiveRecord  # :nodoc:
  module ConnectionHandling  # :nodoc:

    if RUBY_ENGINE == 'jruby'

      def postgis_connection(config)
        config[:adapter_class] = ConnectionAdapters::PostGISAdapter
        postgresql_connection(config)
      end

      alias_method :jdbcpostgis_connection, :postgis_connection

    else

      # Based on the default <tt>postgresql_connection</tt> definition from ActiveRecord.
      # https://github.com/rails/rails/blob/master/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
      def postgis_connection(config)
        # FULL REPLACEMENT because we need to create a different class.
        conn_params = config.symbolize_keys

        conn_params.delete_if { |_, v| v.nil? }

        # Map ActiveRecords param names to PGs.
        conn_params[:user] = conn_params.delete(:username) if conn_params[:username]
        conn_params[:dbname] = conn_params.delete(:database) if conn_params[:database]

        # Forward only valid config params to PGconn.connect.
        conn_params.keep_if { |k, _| VALID_CONN_PARAMS.include?(k) }

        # The postgres drivers don't allow the creation of an unconnected PGconn object,
        # so just pass a nil connection object for the time being.
        ConnectionAdapters::PostGISAdapter.new(nil, logger, conn_params, config)
      end

    end

  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
activerecord-postgis-adapter-3.1.0 lib/active_record/connection_adapters/postgis/create_connection.rb
activerecord-postgis-adapter-3.0.0 lib/active_record/connection_adapters/postgis/create_connection.rb