module Onebox module Helpers def self.symbolize_keys(hash) return {} if hash.nil? hash.inject({}){|result, (key, value)| new_key = key.is_a?(String) ? key.to_sym : key new_value = value.is_a?(Hash) ? symbolize_keys(value) : value result[new_key] = new_value result } end def self.clean(html) html.gsub(/<[^>]+>/, ' ').gsub(/\n/, '') end def self.fetch_response(location, limit = 5, domain = nil, headers = nil) raise Net::HTTPError.new('HTTP redirect too deep', location) if limit == 0 uri = URI(location) uri = URI("#{domain}#{location}") if !uri.host http = Net::HTTP.new(uri.host, uri.port) http.open_timeout = Onebox.options.connect_timeout http.read_timeout = Onebox.options.timeout if uri.is_a?(URI::HTTPS) http.use_ssl = true http.verify_mode = OpenSSL::SSL::VERIFY_NONE end response = http.request_get(uri.request_uri,headers) if cookie = response.get_fields('set-cookie') header = { 'cookie' => cookie.join } end header = nil unless header.is_a? Hash case response when Net::HTTPSuccess then response when Net::HTTPRedirection then fetch_response(response['location'], limit - 1, "#{uri.scheme}://#{uri.host}",header) else response.error! end end def self.click_to_scroll_div(width = 690, height = 400) "
" end def self.blank?(value) if value.respond_to?(:blank?) value.blank? else value.respond_to?(:empty?) ? !!value.empty? : !value end end def self.truncate(string, length = 50) string.size > length ? string[0...(string.rindex(" ", length)||length)] + "..." : string end def self.title_attr(meta) (meta && !blank?(meta[:title])) ? "title='#{meta[:title]}'" : "" end def self.normalize_url_for_output(url) return "" unless url url = url.dup # expect properly encoded url, remove any unsafe chars url.gsub!("'", "'") url.gsub!('"', """) url.gsub!(/[^\w\-`._~:\/?#\[\]@!$&'\(\)*+,;=]/, "") url end end end