Sha256: 3bb3eab981b0de8e9ba5dc4528119733e1f1fdb9bb34e2304b150ae141567b30

Contents?: true

Size: 1.14 KB

Versions: 3

Compression:

Stored size: 1.14 KB

Contents

require 'redis_failover/errors'

module RedisFailover
  # Common utiilty methods.
  module Util
    extend self

    DEFAULT_ZNODE_PATH = '/redis_failover_nodes'.freeze
    REDIS_ERRORS = Errno.constants.map { |c| Errno.const_get(c) }.freeze
    CONNECTIVITY_ERRORS = [
      RedisFailover::Error,
      ZK::Exceptions::KeeperException,
      ZookeeperExceptions::ZookeeperException,
      REDIS_ERRORS].flatten.freeze

    def symbolize_keys(hash)
      Hash[hash.map { |k, v| [k.to_sym, v] }]
    end

    def different?(ary_a, ary_b)
      ((ary_a | ary_b) - (ary_a & ary_b)).size > 0
    end

    def self.logger
      @logger ||= begin
        logger = Logger.new(STDOUT)
        logger.level = Logger::INFO
        logger.formatter = proc do |severity, datetime, progname, msg|
          "#{datetime.utc} RedisFailover #{Process.pid} #{severity}: #{msg}\n"
        end
        logger
      end
    end

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

    def logger
      Util.logger
    end

    def encode(data)
      MultiJson.encode(data)
    end

    def decode(data)
      return unless data
      MultiJson.decode(data)
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
redis_failover-0.5.4 lib/redis_failover/util.rb
redis_failover-0.5.3 lib/redis_failover/util.rb
redis_failover-0.5.2 lib/redis_failover/util.rb