#pragma once
#if ENABLE(INDEXED_DATABASE)
#include "ActiveDOMObject.h"
#include "IDBObjectStoreInfo.h"
#include <wtf/HashSet.h>
namespace JSC {
class ExecState;
class JSValue;
class SlotVisitor;
}
namespace WebCore {
class DOMStringList;
class IDBIndex;
class IDBKey;
class IDBKeyRange;
class IDBRequest;
class IDBTransaction;
struct ExceptionCodeWithMessage;
struct IDBKeyRangeData;
namespace IndexedDB {
enum class ObjectStoreOverwriteMode;
}
class IDBObjectStore final : public RefCounted<IDBObjectStore>, public ActiveDOMObject {
public:
static Ref<IDBObjectStore> create(ScriptExecutionContext&, const IDBObjectStoreInfo&, IDBTransaction&);
~IDBObjectStore();
const String& name() const;
const IDBKeyPath& keyPath() const;
RefPtr<DOMStringList> indexNames() const;
RefPtr<IDBTransaction> transaction();
bool autoIncrement() const;
struct IndexParameters {
bool unique;
bool multiEntry;
};
RefPtr<IDBRequest> openCursor(ScriptExecutionContext&, IDBKeyRange*, const String& direction, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> openCursor(ScriptExecutionContext&, JSC::JSValue key, const String& direction, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> get(ScriptExecutionContext&, JSC::JSValue key, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> get(ScriptExecutionContext&, IDBKeyRange*, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> add(JSC::ExecState&, JSC::JSValue, JSC::JSValue key, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> put(JSC::ExecState&, JSC::JSValue, JSC::JSValue key, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> deleteFunction(ScriptExecutionContext&, IDBKeyRange*, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> deleteFunction(ScriptExecutionContext&, JSC::JSValue key, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> clear(ScriptExecutionContext&, ExceptionCodeWithMessage&);
RefPtr<IDBIndex> createIndex(ScriptExecutionContext&, const String& name, const IDBKeyPath&, const IndexParameters&, ExceptionCodeWithMessage&);
RefPtr<IDBIndex> index(const String& name, ExceptionCodeWithMessage&);
void deleteIndex(const String& name, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> count(ScriptExecutionContext&, IDBKeyRange*, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> count(ScriptExecutionContext&, JSC::JSValue key, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> putForCursorUpdate(JSC::ExecState&, JSC::JSValue, JSC::JSValue key, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> modernDelete(ScriptExecutionContext&, JSC::JSValue key, ExceptionCodeWithMessage&);
void markAsDeleted();
bool isDeleted() const { return m_deleted; }
const IDBObjectStoreInfo& info() const { return m_info; }
IDBTransaction& modernTransaction() { return m_transaction.get(); }
void rollbackInfoForVersionChangeAbort();
void visitReferencedIndexes(JSC::SlotVisitor&) const;
private:
IDBObjectStore(ScriptExecutionContext&, const IDBObjectStoreInfo&, IDBTransaction&);
enum class InlineKeyCheck { Perform, DoNotPerform };
RefPtr<IDBRequest> putOrAdd(JSC::ExecState&, JSC::JSValue, RefPtr<IDBKey>, IndexedDB::ObjectStoreOverwriteMode, InlineKeyCheck, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> doCount(ScriptExecutionContext&, const IDBKeyRangeData&, ExceptionCodeWithMessage&);
RefPtr<IDBRequest> doDelete(ScriptExecutionContext&, IDBKeyRange*, ExceptionCodeWithMessage&);
const char* activeDOMObjectName() const final;
bool canSuspendForDocumentSuspension() const final;
bool hasPendingActivity() const final;
IDBObjectStoreInfo m_info;
IDBObjectStoreInfo m_originalInfo;
Ref<IDBTransaction> m_transaction;
bool m_deleted { false };
mutable Lock m_referencedIndexLock;
HashMap<String, std::unique_ptr<IDBIndex>> m_referencedIndexes;
HashSet<std::unique_ptr<IDBIndex>> m_deletedIndexes;
};
}
#endif // ENABLE(INDEXED_DATABASE)