-
Notifications
You must be signed in to change notification settings - Fork 64
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow more explicit control over transaction lifetimes #34
Comments
My thoughts on both of these are captured in these gists: |
In addition, for many puts, the overhead of all the individual success events can jank the main thread. We may want to design this in such a way that the transaction just opts-out of the per-request events entirely - possibly |
TPAC 2019 Web Apps breakout: Looked at two proposals:
Notes:
Next steps: make concrete proposals; reach out to library authors to get feedback on preferences |
I'd like to give my real-world example of how pain is it to use Indexed DB v2. I have a database called In version 2, I need to change from Even worse, in Indexed DB v2, I can't query the database version (it's a v3 API and only Chrome support it now) so I can't open the current version (1) based on the query result and prepare all async data I need, then open the database in version 2 to use previously prepared data to move from 'CryptoKey In the end, I have to open my database like this: (and I think this kind of solution is very, very ugly)
|
The web locks API shares a lot in common with this, I wonder if the concepts actually map one-to-one, for example we have Then there's also requests for timeouts on indexxedDB transactions, this could naturally be built on top stealing locks. In a lot of ways this would actually be safer for indexxeddb as the whole transaction can be rolled back instead of committed. I wonder if would actually be possible to simply share the architecture such that in request a lock, instead of simply taking a name, it could take an indexxeddb transaction record instead. This way indexeddb wouldn't need to build it's own concept of locking. |
Putting my hat in the ring here for more control over transaction lifetimes and/or better composability with promises/async/await. My use case is the implementation of an abstract data structure, think linked list, or tree, with persistence and encryption-at-rest. In practice that means I need to be able to read a node in my structure from IndexedDB, decrypt it (which is an async operation) and then use the decrypted content to identify which next node to load from IndexedDB to traverse my data structure. Say I want to give transaction semantics to a list reorder, or tree insert operation, I will have to read and write a number of entries from IndexedDB and further entries based on encrypting those entries. All of which I can’t do at the moment because of the auto commit behaviour. I can live with either an explicit The goal here is to provide special-purpose data management APIs that support transparent encryption-at-rest in scenarios where a simple (and today ubiquitous) device-level encryption is not satisfactory (e.g. when devices are shared among multiple users with the same system “login”). Aside from the consistency guarantees that I can’t implement today, this works quite well already. I’d love to be able to offer this as a proper safe solution with official Web API support. I’m happy to elaborate or answer any further questions on this. Thanks! <3 |
We discussed this at TPAC 2024 again and I believe there was more or less consensus on this option:
The advantages are that it's simple to understand and implement. The main drawback is that it's a footgun to make it possible to wedge an entire database by forgetting to call |
Imported from https://www.w3.org/Bugs/Public/show_bug.cgi?id=11528
Based on lots of developer feedback, in addition to the current automatic commit model it would be nice to support:
Both make the transaction model more complex, so we should tread carefully.
The text was updated successfully, but these errors were encountered: