Encapsulates the notion of a MIME type. Can be used at render time, for example, with:
class PostsController < ActionController::Base def show @post = Post.find(params[:id]) respond_to do |format| format.html format.ics { render body: @post.to_ics, mime_type: Mime::Type.lookup("text/calendar") } format.xml { render xml: @post } end end end
Namespace
    
  
  
    
    Methods
    - #
- A
- E
- H
- L
- M
- N
- P
- R
- T
- U
Constants
| ACCEPT_HEADER_REGEXP | = | /[^,\s"](?:[^,"]|"[^"]*")*/ | 
| MIME_NAME | = | "[a-zA-Z0-9][a-zA-Z0-9#{Regexp.escape('!#$&-^_.+')}]{0,126}" | 
| MIME_PARAMETER | = | "\s*;\s*#{MIME_NAME}(?:=#{MIME_PARAMETER_VALUE})?" | 
| MIME_PARAMETER_VALUE | = | "(?:#{MIME_NAME}|\"[^\"\r\\\\]*\")" | 
| MIME_REGEXP | = | /\A(?:\*\/\*|#{MIME_NAME}\/(?:\*|#{MIME_NAME})(?>#{MIME_PARAMETER})*\s*)\z/ | 
| PARAMETER_SEPARATOR_REGEXP | = | /;\s*q="?/ | 
| all media-type parameters need to be before the q-parameter www.rfc-editor.org/rfc/rfc7231#section-5.3.2 | ||
| TRAILING_STAR_REGEXP | = | /^(text|application)\/\*/ | 
Attributes
| [R] | hash | |
| [R] | string | |
| [R] | symbol | |
| [R] | synonyms | 
Class Public methods
lookup(string) Link
# File actionpack/lib/action_dispatch/http/mime_type.rb, line 167 def lookup(string) return LOOKUP[string] if LOOKUP.key?(string) # fallback to the media-type without parameters if it was not found string = string.split(";", 2)[0]&.rstrip LOOKUP[string] || Type.new(string) end
lookup_by_extension(extension) Link
new(string, symbol = nil, synonyms = []) Link
# File actionpack/lib/action_dispatch/http/mime_type.rb, line 264 def initialize(string, symbol = nil, synonyms = []) unless MIME_REGEXP.match?(string) raise InvalidMimeType, "#{string.inspect} is not a valid MIME type" end @symbol, @synonyms = symbol, synonyms @string = string @hash = [@string, @synonyms, @symbol].hash end
parse(accept_header) Link
# File actionpack/lib/action_dispatch/http/mime_type.rb, line 200 def parse(accept_header) if !accept_header.include?(",") if (index = accept_header.index(PARAMETER_SEPARATOR_REGEXP)) accept_header = accept_header[0, index].strip end return [] if accept_header.blank? parse_trailing_star(accept_header) || Array(Mime::Type.lookup(accept_header)) else list, index = [], 0 accept_header.scan(ACCEPT_HEADER_REGEXP).each do |header| params, q = header.split(PARAMETER_SEPARATOR_REGEXP) next unless params params.strip! next if params.empty? params = parse_trailing_star(params) || [params] params.each do |m| list << AcceptItem.new(index, m.to_s, q) index += 1 end end AcceptList.sort! list end end
parse_data_with_trailing_star(type) Link
For an input of 'text', returns [Mime[:json], Mime[:xml], Mime[:ics], Mime[:html], Mime[:css], Mime[:csv], Mime[:js], Mime[:yaml], Mime[:text]].
For an input of 'application', returns [Mime[:html], Mime[:js], Mime[:xml], Mime[:yaml], Mime[:atom], Mime[:json], Mime[:rss], Mime[:url_encoded_form]].
parse_trailing_star(accept_header) Link
register(string, symbol, mime_type_synonyms = [], extension_synonyms = [], skip_lookup = false) Link
# File actionpack/lib/action_dispatch/http/mime_type.rb, line 186 def register(string, symbol, mime_type_synonyms = [], extension_synonyms = [], skip_lookup = false) new_mime = Type.new(string, symbol, mime_type_synonyms) SET << new_mime ([string] + mime_type_synonyms).each { |str| LOOKUP[str] = new_mime } unless skip_lookup ([symbol] + extension_synonyms).each { |ext| EXTENSION_LOOKUP[ext.to_s] = new_mime } @register_callbacks.each do |callback| callback.call(new_mime) end new_mime end
register_alias(string, symbol, extension_synonyms = []) Link
Registers an alias that’s not used on MIME type lookup, but can be referenced directly. Especially useful for rendering different HTML versions depending on the user agent, like an iPhone.
register_callback(&block) Link
unregister(symbol) Link
This method is opposite of register method.
To unregister a MIME type:
Mime::Type.unregister(:mobile)