summaryrefslogtreecommitdiffstats
path: root/net/base/force_tls_state.h
diff options
context:
space:
mode:
Diffstat (limited to 'net/base/force_tls_state.h')
-rw-r--r--net/base/force_tls_state.h50
1 files changed, 50 insertions, 0 deletions
diff --git a/net/base/force_tls_state.h b/net/base/force_tls_state.h
new file mode 100644
index 0000000..988e9c07
--- /dev/null
+++ b/net/base/force_tls_state.h
@@ -0,0 +1,50 @@
+// Copyright (c) 2009 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 NET_BASE_FORCE_TLS_STATE_H_
+#define NET_BASE_FORCE_TLS_STATE_H_
+
+#include <set>
+#include <string>
+
+#include "base/basictypes.h"
+#include "base/lock.h"
+
+class GURL;
+
+namespace net {
+
+// ForceTLSState
+//
+// Tracks which hosts have enabled ForceTLS. After a host enables ForceTLS,
+// then we refuse to talk to the host over HTTP, treat all certificate errors as
+// fatal, and refuses to load any mixed content.
+//
+class ForceTLSState {
+ public:
+ ForceTLSState();
+
+ // Called when we see an X-Force-TLS header that we should process. Modifies
+ // our state as instructed by the header.
+ void DidReceiveHeader(const GURL& url, const std::string& value);
+
+ // Enable ForceTLS for |host|.
+ void EnableHost(const std::string& host);
+
+ // Returns whether |host| has had ForceTLS enabled.
+ bool IsEnabledForHost(const std::string& host);
+
+ private:
+ // The set of hosts that have enabled ForceTLS.
+ std::set<std::string> enabled_hosts_;
+
+ // Protect access to our data members with this lock.
+ Lock lock_;
+
+ DISALLOW_COPY_AND_ASSIGN(ForceTLSState);
+};
+
+} // namespace net
+
+#endif // NET_BASE_FORCE_TLS_STATE_H_