diff options
author | Zeno Albisser <zeno.albisser@digia.com> | 2013-08-15 21:46:11 +0200 |
---|---|---|
committer | Zeno Albisser <zeno.albisser@digia.com> | 2013-08-15 21:46:11 +0200 |
commit | 679147eead574d186ebf3069647b4c23e8ccace6 (patch) | |
tree | fc247a0ac8ff119f7c8550879ebb6d3dd8d1ff69 /chromium/content/browser/media/webrtc_identity_store_backend.h | |
download | qtwebengine-chromium-679147eead574d186ebf3069647b4c23e8ccace6.tar.gz |
Initial import.
Diffstat (limited to 'chromium/content/browser/media/webrtc_identity_store_backend.h')
-rw-r--r-- | chromium/content/browser/media/webrtc_identity_store_backend.h | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/chromium/content/browser/media/webrtc_identity_store_backend.h b/chromium/content/browser/media/webrtc_identity_store_backend.h new file mode 100644 index 00000000000..ab4e1ed7e1e --- /dev/null +++ b/chromium/content/browser/media/webrtc_identity_store_backend.h @@ -0,0 +1,111 @@ +// Copyright 2013 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_MEDIA_WEBRTC_IDENTITY_STORE_BACKEND_H_ +#define CONTENT_BROWSER_MEDIA_WEBRTC_IDENTITY_STORE_BACKEND_H_ + +#include <map> +#include <string> + +#include "base/time/time.h" +#include "sql/connection.h" +#include "sql/meta_table.h" + +class GURL; + +namespace base { +class FilePath; +} // namespace base + +namespace quota { +class SpecialStoragePolicy; +} // namespace quota + +namespace content { + +// This class represents a persistent cache of WebRTC identities. +// It can be created/destroyed/Close() on any thread. All other members should +// be accessed on the IO thread. +class WebRTCIdentityStoreBackend + : public base::RefCountedThreadSafe<WebRTCIdentityStoreBackend> { + public: + typedef base::Callback<void(int error, + const std::string& certificate, + const std::string& private_key)> + FindIdentityCallback; + + // No data is saved on disk if |path| is empty. + WebRTCIdentityStoreBackend(const base::FilePath& path, + quota::SpecialStoragePolicy* policy); + + // Finds the identity with |origin|, |identity_name|, and |common_name| from + // the DB. + // |origin| is the origin of the identity; + // |identity_name| is used to identify an identity within an origin; + // |common_name| is the common name used to generate the certificate; + // |callback| is the callback to return the find result. + // Returns true if |callback| will be called. + // Should be called on the IO thread. + bool FindIdentity(const GURL& origin, + const std::string& identity_name, + const std::string& common_name, + const FindIdentityCallback& callback); + + // Adds the identity to the DB and overwrites any existing identity having the + // same origin and identity_name. + // |origin| is the origin of the identity; + // |identity_name| is used to identify an identity within an origin; + // |common_name| is the common name used to generate the certificate; + // |certificate| is the DER string of the certificate; + // |private_key| is the DER string of the private key. + // Should be called on the IO thread. + void AddIdentity(const GURL& origin, + const std::string& identity_name, + const std::string& common_name, + const std::string& certificate, + const std::string& private_key); + + // Commits all pending DB operations and closes the DB connection. Any API + // call after this will fail. + // Can be called on any thread. + void Close(); + + // Delete the data created between |delete_begin| and |delete_end|. + // Should be called on the IO thread. + void DeleteBetween(base::Time delete_begin, + base::Time delete_end, + const base::Closure& callback); + + private: + friend class base::RefCountedThreadSafe<WebRTCIdentityStoreBackend>; + class SqlLiteStorage; + enum LoadingState { + NOT_STARTED, + LOADING, + LOADED, + CLOSED, + }; + struct PendingFindRequest; + struct IdentityKey; + struct Identity; + typedef std::map<IdentityKey, Identity> IdentityMap; + + ~WebRTCIdentityStoreBackend(); + + void OnLoaded(scoped_ptr<IdentityMap> out_map); + + // In-memory copy of the identities. + IdentityMap identities_; + // "Find identity" requests waiting for the DB to load. + std::vector<PendingFindRequest*> pending_find_requests_; + // The persistent storage loading state. + LoadingState state_; + // The persistent storage of identities. + scoped_refptr<SqlLiteStorage> sql_lite_storage_; + + DISALLOW_COPY_AND_ASSIGN(WebRTCIdentityStoreBackend); +}; +} + +#endif // CONTENT_BROWSER_MEDIA_WEBRTC_IDENTITY_STORE_BACKEND_H_ |