Remove ENABLE(SQL_DATABASE) guards
[WebKit-https.git] / Source / WebCore / Modules / webdatabase / DatabaseManager.h
1 /*
2  * Copyright (C) 2012 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  */
25
26 #ifndef DatabaseManager_h
27 #define DatabaseManager_h
28
29 #include "DatabaseBasicTypes.h"
30 #include "DatabaseDetails.h"
31 #include "DatabaseError.h"
32 #include <mutex>
33 #include <wtf/Assertions.h>
34 #include <wtf/HashMap.h>
35 #include <wtf/HashSet.h>
36 #include <wtf/PassRefPtr.h>
37 #include <wtf/Threading.h>
38
39 namespace WebCore {
40
41 class AbstractDatabaseServer;
42 class Database;
43 class DatabaseBackendBase;
44 class DatabaseCallback;
45 class DatabaseContext;
46 class DatabaseManagerClient;
47 class DatabaseSync;
48 class DatabaseTaskSynchronizer;
49 class SecurityOrigin;
50 class ScriptExecutionContext;
51
52 class DatabaseManager {
53     WTF_MAKE_NONCOPYABLE(DatabaseManager); WTF_MAKE_FAST_ALLOCATED;
54 public:
55     WEBCORE_EXPORT static DatabaseManager& manager();
56
57     WEBCORE_EXPORT void initialize(const String& databasePath);
58     WEBCORE_EXPORT void setClient(DatabaseManagerClient*);
59     String databaseDirectoryPath() const;
60     void setDatabaseDirectoryPath(const String&);
61
62     bool isAvailable();
63     WEBCORE_EXPORT void setIsAvailable(bool);
64
65     // This gets a DatabaseContext for the specified ScriptExecutionContext.
66     // If one doesn't already exist, it will create a new one.
67     PassRefPtr<DatabaseContext> databaseContextFor(ScriptExecutionContext*);
68
69     // These 2 methods are for DatabaseContext (un)registration, and should only
70     // be called by the DatabaseContext constructor and destructor.
71     void registerDatabaseContext(DatabaseContext*);
72     void unregisterDatabaseContext(DatabaseContext*);
73
74 #if !ASSERT_DISABLED
75     void didConstructDatabaseContext();
76     void didDestructDatabaseContext();
77 #else
78     void didConstructDatabaseContext() { }
79     void didDestructDatabaseContext() { }
80 #endif
81
82     static ExceptionCode exceptionCodeForDatabaseError(DatabaseError);
83
84     PassRefPtr<Database> openDatabase(ScriptExecutionContext*, const String& name, const String& expectedVersion, const String& displayName, unsigned long estimatedSize, PassRefPtr<DatabaseCallback>, DatabaseError&);
85
86     WEBCORE_EXPORT bool hasOpenDatabases(ScriptExecutionContext*);
87     void stopDatabases(ScriptExecutionContext*, DatabaseTaskSynchronizer*);
88
89     String fullPathForDatabase(SecurityOrigin*, const String& name, bool createIfDoesNotExist = true);
90
91     bool hasEntryForOrigin(SecurityOrigin*);
92     WEBCORE_EXPORT void origins(Vector<RefPtr<SecurityOrigin>>& result);
93     WEBCORE_EXPORT bool databaseNamesForOrigin(SecurityOrigin*, Vector<String>& result);
94     WEBCORE_EXPORT DatabaseDetails detailsForNameAndOrigin(const String&, SecurityOrigin*);
95
96     WEBCORE_EXPORT unsigned long long usageForOrigin(SecurityOrigin*);
97     WEBCORE_EXPORT unsigned long long quotaForOrigin(SecurityOrigin*);
98
99     WEBCORE_EXPORT void setQuota(SecurityOrigin*, unsigned long long);
100
101     WEBCORE_EXPORT void deleteAllDatabases();
102     WEBCORE_EXPORT bool deleteOrigin(SecurityOrigin*);
103     WEBCORE_EXPORT bool deleteDatabase(SecurityOrigin*, const String& name);
104
105     void interruptAllDatabasesForContext(ScriptExecutionContext*);
106
107 private:
108     class ProposedDatabase {
109     public:
110         ProposedDatabase(DatabaseManager&, SecurityOrigin*,
111             const String& name, const String& displayName, unsigned long estimatedSize);
112         ~ProposedDatabase();
113
114         SecurityOrigin* origin() { return m_origin.get(); }
115         DatabaseDetails& details() { return m_details; }
116
117     private:
118         DatabaseManager& m_manager;
119         RefPtr<SecurityOrigin> m_origin;
120         DatabaseDetails m_details;
121     };
122
123     DatabaseManager();
124     ~DatabaseManager() { }
125
126     // This gets a DatabaseContext for the specified ScriptExecutionContext if
127     // it already exist previously. Otherwise, it returns 0.
128     PassRefPtr<DatabaseContext> existingDatabaseContextFor(ScriptExecutionContext*);
129
130     PassRefPtr<DatabaseBackendBase> openDatabaseBackend(ScriptExecutionContext*, const String& name, const String& expectedVersion, const String& displayName, unsigned long estimatedSize, bool setVersionInNewDatabase, DatabaseError&, String& errorMessage);
131
132     void addProposedDatabase(ProposedDatabase*);
133     void removeProposedDatabase(ProposedDatabase*);
134
135     static void logErrorMessage(ScriptExecutionContext*, const String& message);
136
137     AbstractDatabaseServer* m_server;
138     DatabaseManagerClient* m_client;
139     bool m_databaseIsAvailable;
140
141     // Access to the following fields require locking m_lock below:
142     typedef HashMap<ScriptExecutionContext*, DatabaseContext*> ContextMap;
143     ContextMap m_contextMap;
144 #if !ASSERT_DISABLED
145     int m_databaseContextRegisteredCount;
146     int m_databaseContextInstanceCount;
147 #endif
148     HashSet<ProposedDatabase*> m_proposedDatabases;
149
150     // This mutex protects m_contextMap, and m_proposedDatabases.
151     std::mutex m_mutex;
152 };
153
154 } // namespace WebCore
155
156 #endif // DatabaseManager_h