Class: HTTPotato::Parser Abstract

Inherits:
Object
  • Object
show all
Defined in:
lib/httpotato/parser.rb

Overview

This class is abstract.

Read the Custom Parsers section for more information.

The default parser used by HTTPotato, supports xml, json, html, yaml, and plain text.

Custom Parsers

If you’d like to do your own custom parsing, subclassing HTTPotato::Parser will make that process much easier. There are a few different ways you can utilize HTTPotato::Parser as a superclass.

Examples:

Intercept the parsing for all formats

class SimpleParser < HTTPotato::Parser
  def parse
    perform_parsing
  end
end

Add the atom format and parsing method to the default parser

class AtomParsingIncluded < HTTPotato::Parser
  SupportedFormats.merge!(
    {"application/atom+xml" => :atom}
  )

  def atom
    perform_atom_parsing
  end
end

Only support the atom format

class ParseOnlyAtom < HTTPotato::Parser
  SupportedFormats = {"application/atom+xml" => :atom}

  def atom
    perform_atom_parsing
  end
end

Constant Summary collapse

SupportedFormats =
{
  'text/xml'               => :xml,
  'application/xml'        => :xml,
  'application/json'       => :json,
  'text/json'              => :json,
  'application/javascript' => :json,
  'text/javascript'        => :json,
  'text/html'              => :html,
  'application/x-yaml'     => :yaml,
  'text/yaml'              => :yaml,
  'text/plain'             => :plain
}

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(body, format) ⇒ Parser

Returns a new instance of Parser.



93
94
95
96
# File 'lib/httpotato/parser.rb', line 93

def initialize(body, format)
  @body = body
  @format = format
end

Instance Attribute Details

#bodyString (readonly)

The response body of the request

Returns:

  • (String)


56
57
58
# File 'lib/httpotato/parser.rb', line 56

def body
  @body
end

#formatSymbol (readonly)

The intended parsing format for the request

Returns:

  • (Symbol)

    e.g. :json



60
61
62
# File 'lib/httpotato/parser.rb', line 60

def format
  @format
end

Class Method Details

.call(body, format) ⇒ Object

Instantiate the parser and call #parse.

Parameters:

  • body (String)

    the response body

  • format (Symbol)

    the response format

Returns:

  • parsed response



66
67
68
# File 'lib/httpotato/parser.rb', line 66

def self.call(body, format)
  new(body, format).parse
end

.format_from_mimetype(mimetype) ⇒ Symbol?

Parameters:

  • mimetype (String)

    response MIME type

Returns:

  • (Symbol)
  • (nil)

    mime type not supported



78
79
80
# File 'lib/httpotato/parser.rb', line 78

def self.format_from_mimetype(mimetype)
  formats[formats.keys.detect {|k| mimetype.include?(k)}]
end

.formatsHash

Returns the SupportedFormats hash.

Returns:

  • (Hash)

    the SupportedFormats hash



71
72
73
# File 'lib/httpotato/parser.rb', line 71

def self.formats
  const_get(:SupportedFormats)
end

.supported_formatsArray<Symbol>

Returns list of supported formats.

Returns:

  • (Array<Symbol>)

    list of supported formats



83
84
85
# File 'lib/httpotato/parser.rb', line 83

def self.supported_formats
  formats.values.uniq
end

.supports_format?(format) ⇒ Boolean

Parameters:

  • format (Symbol)

    e.g. :json, :xml

Returns:

  • (Boolean)


89
90
91
# File 'lib/httpotato/parser.rb', line 89

def self.supports_format?(format)
  supported_formats.include?(format)
end

Instance Method Details

#parseObject?

Returns:

  • (Object)

    the parsed body

  • (nil)

    when the response body is nil or an empty string



101
102
103
104
105
106
107
108
# File 'lib/httpotato/parser.rb', line 101

def parse
  return nil if body.nil? || body.empty?
  if supports_format?
    parse_supported_format
  else
    body
  end
end