class RuboCop::RemoteConfig

Common methods and behaviors for dealing with remote config files.

def cache_name_from_uri

def cache_name_from_uri
  uri = @uri.clone
  uri.query = nil
  uri.to_s.gsub!(/[^0-9A-Za-z]/, '-')
end

def cache_path

def cache_path
  File.expand_path(".rubocop-#{cache_name_from_uri}", @base_dir)
end

def cache_path_exists?

def cache_path_exists?
  @cache_path_exists ||= File.exist?(cache_path)
end

def cache_path_expired?

def cache_path_expired?
  return true unless cache_path_exists?
  @cache_path_expired ||= begin
    file_age = (Time.now - File.stat(cache_path).mtime).to_f
    (file_age / CACHE_LIFETIME) > 1
  end
end

def file

def file
  return cache_path unless cache_path_expired?
  request do |response|
    next if response.is_a?(Net::HTTPNotModified)
    next if response.is_a?(SocketError)
    open cache_path, 'w' do |io|
      io.write response.body
    end
  end
  cache_path
end

def handle_response(response, limit, &block)

def handle_response(response, limit, &block)
  case response
  when Net::HTTPSuccess, Net::HTTPNotModified, SocketError
    yield response
  when Net::HTTPRedirection
    request(URI.parse(response['location']), limit - 1, &block)
  else
    response.error!
  end
end

def initialize(url, base_dir)

def initialize(url, base_dir)
  @uri = URI.parse(url)
  @base_dir = base_dir
end

def request(uri = @uri, limit = 10, &block)

def request(uri = @uri, limit = 10, &block)
  raise ArgumentError, 'HTTP redirect too deep' if limit.zero?
  http = Net::HTTP.new(uri.hostname, uri.port)
  http.use_ssl = true if uri.instance_of? URI::HTTPS
  request = Net::HTTP::Get.new(uri.request_uri)
  if cache_path_exists?
    request['If-Modified-Since'] = File.stat(cache_path).mtime.rfc2822
  end
  handle_response(http.request(request), limit, &block)
rescue SocketError => err
  handle_response(err, limit, &block)
end