kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 1 | // Copyright 2015 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 "content/public/common/origin_util.h" |
| 6 | |
| 7 | #include "base/lazy_instance.h" |
avi | a9aa7a8 | 2015-12-25 03:06:31 | [diff] [blame] | 8 | #include "base/macros.h" |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 9 | #include "base/stl_util.h" |
jam | e0dcd98 | 2017-01-11 03:13:45 | [diff] [blame^] | 10 | #include "content/common/url_schemes.h" |
tfarina | 7ba5a62 | 2016-02-23 23:21:44 | [diff] [blame] | 11 | #include "net/base/url_util.h" |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 12 | #include "url/gurl.h" |
| 13 | |
| 14 | namespace content { |
| 15 | |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 16 | bool IsOriginSecure(const GURL& url) { |
| 17 | if (url.SchemeIsCryptographic() || url.SchemeIsFile()) |
| 18 | return true; |
| 19 | |
| 20 | if (url.SchemeIsFileSystem() && url.inner_url() && |
| 21 | IsOriginSecure(*url.inner_url())) { |
| 22 | return true; |
| 23 | } |
| 24 | |
| 25 | std::string hostname = url.HostNoBrackets(); |
| 26 | if (net::IsLocalhost(hostname)) |
| 27 | return true; |
| 28 | |
jam | e0dcd98 | 2017-01-11 03:13:45 | [diff] [blame^] | 29 | if (base::ContainsValue(GetSecureSchemes(), url.scheme())) |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 30 | return true; |
| 31 | |
jam | e0dcd98 | 2017-01-11 03:13:45 | [diff] [blame^] | 32 | if (base::ContainsValue(GetSecureOrigins(), url.GetOrigin())) { |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 33 | return true; |
annekao | 1db36fd | 2015-07-29 17:09:16 | [diff] [blame] | 34 | } |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 35 | |
| 36 | return false; |
| 37 | } |
| 38 | |
annekao | 1db36fd | 2015-07-29 17:09:16 | [diff] [blame] | 39 | bool OriginCanAccessServiceWorkers(const GURL& url) { |
| 40 | if (url.SchemeIsHTTPOrHTTPS() && IsOriginSecure(url)) |
| 41 | return true; |
| 42 | |
jam | e0dcd98 | 2017-01-11 03:13:45 | [diff] [blame^] | 43 | if (base::ContainsValue(GetServiceWorkerSchemes(), url.scheme())) { |
annekao | 1db36fd | 2015-07-29 17:09:16 | [diff] [blame] | 44 | return true; |
| 45 | } |
| 46 | |
| 47 | return false; |
| 48 | } |
| 49 | |
| 50 | void ResetSchemesAndOriginsWhitelistForTesting() { |
jam | e0dcd98 | 2017-01-11 03:13:45 | [diff] [blame^] | 51 | RefreshSecuritySchemesForTesting(); |
kinuko | aaff1f6f | 2015-05-01 04:04:13 | [diff] [blame] | 52 | } |
| 53 | |
kinuko | 8cbea05 | 2015-04-25 13:35:43 | [diff] [blame] | 54 | } // namespace content |