Implement .call, since it seems like the “Rack-y” thing to do. Plus, it opens the door for cache key generators to just be blocks.
# File lib/rack/cache/key.rb, line 9 def self.call(request) new(request).generate end
# File lib/rack/cache/key.rb, line 13 def initialize(request) @request = request end
Generate a normalized cache key for the request.
# File lib/rack/cache/key.rb, line 18 def generate parts = [] parts << @request.scheme << "://" parts << @request.host if @request.scheme == "https" && @request.port != 443 || @request.scheme == "http" && @request.port != 80 parts << ":" << @request.port.to_s end parts << @request.script_name parts << @request.path_info if qs = query_string parts << "?" parts << qs end parts.join end
Build a normalized query string by alphabetizing all keys/values and applying consistent escaping.
# File lib/rack/cache/key.rb, line 42 def query_string return nil if @request.query_string.nil? @request.query_string.split(/[&;] */). map { |p| unescape(p).split('=', 2) }. sort. map { |k,v| "#{escape(k)}=#{escape(v)}" }. join('&') end