Sha256: b5d259b6ffb17f9e6eed2d18bf1e98f8752b26a5409e86969b84b5b06b7607c3
Contents?: true
Size: 1.91 KB
Versions: 3
Compression:
Stored size: 1.91 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)}") # if you don't use Net::Http#start it will not keep the socket open even if you set # the connection header BUT setting the connection header to 'keep-alive' its enough # to fool MEGA servers and don't let them reset your connection! 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 = ::Net::HTTP.new(uri.host, uri.port) http.use_ssl = true if uri.scheme == 'https' # 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
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
rmega-0.2.7 | lib/rmega/net.rb |
rmega-0.2.6 | lib/rmega/net.rb |
rmega-0.2.5 | lib/rmega/net.rb |