Sha256: 068a62a7933e516976b19d3e921b72f145c09681d9e96a508ee30ab1cd14d425

Contents?: true

Size: 1.6 KB

Versions: 2

Compression:

Stored size: 1.6 KB

Contents

require "riak"

require "rico/object"
require "rico/collection"

require "rico/value"

require "rico/array"
require "rico/list"
require "rico/set"
require "rico/sorted_set"

require "rico/map"
require "rico/sorted_map"
require "rico/capped_sorted_map"

require "rico/resolver"

require "rico/version"

module Rico

  TYPES = {
    "Array" => "array",
    "List" => "list",
    "Map" => "map",
    "Set" => "set",
    "SortedSet" => "sset",
    "SortedMap" => "smap",
    "Value" => "value"
  }

  def self.configure
    yield self if block_given?
  end

  def self.bucket(key)
    namespaced_key = [@namespace, key].flatten.select(&:present?).join(":")
    @bucket_cache ||= {}
    @bucket_cache[namespaced_key] ||= riak.bucket(namespaced_key)
  end

  def self.namespace
    @namespace
  end

  def self.namespace=(namespace)
    @namespace = namespace
  end

  def self.options
    @options || {}
  end

  def self.options=(options)
    @options = options
  end

  def self.riak
    Thread.current[:riak] ||= Riak::Client.new(options)
  end
end

module Riak
  module Serializers
    module ApplicationXGZIP
      extend self

      def dump(object)
        json = ApplicationJSON.dump(object)
        io = StringIO.new
        gz = Zlib::GzipWriter.new(io)
        gz.write(json)
        gz.close

        io.string
      end

      def load(string)
        io = StringIO.new(string)
        gz = Zlib::GzipReader.new(io)
        json = gz.read
        gz.close

        ApplicationJSON.load(json)
      end
    end

    Serializers['application/x-gzip'] = ApplicationXGZIP
  end
end

Riak::RObject.on_conflict(&Rico::Resolver.to_proc)

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
rico-0.4.0 lib/rico.rb
rico-0.3.0 lib/rico.rb