Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / content / browser / ssl / ssl_policy_backend.cc
1 // Copyright (c) 2012 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/browser/ssl/ssl_policy_backend.h"
6
7 #include "content/browser/frame_host/navigation_controller_impl.h"
8 #include "content/public/browser/browser_context.h"
9 #include "content/public/browser/ssl_host_state_delegate.h"
10
11 namespace content {
12
13 SSLPolicyBackend::SSLPolicyBackend(NavigationControllerImpl* controller)
14     : ssl_host_state_delegate_(
15           controller->GetBrowserContext()->GetSSLHostStateDelegate()),
16       controller_(controller) {
17   DCHECK(controller_);
18 }
19
20 void SSLPolicyBackend::HostRanInsecureContent(const std::string& host, int id) {
21   if (ssl_host_state_delegate_)
22     ssl_host_state_delegate_->HostRanInsecureContent(host, id);
23   SSLManager::NotifySSLInternalStateChanged(controller_->GetBrowserContext());
24 }
25
26 bool SSLPolicyBackend::DidHostRunInsecureContent(const std::string& host,
27                                                  int pid) const {
28   if (!ssl_host_state_delegate_)
29     return false;
30
31   return ssl_host_state_delegate_->DidHostRunInsecureContent(host, pid);
32 }
33
34 void SSLPolicyBackend::DenyCertForHost(net::X509Certificate* cert,
35                                        const std::string& host,
36                                        net::CertStatus error) {
37   if (ssl_host_state_delegate_)
38     ssl_host_state_delegate_->DenyCert(host, cert, error);
39 }
40
41 void SSLPolicyBackend::AllowCertForHost(net::X509Certificate* cert,
42                                         const std::string& host,
43                                         net::CertStatus error) {
44   if (ssl_host_state_delegate_)
45     ssl_host_state_delegate_->AllowCert(host, cert, error);
46 }
47
48 net::CertPolicy::Judgment SSLPolicyBackend::QueryPolicy(
49     net::X509Certificate* cert,
50     const std::string& host,
51     net::CertStatus error,
52     bool* expired_previous_decision) {
53   if (!ssl_host_state_delegate_)
54     return net::CertPolicy::UNKNOWN;
55
56   return ssl_host_state_delegate_->QueryPolicy(
57       host, cert, error, expired_previous_decision);
58 }
59
60 }  // namespace content