OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ | 5 #ifndef CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ |
6 #define CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ | 6 #define CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <map> | 9 #include <map> |
10 #include <set> | 10 #include <set> |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
60 DOMStorageArea* GetStorageArea(int64 id); | 60 DOMStorageArea* GetStorageArea(int64 id); |
61 | 61 |
62 // Called on WebKit thread when a session storage namespace can be deleted. | 62 // Called on WebKit thread when a session storage namespace can be deleted. |
63 void DeleteSessionStorageNamespace(int64 namespace_id); | 63 void DeleteSessionStorageNamespace(int64 namespace_id); |
64 | 64 |
65 // Get a namespace from an id. What's returned is owned by this class. If | 65 // Get a namespace from an id. What's returned is owned by this class. If |
66 // allocation_allowed is true, then this function will create the storage | 66 // allocation_allowed is true, then this function will create the storage |
67 // namespace if it hasn't been already. | 67 // namespace if it hasn't been already. |
68 DOMStorageNamespace* GetStorageNamespace(int64 id, bool allocation_allowed); | 68 DOMStorageNamespace* GetStorageNamespace(int64 id, bool allocation_allowed); |
69 | 69 |
| 70 // Creates a session storage namespace which is backed up by the existing |
| 71 // |session_storage_directory|. |
| 72 DOMStorageNamespace* RecreateSessionStorageNamespace( |
| 73 int64 id, |
| 74 const FilePath& session_storage_directory); |
| 75 |
70 // Sometimes an event from one DOM storage message filter requires | 76 // Sometimes an event from one DOM storage message filter requires |
71 // communication to all of them. | 77 // communication to all of them. |
72 typedef std::set<DOMStorageMessageFilter*> MessageFilterSet; | 78 typedef std::set<DOMStorageMessageFilter*> MessageFilterSet; |
73 void RegisterMessageFilter(DOMStorageMessageFilter* message_filter); | 79 void RegisterMessageFilter(DOMStorageMessageFilter* message_filter); |
74 void UnregisterMessageFilter(DOMStorageMessageFilter* MessageFilter); | 80 void UnregisterMessageFilter(DOMStorageMessageFilter* MessageFilter); |
75 const MessageFilterSet* GetMessageFilterSet() const; | 81 const MessageFilterSet* GetMessageFilterSet() const; |
76 | 82 |
77 // Tells storage namespaces to purge any memory they do not need. | 83 // Tells storage namespaces to purge any memory they do not need. |
78 virtual void PurgeMemory(); | 84 virtual void PurgeMemory(); |
79 | 85 |
80 // Delete any local storage files that have been touched since the cutoff | 86 // Delete any local storage files that have been touched since the cutoff |
81 // date that's supplied. Protected origins, per the SpecialStoragePolicy, | 87 // date that's supplied. Protected origins, per the SpecialStoragePolicy, |
82 // are not deleted by this method. | 88 // are not deleted by this method. |
83 void DeleteDataModifiedSince(const base::Time& cutoff); | 89 void DeleteDataModifiedSince(const base::Time& cutoff); |
84 | 90 |
85 // Deletes a single local storage file. | 91 // Deletes a single local storage file. |
86 void DeleteLocalStorageFile(const FilePath& file_path); | 92 void DeleteLocalStorageFile(const FilePath& file_path); |
87 | 93 |
88 // Deletes the local storage file for the given origin. | 94 // Deletes the local storage file for the given origin. |
89 void DeleteLocalStorageForOrigin(const string16& origin_id); | 95 void DeleteLocalStorageForOrigin(const string16& origin_id); |
90 | 96 |
91 // Deletes all local storage files. | 97 // Deletes all local storage files. |
92 void DeleteAllLocalStorageFiles(); | 98 void DeleteAllLocalStorageFiles(); |
93 | 99 |
94 // The local storage directory. | 100 // The local storage directory. |
95 static const FilePath::CharType kLocalStorageDirectory[]; | 101 static const FilePath::CharType kLocalStorageDirectory[]; |
96 | 102 |
| 103 // The session storage directory. |
| 104 static const FilePath::CharType kSessionStorageDirectory[]; |
| 105 |
97 // The local storage file extension. | 106 // The local storage file extension. |
98 static const FilePath::CharType kLocalStorageExtension[]; | 107 static const FilePath::CharType kLocalStorageExtension[]; |
99 | 108 |
100 // Get the file name of the local storage file for the given origin. | 109 // Get the file name of the local storage file for the given origin. |
101 FilePath GetLocalStorageFilePath(const string16& origin_id) const; | 110 FilePath GetLocalStorageFilePath(const string16& origin_id) const; |
102 | 111 |
103 void set_clear_local_state_on_exit_(bool clear_local_state) { | 112 void set_clear_local_state_on_exit_(bool clear_local_state) { |
104 clear_local_state_on_exit_ = clear_local_state; | 113 clear_local_state_on_exit_ = clear_local_state; |
105 } | 114 } |
106 | 115 |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
168 // Maps ids to StorageNamespaces. We own these objects. | 177 // Maps ids to StorageNamespaces. We own these objects. |
169 typedef std::map<int64, DOMStorageNamespace*> StorageNamespaceMap; | 178 typedef std::map<int64, DOMStorageNamespace*> StorageNamespaceMap; |
170 StorageNamespaceMap storage_namespace_map_; | 179 StorageNamespaceMap storage_namespace_map_; |
171 | 180 |
172 scoped_refptr<quota::SpecialStoragePolicy> special_storage_policy_; | 181 scoped_refptr<quota::SpecialStoragePolicy> special_storage_policy_; |
173 | 182 |
174 DISALLOW_IMPLICIT_CONSTRUCTORS(DOMStorageContext); | 183 DISALLOW_IMPLICIT_CONSTRUCTORS(DOMStorageContext); |
175 }; | 184 }; |
176 | 185 |
177 #endif // CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ | 186 #endif // CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ |
OLD | NEW |