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