diff options
Diffstat (limited to 'content/browser/ssl/ssl_policy_backend.h')
-rw-r--r-- | content/browser/ssl/ssl_policy_backend.h | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/content/browser/ssl/ssl_policy_backend.h b/content/browser/ssl/ssl_policy_backend.h new file mode 100644 index 0000000..97fa38f --- /dev/null +++ b/content/browser/ssl/ssl_policy_backend.h @@ -0,0 +1,46 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef CONTENT_BROWSER_SSL_SSL_POLICY_BACKEND_H_ +#define CONTENT_BROWSER_SSL_SSL_POLICY_BACKEND_H_ +#pragma once + +#include <string> +#include <vector> + +#include "base/basictypes.h" +#include "base/string16.h" +#include "net/base/x509_certificate.h" + +class NavigationController; +class SSLHostState; + +class SSLPolicyBackend { + public: + explicit SSLPolicyBackend(NavigationController* controller); + + // Records that a host has run insecure content. + void HostRanInsecureContent(const std::string& host, int pid); + + // Returns whether the specified host ran insecure content. + bool DidHostRunInsecureContent(const std::string& host, int pid) const; + + // Records that |cert| is permitted to be used for |host| in the future. + void DenyCertForHost(net::X509Certificate* cert, const std::string& host); + + // Records that |cert| is not permitted to be used for |host| in the future. + void AllowCertForHost(net::X509Certificate* cert, const std::string& host); + + // Queries whether |cert| is allowed or denied for |host|. + net::CertPolicy::Judgment QueryPolicy( + net::X509Certificate* cert, const std::string& host); + + private: + // SSL state specific for each host. + SSLHostState* ssl_host_state_; + + DISALLOW_COPY_AND_ASSIGN(SSLPolicyBackend); +}; + +#endif // CONTENT_BROWSER_SSL_SSL_POLICY_BACKEND_H_ |