Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(231)

Side by Side Diff: chrome/browser/download/download_extensions.cc

Issue 1403001: Modifying the "dangerous download" algorithm. (Closed)
Patch Set: Moving extension methods out of download_util.h Created 10 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include <set>
6 #include <string>
7
8 #include "chrome/browser/download/download_extensions.h"
9
10 #include "base/string_util.h"
11 #include "net/base/mime_util.h"
12 #include "net/base/net_util.h"
13
14 namespace download_util {
15
16 // For file extensions taken from mozilla:
17
18 /* ***** BEGIN LICENSE BLOCK *****
19 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
20 *
21 * The contents of this file are subject to the Mozilla Public License Version
22 * 1.1 (the "License"); you may not use this file except in compliance with
23 * the License. You may obtain a copy of the License at
24 * http://www.mozilla.org/MPL/
25 *
26 * Software distributed under the License is distributed on an "AS IS" basis,
27 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
28 * for the specific language governing rights and limitations under the
29 * License.
30 *
31 * The Original Code is Mozilla Communicator client code, released
32 * March 31, 1998.
33 *
34 * The Initial Developer of the Original Code is
35 * Netscape Communications Corporation.
36 * Portions created by the Initial Developer are Copyright (C) 1998-1999
37 * the Initial Developer. All Rights Reserved.
38 *
39 * Contributor(s):
40 * Doug Turner <dougt@netscape.com>
41 * Dean Tessman <dean_tessman@hotmail.com>
42 * Brodie Thiesfield <brofield@jellycan.com>
43 * Jungshik Shin <jshin@i18nl10n.com>
44 *
45 * Alternatively, the contents of this file may be used under the terms of
46 * either of the GNU General Public License Version 2 or later (the "GPL"),
47 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
48 * in which case the provisions of the GPL or the LGPL are applicable instead
49 * of those above. If you wish to allow use of your version of this file only
50 * under the terms of either the GPL or the LGPL, and not to allow others to
51 * use your version of this file under the terms of the MPL, indicate your
52 * decision by deleting the provisions above and replace them with the notice
53 * and other provisions required by the GPL or the LGPL. If you do not delete
54 * the provisions above, a recipient may use your version of this file under
55 * the terms of any one of the MPL, the GPL or the LGPL.
56 *
57 * ***** END LICENSE BLOCK ***** */
58
59 static const struct Executables {
60 const char* extension;
61 DownloadDangerLevel level;
62 } g_executables[] = {
63 { "class", AllowOnUserGesture },
64 { "htm", AllowOnUserGesture },
65 { "html", AllowOnUserGesture },
66 { "jar", AllowOnUserGesture },
67 { "jnlp", AllowOnUserGesture },
68 { "pdf", AllowOnUserGesture },
69 { "pdfxml", AllowOnUserGesture },
70 { "mars", AllowOnUserGesture },
71 { "fdf", AllowOnUserGesture },
72 { "xfdf", AllowOnUserGesture },
73 { "xdp", AllowOnUserGesture },
74 { "xfd", AllowOnUserGesture },
75 { "pl", AllowOnUserGesture },
76 { "py", AllowOnUserGesture },
77 { "rb", AllowOnUserGesture },
78 { "shtm", AllowOnUserGesture },
79 { "shtml", AllowOnUserGesture },
80 { "svg", AllowOnUserGesture },
81 { "swf", AllowOnUserGesture },
82 { "xht", AllowOnUserGesture },
83 { "xhtm", AllowOnUserGesture },
84 { "xhtml", AllowOnUserGesture },
85 { "xml", AllowOnUserGesture },
86 { "xsl", AllowOnUserGesture },
87 { "xslt", AllowOnUserGesture },
88 #if defined(OS_WIN)
89 { "ad", AllowOnUserGesture },
90 { "ade", AllowOnUserGesture },
91 { "adp", AllowOnUserGesture },
92 { "app", AllowOnUserGesture },
93 { "application", AllowOnUserGesture },
94 { "asp", AllowOnUserGesture },
95 { "asx", AllowOnUserGesture },
96 { "bas", AllowOnUserGesture },
97 { "bat", AllowOnUserGesture },
98 { "chi", AllowOnUserGesture },
99 { "chm", AllowOnUserGesture },
100 { "cmd", AllowOnUserGesture },
101 { "com", AllowOnUserGesture },
102 { "cpl", AllowOnUserGesture },
103 { "crt", AllowOnUserGesture },
104 { "dll", Dangerous },
105 { "exe", AllowOnUserGesture },
106 { "fxp", AllowOnUserGesture },
107 { "hlp", AllowOnUserGesture },
108 { "hta", AllowOnUserGesture },
109 { "htt", AllowOnUserGesture },
110 { "inf", AllowOnUserGesture },
111 { "ins", AllowOnUserGesture },
112 { "isp", AllowOnUserGesture },
113 { "js", AllowOnUserGesture },
114 { "jse", AllowOnUserGesture },
115 { "lnk", AllowOnUserGesture },
116 { "mad", AllowOnUserGesture },
117 { "maf", AllowOnUserGesture },
118 { "mag", AllowOnUserGesture },
119 { "mam", AllowOnUserGesture },
120 { "maq", AllowOnUserGesture },
121 { "mar", AllowOnUserGesture },
122 { "mas", AllowOnUserGesture },
123 { "mat", AllowOnUserGesture },
124 { "mau", AllowOnUserGesture },
125 { "mav", AllowOnUserGesture },
126 { "maw", AllowOnUserGesture },
127 { "mda", AllowOnUserGesture },
128 { "mdb", AllowOnUserGesture },
129 { "mde", AllowOnUserGesture },
130 { "mdt", AllowOnUserGesture },
131 { "mdw", AllowOnUserGesture },
132 { "mdz", AllowOnUserGesture },
133 { "mht", AllowOnUserGesture },
134 { "mhtml", AllowOnUserGesture },
135 { "mmc", AllowOnUserGesture },
136 { "msc", AllowOnUserGesture },
137 { "msh", AllowOnUserGesture },
138 { "mshxml", AllowOnUserGesture },
139 { "msi", AllowOnUserGesture },
140 { "msp", AllowOnUserGesture },
141 { "mst", AllowOnUserGesture },
142 { "ocx", AllowOnUserGesture },
143 { "ops", AllowOnUserGesture },
144 { "pcd", AllowOnUserGesture },
145 { "pif", AllowOnUserGesture },
146 { "plg", AllowOnUserGesture },
147 { "prf", AllowOnUserGesture },
148 { "prg", AllowOnUserGesture },
149 { "pst", AllowOnUserGesture },
150 { "reg", AllowOnUserGesture },
151 { "scf", AllowOnUserGesture },
152 { "scr", AllowOnUserGesture },
153 { "sct", AllowOnUserGesture },
154 { "shb", AllowOnUserGesture },
155 { "shs", AllowOnUserGesture },
156 { "url", AllowOnUserGesture },
157 { "vb", AllowOnUserGesture },
158 { "vbe", AllowOnUserGesture },
159 { "vbs", AllowOnUserGesture },
160 { "vsd", AllowOnUserGesture },
161 { "vsmacros", AllowOnUserGesture },
162 { "vss", AllowOnUserGesture },
163 { "vst", AllowOnUserGesture },
164 { "vsw", AllowOnUserGesture },
165 { "ws", AllowOnUserGesture },
166 { "wsc", AllowOnUserGesture },
167 { "wsf", AllowOnUserGesture },
168 { "wsh", AllowOnUserGesture },
169 { "xbap", Dangerous },
170 #elif defined(OS_MACOSX)
171 // TODO(thakis): Figure out what makes sense here -- crbug.com/19096
172 { "app", AllowOnUserGesture },
173 { "dmg", AllowOnUserGesture },
174 #elif defined(OS_POSIX)
175 // TODO(estade): lengthen this list.
176 { "bash", AllowOnUserGesture },
177 { "csh", AllowOnUserGesture },
178 { "deb", AllowOnUserGesture },
179 { "exe", AllowOnUserGesture },
180 { "ksh", AllowOnUserGesture },
181 { "rpm", AllowOnUserGesture },
182 { "sh", AllowOnUserGesture },
183 { "tcsh", AllowOnUserGesture },
184 #endif
185 };
186
187 DownloadDangerLevel GetFileDangerLevel(const FilePath& path) {
188 return GetFileExtensionDangerLevel(path.Extension());
189 }
190
191 DownloadDangerLevel GetFileExtensionDangerLevel(
192 const FilePath::StringType& extension) {
193 if (extension.empty())
194 return NotDangerous;
195 if (!IsStringASCII(extension))
196 return NotDangerous;
197 #if defined(OS_WIN)
198 std::string ascii_extension = WideToASCII(extension);
199 #elif defined(OS_POSIX)
200 std::string ascii_extension = extension;
201 #endif
202
203 // Strip out leading dot if it's still there
204 if (ascii_extension[0] == FilePath::kExtensionSeparator)
205 ascii_extension.erase(0, 1);
206
207 for (size_t i = 0; i < arraysize(g_executables); ++i) {
208 if (LowerCaseEqualsASCII(ascii_extension, g_executables[i].extension))
209 return g_executables[i].level;
210 }
211 return NotDangerous;
212 }
213
214 bool IsFileExtensionSafe(const FilePath::StringType& extension) {
215 return GetFileExtensionDangerLevel(extension) == NotDangerous;
216 }
217
218 bool IsFileSafe(const FilePath& path) {
219 return GetFileDangerLevel(path) == NotDangerous;
220 }
221
222 static const char* kExecutableWhiteList[] = {
223 // JavaScript is just as powerful as EXE.
224 "text/javascript",
225 "text/javascript;version=*",
226 "text/html",
227 // Registry files can cause critical changes to the MS OS behavior.
228 // Addition of this mimetype also addresses bug 7337.
229 "text/x-registry",
230 "text/x-sh",
231 // Some sites use binary/octet-stream to mean application/octet-stream.
232 // See http://code.google.com/p/chromium/issues/detail?id=1573
233 "binary/octet-stream"
234 };
235
236 static const char* kExecutableBlackList[] = {
237 // These application types are not executable.
238 "application/*+xml",
239 "application/xml"
240 };
241
242 bool IsExecutableMimeType(const std::string& mime_type) {
243 for (size_t i = 0; i < arraysize(kExecutableWhiteList); ++i) {
244 if (net::MatchesMimeType(kExecutableWhiteList[i], mime_type))
245 return true;
246 }
247 for (size_t i = 0; i < arraysize(kExecutableBlackList); ++i) {
248 if (net::MatchesMimeType(kExecutableBlackList[i], mime_type))
249 return false;
250 }
251 // We consider only other application types to be executable.
252 return net::MatchesMimeType("application/*", mime_type);
253 }
254
255
256 } // namespace download_util
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698