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)