| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 #include "content/browser/indexed_db/indexed_db_database.h" | 5 #include "content/browser/indexed_db/indexed_db_database.h" |
| 6 | 6 |
| 7 #include <math.h> | 7 #include <math.h> |
| 8 | 8 |
| 9 #include <limits> | 9 #include <limits> |
| 10 #include <set> | 10 #include <set> |
| (...skipping 787 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 798 } | 798 } |
| 799 | 799 |
| 800 void IndexedDBDatabase::AddPendingObserver( | 800 void IndexedDBDatabase::AddPendingObserver( |
| 801 IndexedDBTransaction* transaction, | 801 IndexedDBTransaction* transaction, |
| 802 int32_t observer_id, | 802 int32_t observer_id, |
| 803 const IndexedDBObserver::Options& options) { | 803 const IndexedDBObserver::Options& options) { |
| 804 DCHECK(transaction); | 804 DCHECK(transaction); |
| 805 transaction->AddPendingObserver(observer_id, options); | 805 transaction->AddPendingObserver(observer_id, options); |
| 806 } | 806 } |
| 807 | 807 |
| 808 // TODO(palakj): Augment the function with IDBValue later. Issue | |
| 809 // crbug.com/609934. | |
| 810 void IndexedDBDatabase::FilterObservation(IndexedDBTransaction* transaction, | 808 void IndexedDBDatabase::FilterObservation(IndexedDBTransaction* transaction, |
| 811 int64_t object_store_id, | 809 int64_t object_store_id, |
| 812 blink::WebIDBOperationType type, | 810 blink::WebIDBOperationType type, |
| 813 const IndexedDBKeyRange& key_range) { | 811 const IndexedDBKeyRange& key_range, |
| 812 const IndexedDBValue* value) { |
| 814 for (auto* connection : connections_) { | 813 for (auto* connection : connections_) { |
| 815 bool recorded = false; | 814 bool recorded = false; |
| 816 for (const auto& observer : connection->active_observers()) { | 815 for (const auto& observer : connection->active_observers()) { |
| 817 if (!observer->IsRecordingType(type) || | 816 if (!observer->IsRecordingType(type) || |
| 818 !observer->IsRecordingObjectStore(object_store_id)) | 817 !observer->IsRecordingObjectStore(object_store_id)) |
| 819 continue; | 818 continue; |
| 820 if (!recorded) { | 819 if (!recorded) { |
| 821 auto observation = ::indexed_db::mojom::Observation::New(); | 820 auto observation = ::indexed_db::mojom::Observation::New(); |
| 822 observation->object_store_id = object_store_id; | 821 observation->object_store_id = object_store_id; |
| 823 observation->type = type; | 822 observation->type = type; |
| 824 if (type != blink::WebIDBClear) | 823 if (type != blink::WebIDBClear) |
| 825 observation->key_range = key_range; | 824 observation->key_range = key_range; |
| 826 transaction->AddObservation(connection->id(), std::move(observation)); | 825 transaction->AddObservation(connection->id(), std::move(observation)); |
| 827 recorded = true; | 826 recorded = true; |
| 828 } | 827 } |
| 829 transaction->RecordObserverForLastObservation(connection->id(), | 828 ::indexed_db::mojom::ObserverChangesPtr& changes = |
| 830 observer->id()); | 829 *transaction->GetPendingChangesForConnection(connection->id()); |
| 830 |
| 831 changes->observation_index_map[observer->id()].push_back( |
| 832 changes->observations.size() - 1); |
| 833 if (observer->include_transaction() && |
| 834 !base::ContainsKey(changes->transaction_map, observer->id())) { |
| 835 auto mojo_transaction = ::indexed_db::mojom::ObserverTransaction::New(); |
| 836 mojo_transaction->id = connection->NewObserverTransactionId(); |
| 837 mojo_transaction->scope.insert(mojo_transaction->scope.end(), |
| 838 observer->object_store_ids().begin(), |
| 839 observer->object_store_ids().end()); |
| 840 changes->transaction_map[observer->id()] = std::move(mojo_transaction); |
| 841 } |
| 842 if (value && observer->values() && !changes->observations.back()->value) { |
| 843 IndexedDBValue copy = *value; |
| 844 changes->observations.back()->value = |
| 845 IndexedDBCallbacks::ConvertValue(©); |
| 846 } |
| 831 } | 847 } |
| 832 } | 848 } |
| 833 } | 849 } |
| 834 | 850 |
| 835 void IndexedDBDatabase::SendObservations( | 851 void IndexedDBDatabase::SendObservations( |
| 836 std::map<int32_t, ::indexed_db::mojom::ObserverChangesPtr> changes_map) { | 852 std::map<int32_t, ::indexed_db::mojom::ObserverChangesPtr> changes_map) { |
| 837 for (auto* conn : connections_) { | 853 for (auto* conn : connections_) { |
| 838 auto it = changes_map.find(conn->id()); | 854 auto it = changes_map.find(conn->id()); |
| 839 if (it != changes_map.end()) | 855 if (it == changes_map.end()) |
| 840 conn->callbacks()->OnDatabaseChange(std::move(it->second)); | 856 continue; |
| 857 |
| 858 // Start all of the transactions. |
| 859 ::indexed_db::mojom::ObserverChangesPtr& changes = it->second; |
| 860 for (const auto& transaction_pair : changes->transaction_map) { |
| 861 std::set<int64_t> scope(transaction_pair.second->scope.begin(), |
| 862 transaction_pair.second->scope.end()); |
| 863 IndexedDBTransaction* transaction = conn->CreateTransaction( |
| 864 transaction_pair.second->id, scope, |
| 865 blink::WebIDBTransactionModeReadOnly, |
| 866 new IndexedDBBackingStore::Transaction(backing_store_.get())); |
| 867 DCHECK(transaction); |
| 868 transaction_coordinator_.DidCreateObserverTransaction(transaction); |
| 869 transaction_count_++; |
| 870 transaction->GrabSnapshotThenStart(); |
| 871 } |
| 872 |
| 873 conn->callbacks()->OnDatabaseChange(std::move(it->second)); |
| 841 } | 874 } |
| 842 } | 875 } |
| 843 | 876 |
| 844 void IndexedDBDatabase::GetAll(IndexedDBTransaction* transaction, | 877 void IndexedDBDatabase::GetAll(IndexedDBTransaction* transaction, |
| 845 int64_t object_store_id, | 878 int64_t object_store_id, |
| 846 int64_t index_id, | 879 int64_t index_id, |
| 847 std::unique_ptr<IndexedDBKeyRange> key_range, | 880 std::unique_ptr<IndexedDBKeyRange> key_range, |
| 848 bool key_only, | 881 bool key_only, |
| 849 int64_t max_count, | 882 int64_t max_count, |
| 850 scoped_refptr<IndexedDBCallbacks> callbacks) { | 883 scoped_refptr<IndexedDBCallbacks> callbacks) { |
| (...skipping 483 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1334 } | 1367 } |
| 1335 { | 1368 { |
| 1336 IDB_TRACE1("IndexedDBDatabase::PutOperation.Callbacks", "txn.id", | 1369 IDB_TRACE1("IndexedDBDatabase::PutOperation.Callbacks", "txn.id", |
| 1337 transaction->id()); | 1370 transaction->id()); |
| 1338 params->callbacks->OnSuccess(*key); | 1371 params->callbacks->OnSuccess(*key); |
| 1339 } | 1372 } |
| 1340 FilterObservation(transaction, params->object_store_id, | 1373 FilterObservation(transaction, params->object_store_id, |
| 1341 params->put_mode == blink::WebIDBPutModeAddOnly | 1374 params->put_mode == blink::WebIDBPutModeAddOnly |
| 1342 ? blink::WebIDBAdd | 1375 ? blink::WebIDBAdd |
| 1343 : blink::WebIDBPut, | 1376 : blink::WebIDBPut, |
| 1344 IndexedDBKeyRange(*key)); | 1377 IndexedDBKeyRange(*key), ¶ms->value); |
| 1345 return s; | 1378 return s; |
| 1346 } | 1379 } |
| 1347 | 1380 |
| 1348 void IndexedDBDatabase::SetIndexKeys( | 1381 void IndexedDBDatabase::SetIndexKeys( |
| 1349 IndexedDBTransaction* transaction, | 1382 IndexedDBTransaction* transaction, |
| 1350 int64_t object_store_id, | 1383 int64_t object_store_id, |
| 1351 std::unique_ptr<IndexedDBKey> primary_key, | 1384 std::unique_ptr<IndexedDBKey> primary_key, |
| 1352 const std::vector<IndexedDBIndexKeys>& index_keys) { | 1385 const std::vector<IndexedDBIndexKeys>& index_keys) { |
| 1353 DCHECK(transaction); | 1386 DCHECK(transaction); |
| 1354 IDB_TRACE1("IndexedDBDatabase::SetIndexKeys", "txn.id", transaction->id()); | 1387 IDB_TRACE1("IndexedDBDatabase::SetIndexKeys", "txn.id", transaction->id()); |
| (...skipping 293 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1648 IDB_TRACE1("IndexedDBDatabase::DeleteRangeOperation", "txn.id", | 1681 IDB_TRACE1("IndexedDBDatabase::DeleteRangeOperation", "txn.id", |
| 1649 transaction->id()); | 1682 transaction->id()); |
| 1650 size_t delete_count = 0; | 1683 size_t delete_count = 0; |
| 1651 leveldb::Status s = | 1684 leveldb::Status s = |
| 1652 backing_store_->DeleteRange(transaction->BackingStoreTransaction(), id(), | 1685 backing_store_->DeleteRange(transaction->BackingStoreTransaction(), id(), |
| 1653 object_store_id, *key_range, &delete_count); | 1686 object_store_id, *key_range, &delete_count); |
| 1654 if (!s.ok()) | 1687 if (!s.ok()) |
| 1655 return s; | 1688 return s; |
| 1656 callbacks->OnSuccess(); | 1689 callbacks->OnSuccess(); |
| 1657 FilterObservation(transaction, object_store_id, blink::WebIDBDelete, | 1690 FilterObservation(transaction, object_store_id, blink::WebIDBDelete, |
| 1658 *key_range); | 1691 *key_range, nullptr); |
| 1659 return s; | 1692 return s; |
| 1660 } | 1693 } |
| 1661 | 1694 |
| 1662 void IndexedDBDatabase::Clear(IndexedDBTransaction* transaction, | 1695 void IndexedDBDatabase::Clear(IndexedDBTransaction* transaction, |
| 1663 int64_t object_store_id, | 1696 int64_t object_store_id, |
| 1664 scoped_refptr<IndexedDBCallbacks> callbacks) { | 1697 scoped_refptr<IndexedDBCallbacks> callbacks) { |
| 1665 DCHECK(transaction); | 1698 DCHECK(transaction); |
| 1666 IDB_TRACE1("IndexedDBDatabase::Clear", "txn.id", transaction->id()); | 1699 IDB_TRACE1("IndexedDBDatabase::Clear", "txn.id", transaction->id()); |
| 1667 DCHECK_NE(transaction->mode(), blink::WebIDBTransactionModeReadOnly); | 1700 DCHECK_NE(transaction->mode(), blink::WebIDBTransactionModeReadOnly); |
| 1668 | 1701 |
| 1669 if (!ValidateObjectStoreId(object_store_id)) | 1702 if (!ValidateObjectStoreId(object_store_id)) |
| 1670 return; | 1703 return; |
| 1671 | 1704 |
| 1672 transaction->ScheduleTask(base::Bind( | 1705 transaction->ScheduleTask(base::Bind( |
| 1673 &IndexedDBDatabase::ClearOperation, this, object_store_id, callbacks)); | 1706 &IndexedDBDatabase::ClearOperation, this, object_store_id, callbacks)); |
| 1674 } | 1707 } |
| 1675 | 1708 |
| 1676 leveldb::Status IndexedDBDatabase::ClearOperation( | 1709 leveldb::Status IndexedDBDatabase::ClearOperation( |
| 1677 int64_t object_store_id, | 1710 int64_t object_store_id, |
| 1678 scoped_refptr<IndexedDBCallbacks> callbacks, | 1711 scoped_refptr<IndexedDBCallbacks> callbacks, |
| 1679 IndexedDBTransaction* transaction) { | 1712 IndexedDBTransaction* transaction) { |
| 1680 IDB_TRACE1("IndexedDBDatabase::ClearOperation", "txn.id", transaction->id()); | 1713 IDB_TRACE1("IndexedDBDatabase::ClearOperation", "txn.id", transaction->id()); |
| 1681 leveldb::Status s = backing_store_->ClearObjectStore( | 1714 leveldb::Status s = backing_store_->ClearObjectStore( |
| 1682 transaction->BackingStoreTransaction(), id(), object_store_id); | 1715 transaction->BackingStoreTransaction(), id(), object_store_id); |
| 1683 if (!s.ok()) | 1716 if (!s.ok()) |
| 1684 return s; | 1717 return s; |
| 1685 callbacks->OnSuccess(); | 1718 callbacks->OnSuccess(); |
| 1686 | 1719 |
| 1687 FilterObservation(transaction, object_store_id, blink::WebIDBClear, | 1720 FilterObservation(transaction, object_store_id, blink::WebIDBClear, |
| 1688 IndexedDBKeyRange()); | 1721 IndexedDBKeyRange(), nullptr); |
| 1689 return s; | 1722 return s; |
| 1690 } | 1723 } |
| 1691 | 1724 |
| 1692 leveldb::Status IndexedDBDatabase::DeleteObjectStoreOperation( | 1725 leveldb::Status IndexedDBDatabase::DeleteObjectStoreOperation( |
| 1693 int64_t object_store_id, | 1726 int64_t object_store_id, |
| 1694 IndexedDBTransaction* transaction) { | 1727 IndexedDBTransaction* transaction) { |
| 1695 IDB_TRACE1("IndexedDBDatabase::DeleteObjectStoreOperation", | 1728 IDB_TRACE1("IndexedDBDatabase::DeleteObjectStoreOperation", |
| 1696 "txn.id", | 1729 "txn.id", |
| 1697 transaction->id()); | 1730 transaction->id()); |
| 1698 | 1731 |
| (...skipping 213 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1912 if (status.IsCorruption()) { | 1945 if (status.IsCorruption()) { |
| 1913 IndexedDBDatabaseError error(blink::WebIDBDatabaseExceptionUnknownError, | 1946 IndexedDBDatabaseError error(blink::WebIDBDatabaseExceptionUnknownError, |
| 1914 message); | 1947 message); |
| 1915 factory_->HandleBackingStoreCorruption(backing_store_->origin(), error); | 1948 factory_->HandleBackingStoreCorruption(backing_store_->origin(), error); |
| 1916 } else { | 1949 } else { |
| 1917 factory_->HandleBackingStoreFailure(backing_store_->origin()); | 1950 factory_->HandleBackingStoreFailure(backing_store_->origin()); |
| 1918 } | 1951 } |
| 1919 } | 1952 } |
| 1920 | 1953 |
| 1921 } // namespace content | 1954 } // namespace content |
| OLD | NEW |