Sha256: 50f4377480e0b217789003acd9ff5a351ba79f4eb950baadb48570e48937381c

Contents?: true

Size: 1.63 KB

Versions: 1

Compression:

Stored size: 1.63 KB

Contents

pp caller
module Coupler
  module Models
    class Connection < Sequel::Model
      include CommonModel

      ADAPTERS = [
        {
          :name => "mysql", :label => "MySQL",
          :ignored_attributes => %w{path}
        },
        {
          :name => "h2", :label => "H2",
          :ignored_attributes => %w{host port username password database_name}
        }
      ]

      one_to_many :resources

      def database(&block)
        Sequel.connect(connection_string, {
          :loggers => [Coupler::Logger.instance],
          :max_connections => 20
        }, &block)
      end

      def deletable?
        resources_dataset.count == 0
      end

      private
        def connection_string
          case adapter
          when 'mysql'
            misc = '&zeroDateTimeBehavior=convertToNull'
            "jdbc:mysql://%s:%d/%s?user=%s&password=%s%s" % [
              host, port, database_name, username, password, misc
            ]
          when 'h2'
            "jdbc:h2:#{path}"
          end
        end

        def before_validation
          super
          self.slug ||= name.downcase.gsub(/\s+/, "_") if name
        end

        def validate
          super
          validates_presence :name
          validates_unique :name, :slug

          begin
            database { |db| db.test_connection }
          rescue Sequel::DatabaseConnectionError, Sequel::DatabaseError => e
            errors.add(:base, "Couldn't connect to the database")
          end
        end

        def before_destroy
          super

          # Prevent destruction of connections in use by resources.
          deletable?
        end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
coupler-0.0.7-java lib/coupler/models/connection.rb