Class: Brakeman::Rails3Erubis

Inherits:
Erubis::Eruby
  • Object
show all
Includes:
ErubisPatch
Defined in:
lib/brakeman/parsers/rails3_erubis.rb

Overview

Constant Summary collapse

BLOCK_EXPR =
/\s*((\s+|\))do|\{)(\s*\|[^|]*\|)?\s*\Z/

Instance Method Summary collapse

Methods included from ErubisPatch

#convert

Instance Method Details

#add_expr(src, code, indicator) ⇒ Object

Erubis toggles <%= and <%== behavior when escaping is enabled. We override to always treat <%== as escaped.



33
34
35
36
37
38
39
40
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 33

def add_expr(src, code, indicator)
  case indicator
  when '=='
    add_expr_escaped(src, code)
  else
    super
  end
end

#add_expr_escaped(src, code) ⇒ Object



53
54
55
56
57
58
59
60
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 53

def add_expr_escaped(src, code)
  flush_newline_if_pending(src)
  if code =~ BLOCK_EXPR
    src << "@output_buffer.safe_expr_append= " << code
  else
    src << "@output_buffer.safe_expr_append=(" << code << ");"
  end
end

#add_expr_literal(src, code) ⇒ Object



44
45
46
47
48
49
50
51
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 44

def add_expr_literal(src, code)
  flush_newline_if_pending(src)
  if code =~ BLOCK_EXPR
    src << '@output_buffer.append= ' << code
  else
    src << '@output_buffer.append=(' << code << ');'
  end
end

#add_postamble(src) ⇒ Object



67
68
69
70
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 67

def add_postamble(src)
  flush_newline_if_pending(src)
  src << '@output_buffer.to_s; }'
end

#add_preamble(src) ⇒ Object



10
11
12
13
14
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 10

def add_preamble(src)
  @newline_pending = 0
  src << "_this_is_to_make_yields_syntactally_correct {"
  src << "@output_buffer = output_buffer || ActionView::OutputBuffer.new;"
end

#add_stmt(src, code) ⇒ Object



62
63
64
65
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 62

def add_stmt(src, code)
  flush_newline_if_pending(src)
  super
end

#add_text(src, text) ⇒ Object



16
17
18
19
20
21
22
23
24
25
26
27
28
29
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 16

def add_text(src, text)
  return if text.empty?

  if text == "\n"
    @newline_pending += 1
  else
    src << "@output_buffer.safe_append='"
    src << "\n" * @newline_pending if @newline_pending > 0
    src << escape_text(text)
    src << "'.freeze;"

    @newline_pending = 0
  end
end

#convert_input(src, input) ⇒ Object



81
82
83
84
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 81

def convert_input(src, input)
  input = input.gsub(/<%graphql/, "<%#")
  super(src, input)
end

#flush_newline_if_pending(src) ⇒ Object



72
73
74
75
76
77
# File 'lib/brakeman/parsers/rails3_erubis.rb', line 72

def flush_newline_if_pending(src)
  if @newline_pending > 0
    src << "@output_buffer.safe_append='#{"\n" * @newline_pending}'.freeze;"
    @newline_pending = 0
  end
end