Sha256: c7ced40e9959cc8a4ad2c8b063dab1aab1fcb160fd4caf5f6c512a121cfbe627

Contents?: true

Size: 1.87 KB

Versions: 78

Compression:

Stored size: 1.87 KB

Contents

module CassandraObject

  module Tasks

    class Keyspace

      def self.parse(hash)
        ks = Cassandra::Keyspace.new.with_fields hash
        ks.cf_defs = []
        hash['cf_defs'].each do |cf|
          ks.cf_defs << Cassandra::ColumnFamily.new.with_fields(cf)
        end
        ks
      end

      def exists?(name)
        connection.keyspaces.include? name.to_s
      end

      def create(name, options = {})
        opts = { :name => name.to_s,
                 :strategy_class => 'org.apache.cassandra.locator.LocalStrategy',
                 :replication_factor => 1,
                 :cf_defs => [] }.merge(options)

        ks = Cassandra::Keyspace.new.with_fields(opts)
        connection.add_keyspace ks
      end

      def drop(name)
        connection.drop_keyspace name.to_s
      end

      def set(name)
        connection.keyspace = name.to_s
      end

      def get
        connection.keyspace
      end

      def clear
        return puts 'Cannot clear system keyspace' if connection.keyspace == 'system'

        connection.clear_keyspace!
      end

      def schema_dump
        connection.schema
      end

      def schema_load(schema)
        connection.schema.cf_defs.each do |cf|
          connection.drop_column_family cf.name
        end

        keyspace = get
        schema.cf_defs.each do |cf|
          cf.keyspace = keyspace
          connection.add_column_family cf
        end
      end

      private

      def connection
        unless @connection
          c = CassandraObject::Base.connection
          @connection = Cassandra.new('system', c.servers, c.thrift_client_options)
        end
        @connection
      end

    end

  end

end

class Cassandra
  class Keyspace
    def with_fields(options)
      struct_fields.collect { |f| f[1][:name] }.each do |f|
        send("#{f}=", options[f.to_sym] || options[f.to_s])
      end
      self
    end
  end
end

Version data entries

78 entries across 78 versions & 2 rubygems

Version Path
sessionm-cassandra_object-2.2.37 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.36 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.35 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.34 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.33 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.32 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.31 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.30 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.29 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.11 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.28 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.10 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.9 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.27 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.8 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.7 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.6 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.5 lib/cassandra_object/tasks/keyspace.rb
gotime-cassandra_object-2.7.4 lib/cassandra_object/tasks/keyspace.rb
sessionm-cassandra_object-2.2.26 lib/cassandra_object/tasks/keyspace.rb