Sha256: 581410402da9904c8bee378dd9693633f7343a1acbde51902f05093adaadefd7
Contents?: true
Size: 1.83 KB
Versions: 2
Compression:
Stored size: 1.83 KB
Contents
module AcceptHeaders module Negotiatable class Error < StandardError; end class ParseError < Error; end attr_reader :list Q_PATTERN = /(?:\A|;)\s*(?<exists>qs*\=)\s*(?:(?<q>0\.\d{1,3}|[01])|(?:[^;]*))\s*(?:\z|;)/ def initialize(header) @list = parse(header) end def negotiate(supported) return nil if list.empty? supported = [*supported] # TODO: Maybe q=0 should be first by default when sorting rejects, acceptable = list.partition { |m| m.q == 0.0 } (rejects + acceptable).each do |part| supported.each do |support| if part.match(support) if part.q == 0.0 next else return [support, part] end end end end nil end def accept?(other) negotiate(other) ? true : false end def to_s list.join(',') end private def no_header raise NotImplementedError.new("#no_header is not implemented") end def parse_item(entry) raise NotImplementedError.new("#parse_item(entry) is not implemented") end def parse(header, &block) return no_header unless header header = header.dup header.sub!(/\A#{self.class::HEADER_PREFIX}\s*/, '') header.strip! return no_header if header.empty? list = [] header.split(',').each do |entry| begin item = parse_item(entry) next if item.nil? list << item rescue Error next end end list.sort! { |x,y| y <=> x } end def parse_q(header) q = 1 return q unless header q_match = Q_PATTERN.match(header) if q_match && q_match[:exists] if q_match[:q] q = q_match[:q] else q = 0.001 end end q end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
accept_headers-0.1.0 | lib/accept_headers/negotiatable.rb |
accept_headers-0.0.9 | lib/accept_headers/negotiatable.rb |