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