blob: c3ca52069298e4f44f956691f206f1184c166846 [file] [log] [blame]
// Copyright (c) 2012 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 THIRD_PARTY_BLINK_PUBLIC_COMMON_INDEXEDDB_INDEXEDDB_KEY_H_
#define THIRD_PARTY_BLINK_PUBLIC_COMMON_INDEXEDDB_INDEXEDDB_KEY_H_
#include <stddef.h>
#include <string>
#include <vector>
#include "base/check_op.h"
#include "base/strings/string16.h"
#include "third_party/blink/public/common/common_export.h"
#include "third_party/blink/public/common/indexeddb/web_idb_types.h"
namespace blink {
class BLINK_COMMON_EXPORT IndexedDBKey {
public:
typedef std::vector<IndexedDBKey> KeyArray;
// Non-standard limits, selected to avoid breaking real-world use of the API
// while also preventing buggy (or malicious) code from causing crashes.
static constexpr size_t kMaximumDepth = 2000;
static constexpr size_t kMaximumArraySize = 1000000;
IndexedDBKey(); // Defaults to mojom::IDBKeyType::Invalid.
explicit IndexedDBKey(mojom::IDBKeyType); // must be Null or Invalid
explicit IndexedDBKey(KeyArray array);
explicit IndexedDBKey(std::string binary);
explicit IndexedDBKey(base::string16 string);
IndexedDBKey(double number,
mojom::IDBKeyType type); // must be date or number
IndexedDBKey(const IndexedDBKey& other);
~IndexedDBKey();
IndexedDBKey& operator=(const IndexedDBKey& other);
bool IsValid() const;
bool IsLessThan(const IndexedDBKey& other) const;
bool Equals(const IndexedDBKey& other) const;
mojom::IDBKeyType type() const { return type_; }
const std::vector<IndexedDBKey>& array() const {
DCHECK_EQ(type_, mojom::IDBKeyType::Array);
return array_;
}
const std::string& binary() const {
DCHECK_EQ(type_, mojom::IDBKeyType::Binary);
return binary_;
}
const base::string16& string() const {
DCHECK_EQ(type_, mojom::IDBKeyType::String);
return string_;
}
double date() const {
DCHECK_EQ(type_, mojom::IDBKeyType::Date);
return number_;
}
double number() const {
DCHECK_EQ(type_, mojom::IDBKeyType::Number);
return number_;
}
size_t size_estimate() const { return size_estimate_; }
// Tests if this array-type key has "holes". Used in cases where a compound
// key references an auto-generated primary key.
bool HasHoles() const;
// Returns a copy of this array-type key, but with "holes" replaced by the
// given primary key. Used in cases where a compound key references an
// auto-generated primary key.
IndexedDBKey FillHoles(const IndexedDBKey&) const WARN_UNUSED_RESULT;
std::string DebugString() const;
private:
int CompareTo(const IndexedDBKey& other) const;
mojom::IDBKeyType type_;
std::vector<IndexedDBKey> array_;
std::string binary_;
base::string16 string_;
double number_ = 0;
size_t size_estimate_;
};
// An index id, and corresponding set of keys to insert.
struct IndexedDBIndexKeys {
int64_t id;
std::vector<IndexedDBKey> keys;
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_PUBLIC_COMMON_INDEXEDDB_INDEXEDDB_KEY_H_