module Onebox module Helpers def self.symbolize_keys(hash) return {} if hash.nil? hash.inject({}){|result, (key, value)| new_key = case key when String then key.to_sym else key end new_value = case value when Hash then symbolize_keys(value) else value end 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) if !uri.host uri = URI("#{domain}#{location}") end 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) cookie = response.get_fields('set-cookie') if (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='#{CGI.escapeHTML(meta[:title])}'" : "" end def self.normalize_url_for_output(url) url = url.dup # expect properly encoded url, remove any unsafe chars url.gsub!(/[^a-zA-Z0-9%\-`._~:\/?#\[\]@!$&'\(\)*+,;=]/, "") url.gsub!("'", """) url end end end