Chromium Code Reviews| Index: chrome/browser/prerender/prerender_contents.cc |
| diff --git a/chrome/browser/prerender/prerender_contents.cc b/chrome/browser/prerender/prerender_contents.cc |
| index 5e4b3adde081cf5946bff597331e285539392fad..64339e3a1b6295f1931a47d89c6a41c5f6c0bc2e 100644 |
| --- a/chrome/browser/prerender/prerender_contents.cc |
| +++ b/chrome/browser/prerender/prerender_contents.cc |
| @@ -58,6 +58,16 @@ namespace prerender { |
| namespace { |
| +// Valid HTTP methods for both prefetch and prerendering. |
| +const char* const kValidHttpMethods[] = { |
| + "GET", "HEAD", |
| +}; |
| + |
| +// Additional valid HTTP methods for prerendering. |
| +const char* const kValidHttpMethodsForPrerendering[] = { |
| + "OPTIONS", "POST", "TRACE", |
| +}; |
| + |
| void ResumeThrottles( |
| std::vector<base::WeakPtr<PrerenderResourceThrottle> > throttles) { |
| for (size_t i = 0; i < throttles.size(); i++) { |
| @@ -223,6 +233,27 @@ void PrerenderContents::SetPrerenderMode(PrerenderMode mode) { |
| prerender_mode_ = mode; |
| } |
| +bool PrerenderContents::IsValidHttpMethod(const std::string& method) { |
| + DCHECK_NE(prerender_mode(), NO_PRERENDER); |
| + // method has been canonicalized to upper case at this point so we can just |
|
pasko
2016/09/21 17:59:53
nit: s/method/|method|/
droger
2016/09/22 08:42:01
Done.
|
| + // compare them. |
| + DCHECK_EQ(method, base::ToUpperASCII(method)); |
| + for (const char* const valid_method : kValidHttpMethods) { |
| + if (method == valid_method) |
| + return true; |
| + } |
| + |
| + if (prerender_mode() == PREFETCH_ONLY) |
| + return false; |
| + |
| + for (const char* const valid_method : kValidHttpMethodsForPrerendering) { |
|
pasko
2016/09/21 17:59:53
nit: do we really need to be so explicit here abou
droger
2016/09/22 08:42:01
Done.
|
| + if (method == valid_method) |
| + return true; |
| + } |
| + |
| + return false; |
| +} |
| + |
| // static |
| PrerenderContents::Factory* PrerenderContents::CreateFactory() { |
| return new PrerenderContentsFactoryImpl(); |