/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ use ipc_channel::ipc::IpcSender; use serde::{Deserialize, Serialize}; use servo_url::origin::ImmutableOrigin; // https://www.w3.org/TR/IndexedDB-2/#enumdef-idbtransactionmode #[derive(Debug, Deserialize, Serialize)] pub enum IndexedDBTxnMode { Readonly, Readwrite, Versionchange, } // https://www.w3.org/TR/IndexedDB-2/#key-type // FIXME:(arihant2math) Ordering needs to completely be reimplemented as per https://www.w3.org/TR/IndexedDB-2/#compare-two-keys #[derive(Clone, Debug, Deserialize, PartialEq, PartialOrd, Serialize)] pub enum IndexedDBKeyType { Number(f64), String(String), Binary(Vec), // FIXME:(arihant2math) Date should not be stored as a Vec Date(Vec), Array(Vec), // FIXME:(arihant2math) implment ArrayBuffer } // #[derive(Clone, Debug, Default, Deserialize, Serialize)] #[allow(unused)] pub struct IndexedDBKeyRange { pub lower: Option, pub upper: Option, pub lower_open: bool, pub upper_open: bool, } impl From for IndexedDBKeyRange { fn from(key: IndexedDBKeyType) -> Self { IndexedDBKeyRange { lower: Some(key.clone()), upper: Some(key), ..Default::default() } } } impl IndexedDBKeyRange { // pub fn contains(&self, key: &IndexedDBKeyType) -> bool { // A key is in a key range if both of the following conditions are fulfilled: // The lower bound is null, or it is less than key, // or it is both equal to key and the lower open flag is unset. // The upper bound is null, or it is greater than key, // or it is both equal to key and the upper open flag is unset let lower_bound_condition = self .lower .as_ref() .is_none_or(|lower| lower < key || (!self.lower_open && lower == key)); let upper_bound_condition = self .upper .as_ref() .is_none_or(|upper| key < upper || (!self.upper_open && key == upper)); lower_bound_condition && upper_bound_condition } } // Operations that are not executed instantly, but rather added to a // queue that is eventually run. #[derive(Debug, Deserialize, Serialize)] pub enum AsyncOperation { /// Gets the value associated with the given key in the associated idb data GetItem( IndexedDBKeyType, // Key ), /// Sets the value of the given key in the associated idb data PutItem( IndexedDBKeyType, // Key Vec, // Value bool, // Should overwrite ), /// Removes the key/value pair for the given key in the associated idb data RemoveItem( IndexedDBKeyType, // Key ), Count( IndexedDBKeyType, // Key ), } #[derive(Debug, Deserialize, Serialize)] pub enum SyncOperation { // Upgrades the version of the database UpgradeVersion( IpcSender>, ImmutableOrigin, String, // Database u64, // Serial number for the transaction u64, // Version to upgrade to ), // Checks if an object store has a key generator, used in e.g. Put HasKeyGenerator( IpcSender, ImmutableOrigin, String, // Database String, // Store ), // Commits changes of a transaction to the database Commit( IpcSender>, ImmutableOrigin, String, // Database u64, // Transaction serial number ), // Creates a new store for the database CreateObjectStore( IpcSender>, ImmutableOrigin, String, // Database String, // Store bool, ), DeleteObjectStore( IpcSender>, ImmutableOrigin, String, // Database String, // Store ), CloseDatabase( IpcSender>, ImmutableOrigin, String, // Database ), OpenDatabase( IpcSender, // Returns the version ImmutableOrigin, String, // Database Option, // Eventual version ), // Deletes the database DeleteDatabase( IpcSender>, ImmutableOrigin, String, // Database ), // Returns an unique identifier that is used to be able to // commit/abort transactions. RegisterNewTxn( IpcSender, ImmutableOrigin, String, // Database ), // Starts executing the requests of a transaction // https://www.w3.org/TR/IndexedDB-2/#transaction-start StartTransaction( IpcSender>, ImmutableOrigin, String, // Database u64, // The serial number of the mutating transaction ), // Returns the version of the database Version( IpcSender, ImmutableOrigin, String, // Database ), /// Send a reply when done cleaning up thread resources and then shut it down Exit(IpcSender<()>), } #[derive(Debug, Deserialize, Serialize)] pub enum IndexedDBThreadMsg { Sync(SyncOperation), Async( IpcSender>>, // Sender to send the result of the async operation ImmutableOrigin, String, // Database String, // ObjectStore u64, // Serial number of the transaction that requests this operation IndexedDBTxnMode, AsyncOperation, ), }