module LaunchDarkly::Util
@private
Public Class Methods
http_error_message(status, context, recoverable_message)
click to toggle source
# File lib/ldclient-rb/util.rb, line 48 def self.http_error_message(status, context, recoverable_message) desc = (status == 401 || status == 403) ? " (invalid SDK key)" : "" message = Util.http_error_recoverable?(status) ? recoverable_message : "giving up permanently" "HTTP error #{status}#{desc} for #{context} - #{message}" end
http_error_recoverable?(status)
click to toggle source
# File lib/ldclient-rb/util.rb, line 40 def self.http_error_recoverable?(status) if status >= 400 && status < 500 status == 400 || status == 408 || status == 429 else true end end
log_exception(logger, message, exc)
click to toggle source
# File lib/ldclient-rb/util.rb, line 35 def self.log_exception(logger, message, exc) logger.error { "[LDClient] #{message}: #{exc.inspect}" } logger.debug { "[LDClient] Exception trace: #{exc.backtrace}" } end
new_http_client(uri_s, config)
click to toggle source
# File lib/ldclient-rb/util.rb, line 22 def self.new_http_client(uri_s, config) http_client_options = {} if config.socket_factory http_client_options["socket_class"] = config.socket_factory end return HTTP::Client.new(http_client_options) .timeout({ read: config.read_timeout, connect: config.connect_timeout }) .persistent(uri_s) end
stringify_attrs(hash, attrs)
click to toggle source
# File lib/ldclient-rb/util.rb, line 7 def self.stringify_attrs(hash, attrs) return hash if hash.nil? ret = hash changed = false attrs.each do |attr| value = hash[attr] if !value.nil? && !value.is_a?(String) ret = hash.clone if !changed ret[attr] = value.to_s changed = true end end ret end