Sha256: f22fbccaf04d2d1ac1d25edecc92ec382bc087a40e68045246649f4f28fab649
Contents?: true
Size: 1.61 KB
Versions: 2
Compression:
Stored size: 1.61 KB
Contents
module Rmega module Net include Loggable include Options def survive(retries = options.max_retries, &block) yield rescue ServerError raise rescue Exception => error retries -= 1 raise(error) if retries < 0 logger.debug("[#{error.class}] #{error.message}. #{retries} attempt(s) left.") sleep(options.retry_interval) retry end def http_get_content(url) uri = URI(url) req = ::Net::HTTP::Get.new(uri.request_uri) resp = net_http(uri).request(req) if resp.code.to_i == 509 and resp.body.to_s.empty? raise BandwidthLimitExceeded.new end return resp.body end def http_post(url, data) uri = URI(url) req = ::Net::HTTP::Post.new(uri.request_uri) req.body = data logger.debug("REQ POST #{url} #{cut_string(data)}") req['Connection'] = 'keep-alive' response = net_http(uri).request(req) logger.debug("REP #{response.code} #{cut_string(response.body)}") return response end private def net_http(uri) http = Rmega::ConnPool.get(uri) # apply common http options http.proxy_from_env = false if options.http_proxy_address options.marshal_dump.each do |name, value| setter_method = name.to_s.split('http_')[1] http.__send__("#{setter_method}=", value) if setter_method and value end return http end def cut_string(string, max = 50) return "<binary data, #{string.size} bytes>" if string.encoding == ::Encoding::ASCII_8BIT string.size <= max ? string : string[0..max-1]+"..." end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
rmega-0.3.2 | lib/rmega/net.rb |
rmega-0.3.1 | lib/rmega/net.rb |