Class: Webmachine::MediaType

Inherits:
Object
  • Object
show all
Extended by:
Translation
Defined in:
lib/webmachine/media_type.rb

Overview

Encapsulates a MIME media type, with logic for matching types.

Constant Summary

MEDIA_TYPE_REGEX =

Matches valid media types

/^\s*([^;\s]+)\s*((?:;\s*\S+\s*)*)\s*$/
PARAMS_REGEX =

Matches sub-type parameters

/;\s*([^=]+)(=([^;=\s]*))?/

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Translation

t

Constructor Details

#initialize(type, params = {}) ⇒ MediaType



44
45
46
# File 'lib/webmachine/media_type.rb', line 44

def initialize(type, params={})
  @type, @params = type, params
end

Instance Attribute Details

#paramsHash



40
41
42
# File 'lib/webmachine/media_type.rb', line 40

def params
  @params
end

#typeString



37
38
39
# File 'lib/webmachine/media_type.rb', line 37

def type
  @type
end

Class Method Details

.parse(obj) ⇒ MediaType

Creates a new MediaType by parsing an alternate representation.

Raises:

  • (ArgumentError)

    when the type could not be parsed



18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/webmachine/media_type.rb', line 18

def self.parse(obj)
  case obj
  when MediaType
    obj
  when MEDIA_TYPE_REGEX
    type, raw_params = $1, $2
    params = Hash[raw_params.scan(PARAMS_REGEX).map { |m| [m[0], m[2].to_s] }]
    new(type, params)
  else
    unless Array === obj && String === obj[0] && Hash === obj[1]
      raise ArgumentError, t('invalid_media_type', :type => obj.inspect)
    end
    type = parse(obj[0])
    type.params.merge!(obj[1])
    type
  end
end

Instance Method Details

#==(other) ⇒ true, false

Returns Are these two types strictly equal?

See Also:



57
58
59
60
# File 'lib/webmachine/media_type.rb', line 57

def ==(other)
  other = self.class.parse(other)
  other.type == type && other.params == params
end

#exact_match?(other) ⇒ true, false

Detects whether this Webmachine::MediaType matches the other Webmachine::MediaType, taking into account wildcards. Sub-type parameters are treated strictly.



67
68
69
70
# File 'lib/webmachine/media_type.rb', line 67

def exact_match?(other)
  other = self.class.parse(other)
  type_matches?(other) && other.params == params
end

#majorString



99
100
101
# File 'lib/webmachine/media_type.rb', line 99

def major
  type.split("/").first
end

#match?(other) ⇒ true, false

Detects whether the Webmachine::MediaType is an acceptable match for the other Webmachine::MediaType, taking into account wildcards and satisfying all requested parameters, but allowing this type to have extra specificity.



78
79
80
81
# File 'lib/webmachine/media_type.rb', line 78

def match?(other)
  other = self.class.parse(other)
  type_matches?(other) && params_match?(other.params)
end

#matches_all?Boolean

Detects whether the Webmachine::MediaType represents an open wildcard type, that is, “/” without any #params.



50
51
52
# File 'lib/webmachine/media_type.rb', line 50

def matches_all?
  @type == "*/*" && @params.empty?
end

#minorString



104
105
106
# File 'lib/webmachine/media_type.rb', line 104

def minor
  type.split("/").last
end

#params_match?(other) ⇒ true, false

Detects whether the passed sub-type parameters are all satisfied by this Webmachine::MediaType. The receiver is allowed to have other params than the ones specified, but all specified must be equal.



88
89
90
# File 'lib/webmachine/media_type.rb', line 88

def params_match?(other)
  other.all? {|k,v| params[k] == v }
end

#to_sString

Reconstitutes the type into a String



94
95
96
# File 'lib/webmachine/media_type.rb', line 94

def to_s
  [type, *params.map {|k,v| "#{k}=#{v}" }].join(";")
end

#type_matches?(other) ⇒ true, false



111
112
113
114
115
116
117
118
# File 'lib/webmachine/media_type.rb', line 111

def type_matches?(other)
  other = self.class.parse(other)
  if ["*", "*/*", type].include?(other.type)
    true
  else
    other.major == major && other.minor == "*"
  end
end