-
-
Notifications
You must be signed in to change notification settings - Fork 221
/
CVE-2019-5419.yml
93 lines (79 loc) · 2.11 KB
/
CVE-2019-5419.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
---
gem: actionview
framework: rails
cve: 2019-5419
ghsa: m63j-wh5w-c252
url: https://groups.google.com/forum/#!topic/rubyonrails-security/GN7w9fFAQeI
title: Denial of Service Vulnerability in Action View
date: 2019-03-13
description: |
There is a potential denial of service vulnerability in actionview.
This vulnerability has been assigned the CVE identifier CVE-2019-5419.
Impact
------
Specially crafted accept headers can cause the Action View template location
code to consume 100% CPU, causing the server unable to process requests. This
impacts all Rails applications that render views.
All users running an affected release should either upgrade or use one of the
workarounds immediately.
Workarounds
-----------
This vulnerability can be mitigated by wrapping `render` calls with
`respond_to` blocks. For example, the following example is vulnerable:
```
class UserController < ApplicationController
def index
render "index"
end
end
```
But the following code is not vulnerable:
```
class UserController < ApplicationController
def index
respond_to |format|
format.html { render "index" }
end
end
end
```
Implicit rendering is impacted, so this code is vulnerable:
```
class UserController < ApplicationController
def index
end
end
```
But can be changed this this:
```
class UserController < ApplicationController
def index
respond_to |format|
format.html { render "index" }
end
end
end
```
Alternatively to specifying the format, the following monkey patch can be
applied in an initializer:
```
$ cat config/initializers/formats_filter.rb
# frozen_string_literal: true
ActionDispatch::Request.prepend(Module.new do
def formats
super().select do |format|
format.symbol || format.ref == "*/*"
end
end
end)
```
Credits
-------
Thanks to John Hawthorn <john@hawthorn.email> of GitHub
cvss_v3: 7.5
patched_versions:
- ">= 6.0.0.beta3"
- "~> 5.2.2, >= 5.2.2.1"
- "~> 5.1.6, >= 5.1.6.2"
- "~> 5.0.7, >= 5.0.7.2"
- "~> 4.2.11, >= 4.2.11.1"