• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2013 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 "chrome/browser/policy/policy_helpers.h"
6 
7 #include "net/base/net_errors.h"
8 #include "url/gurl.h"
9 
10 #if defined(OS_CHROMEOS)
11 #include "base/command_line.h"
12 #include "chromeos/chromeos_switches.h"
13 #endif
14 
15 #if !defined(OS_CHROMEOS) && !defined(OS_IOS)
16 #include "components/signin/core/browser/signin_manager.h"
17 #include "google_apis/gaia/gaia_urls.h"
18 #endif
19 
20 namespace policy {
21 
OverrideBlacklistForURL(const GURL & url,bool * block,int * reason)22 bool OverrideBlacklistForURL(const GURL& url, bool* block, int* reason) {
23 #if defined(OS_CHROMEOS)
24   // On ChromeOS browsing is only allowed once OOBE has completed. Therefore all
25   // requests are blocked until this condition is met.
26   if (CommandLine::ForCurrentProcess()->HasSwitch(
27           chromeos::switches::kOobeGuestSession)) {
28     if (!url.SchemeIs("chrome") && !url.SchemeIs("chrome-extension")) {
29       *reason = net::ERR_BLOCKED_ENROLLMENT_CHECK_PENDING;
30       *block = true;
31       return true;
32     }
33   }
34   return false;
35 #elif defined(OS_IOS)
36   return false;
37 #else
38   static const char kServiceLoginAuth[] = "/ServiceLoginAuth";
39 
40   *block = false;
41   // Whitelist all the signin flow URLs flagged by the SigninManager.
42   if (SigninManager::IsWebBasedSigninFlowURL(url))
43     return true;
44 
45   // Additionally whitelist /ServiceLoginAuth.
46   if (url.GetOrigin() != GaiaUrls::GetInstance()->gaia_url().GetOrigin())
47     return false;
48 
49   return url.path() == kServiceLoginAuth;
50 #endif
51 }
52 
53 }  // namespace policy
54