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..c4570c07ea7d0ee47fa10a4eba5258cc23c0cbd5 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 |
| + // compare them. |
| + DCHECK_EQ(method, base::ToUpperASCII(method)); |
| + for (size_t i = 0; i < arraysize(kValidHttpMethods); ++i) { |
|
mmenke
2016/09/20 15:25:32
optional nit: for both the loops, can just do: f
droger
2016/09/21 09:57:48
Done.
|
| + if (method.compare(kValidHttpMethods[i]) == 0) |
|
mmenke
2016/09/20 15:25:32
Know this is what the old code did, but maybe we s
droger
2016/09/21 09:57:48
TIL
According to this:
http://stackoverflow.com/q
|
| + return true; |
| + } |
| + |
| + if (prerender_mode() == PREFETCH_ONLY) |
| + return false; |
| + |
| + for (size_t i = 0; i < arraysize(kValidHttpMethodsForPrerendering); ++i) { |
| + if (method.compare(kValidHttpMethodsForPrerendering[i]) == 0) |
| + return true; |
| + } |
| + |
| + return false; |
| +} |
| + |
| // static |
| PrerenderContents::Factory* PrerenderContents::CreateFactory() { |
| return new PrerenderContentsFactoryImpl(); |