hive_plus_secure 1.1.15
hive_plus_secure: ^1.1.15 copied to clipboard
Lightweight and blazing fast key-value database written in pure Dart. Strongly encrypted using AES-256. Fork of the original Hive package with continued maintenance.
1.1.15 #
Features #
- Custom Serialization Support: Added support for custom
toJsonserializers inregisterAdapter()- Allows registration of types with custom serialization logic (e.g., generic classes with type parameters)
- New signature:
registerAdapter<T>(String typeName, T? Function(dynamic json) fromJson, Type? type, [Map<String, dynamic>? Function(T value)? toJson]) - Enables proper serialization of complex types like
SyncOperation<T>that require serializer callbacks - Backward compatible -
toJsonparameter is optional
Bug Fixes #
- Fixed JSON encoding errors for types with parameterized
toJson()methods - Resolved "Converting object to an encodable object failed" errors when storing generic types
1.1.14 #
Bug Fixes #
- Fixed ID Assignment: Fixed
put()method to reuse existing frame ID when updating a value instead of always creating a new auto-incremented ID- This resolves potential memory leaks and ensures proper key-value updates
Improvements #
- Updated dependency
isar_plusto version^1.0.21for improved stability and performance
1.1.13 #
Improvements #
- Updated dependency
isar_plusto version^1.0.20for improved stability and performance.
1.1.12 #
Improvements #
- Updated dependency
isar_plusto version^1.0.19for improved stability and performance.
1.1.11 #
Improvements #
- Enhanced Export API: Added export for
ChangeTypeenum fromisar_pluspackage for better API access and type safety when working with change details
1.1.10 #
Improvements #
- Updated dependency
isar_plusto version^1.0.18for improved stability and performance.
1.1.9 #
Improvements #
- Updated dependency
isar_plusto version^1.0.17for improved stability and performance.
1.1.8 #
Improvements #
- Updated dependency
isar_plusto version^1.0.16for improved stability and performance.
1.1.7 #
Improvements #
- Updated dependency
isar_plusto version^1.0.15for improved stability and performance.
1.1.6 #
Features #
- Enhanced Watch API: Added optional
documentParserparameter towatchDetailed<T>()method for custom document parsing- Allows users to provide custom parsing logic for better type safety and flexibility
- Method signature:
watchDetailed<T>({T Function(Map<String, dynamic>)? documentParser})
Improvements #
- Updated dependency
isar_plusto version^1.0.14for enhanced functionality and stability
1.1.5 #
Improvements #
- exported
DocumentSerializablefromisar_pluspackage for better type constraints inwatchDetailed<T>()method
1.1.4 #
Features #
- Enhanced Type Safety: Added generic type parameter support to
watchDetailed<T>()method for improved type safety - Export Enhancement: Added export for
ChangeDetailclass fromisar_pluspackage for better API access - Improved Documentation: Comprehensive documentation updates for
watchDetailed()method including:- Detailed usage examples with type-safe document parsing
- Platform support information (web platform limitations)
- Performance considerations and best practices
- Clear explanation of change types and thread safety
Breaking Changes #
Box.watchDetailed()method now requires a generic type parameterT extends DocumentSerializable- Method signature changed from
Stream<ChangeDetail> watchDetailed()toStream<ChangeDetail<T>> watchDetailed<T extends DocumentSerializable>()
1.1.2 #
Improvements #
- Updated dependency
isar_plusto version^1.0.12for improved stability and performance.
1.1.1 #
Improvements #
- Watcher Functionality: Added
WatcherDetailsclass for improved watcher management - Box Implementation: Enhanced box implementation with better watcher support
- Code Organization: Improved internal structure and removed obsolete test files
1.1.0 #
Features #
- Enhanced Watch API: Implemented generic
watch()method with type-safe key parameters- Added
WatchEvent<K, E>class for better API ergonomics with.keyand.valueproperties - Support for both String and int key types with proper generic constraints
- Replaced tuple return type
(K, E?)with user-friendlyWatchEvent<K, E> - Example usage:
box.watch<String>(key: 'myKey').listen((event) { String key = event.key; // Type-safe key access String? value = event.value; // Type-safe value access print('Key: $key, Value: $value'); });
- Added
Breaking Changes #
Box.watch()method now returnsStream<WatchEvent<K, E>>instead ofStream<(K, E?)>- Users should update their watch handlers to use
.keyand.valueproperties
1.0.0 #
Hive Plus Fork #
This package is a maintained fork of the original Hive package. The original Hive package is no longer actively maintained, so this fork continues development and maintenance.
Key changes in this fork:
- Package renamed from
hivetohive_plus - Updated repository and homepage links
- Continued maintenance and bug fixes
- Library name changed to
hive_plus
This is a complete rewrite of Hive. It is not compatible with older versions of Hive yet.
Hive Plus now uses Isar internally which brings all the benefits of a native database to Hive.
Enchantments #
- Much more resource efficiency
- Support for access from multiple isolates
- Support for transactions
- No more issues with concurrent access and corruption
- Vastly reduced startup time
- No more code generation
Original Hive Changelog (DEPRECATED) #
All versions below are from the original Hive package and are deprecated. Use hive_plus instead.
4.0.0-dev.0 (Original Hive - DEPRECATED) #
⚠️ THIS VERSION OF HIVE IS UNSTABLE AND NOT READY FOR PRODUCTION USE ⚠️ ⚠️ DEPRECATED: Use hive_plus instead ⚠️
This is a complete rewrite of Hive. It is not compatible with older versions of Hive yet.
Hive now uses Isar internally which brings all the benefits of a native database to Hive.
Enchantments #
- Much more resource efficiency
- Support for access from multiple isolates
- Support for transactions
- No more issues with concurrent access and corruption
- Vastly reduced startup time
- No more code generation
3.0.0-dev (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Enchantments #
- Implemented in-memory storage backend
- Added
notifyparameter to public APIs - Web Worker support
- Threaded AesCipher support (requires hive_flutter >=2.0.0-dev)
2.2.3 (DEPRECATED) #
2.2.2 (DEPRECATED) #
2.2.1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Fixes #
- Retracted [email protected] from pub.dev
- Fixed hive web backend null value exception - #968
2.2.0 (DEPRECATED) #
2.1.0 (DEPRECATED) #
2.0.6 (DEPRECATED) #
2.0.5 (DEPRECATED) #
2.0.4 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Enhancements #
- Adds default value support to hive_generator generated class adapters
2.0.3 (DEPRECATED) #
2.0.2 (DEPRECATED) #
2.0.1 (DEPRECATED) #
1.6.0-nullsafety.2 (DEPRECATED) #
1.6.0-nullsafety.1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Fixes #
- Changed
metadependency version to^1.3.0-nullsafetyto support null-safety
1.6.0-nullsafety.0 (DEPRECATED) #
1.5.0-pre (DEPRECATED) #
1.4.4+1 (DEPRECATED) #
1.4.3 (DEPRECATED) #
1.4.2 (DEPRECATED) #
1.4.1+1 (DEPRECATED) #
1.4.1 (DEPRECATED) #
1.4.0+1 (DEPRECATED) #
1.4.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Enhancements #
- ~1000% encryption / decryption performance improvement
- Added option to implement custom encryption algorithm
- Added
box.valuesBetween(startKey, endKey) - Allow tree shaking to drop encryption engine if no encryption is used
Fixes #
Hive.deleteBoxFromDisk()did not work for boxes with upper-case names
More #
- Deprecated
encryptionKeyparameter. UseHive.openBox('name', encryptionCipher: HiveAesCipher(yourKey)). - Dropped
pointycastledependency - Dropped
pathdependency
1.3.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Use latest version of hive_generator
Breaking changes #
TypeAdaptersand@HiveType()now require atypeIdHive.registerAdapter()does not need atypeIdanymore.- Removed
BinaryReader.readAsciiString() - Removed
BinaryWriter.writeAsciiString()
Enhancements #
- New documentation with tutorials and live code
Fixes #
box.clear()resets auto increment counter
More #
- Not calling
Hive.init()results in better exception
1.2.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Breaking changes #
- Removed the
Hive.pathgetter - Removed
Hive.openBoxFromBytes()(use thebytesparameter ofHive.openBox()instead) LazyBoxandBoxnow have a common parent class:BoxBase- Lazy boxes need to be opened using
Hive.openLazyBox() - Open lazy boxes can be acquired using
Hive.lazyBox() - Box name bug resolved (more information below)
Enhancements #
- Support for relationships,
HiveLists(see docs for details) - Support for inheritance
- Lazy boxes can now have a type argument
LazyBox<YourModel> - Added method to delete boxes without opening them
Hive.deleteBoxFromDisk() - Added
pathparameter to open boxes in a custom path - Improved documentation
Fixes #
HiveObjectshave not been initialized correctly in lazy boxes- Fixed bug where uppercase box name resulted in an uppercase filename
- Fixed compaction bug which caused corrupted boxes
- Fixed bug which did not allow the key
0xFFFFFFFF - Fixed bug where not all
BoxEvents have been broadcasted
More #
- Changed type of
encryptionKeyfromUint8ListtoList<int>
Important: #
Due to a bug in previous Hive versions, boxes whose name contains uppercase characters were stored in a file that also contains upper case characters (e.g. 'myBox' -> 'myBox.hive').
To avoid different behavior on case sensitive file systems, Hive should store files with lower case names. This bug has been resolved in version 1.2.0.
If your box name contains upper case characters, the new version will not find a box stored by an older version. Please rename the hive file manually in that case.
This also applies to the web version.
1.1.1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Breaking changes #
object.delete()now throws exception if object is not stored in a box
Fixes #
- Fixed bug where
object.save()would fail on subsequent calls
1.1.0+2 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Fixes #
- Fixed bug that it was not possible to open typed boxes (
Box<E>)
1.1.0+1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Fixes #
- Fixed bug that corrupted boxes were not detected
1.1.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Breaking changes #
- Changed return type of
addAll()fromList<int>toIterable<int>. - Removed the option to register
TypeAdaptersfor a specific box. E.g.box.registerTypeAdapter(). getAt(),putAt(),deleteAt()andkeyAt()no longer allow indices out of range.
Enhancements #
- Added
HiveObject - Boxes have now an optional type parameter
Box<E> - Support opening boxes from assets
Fixes #
- Fixed bug which was caused by not awaiting write operations
- Fixed bug where custom compaction strategy was not applied
- Hive now locks box files while they are open to prevent concurrent access from multiple processes
More #
- Improved performance of
putAll(),deleteAll(),add(),addAll() - Changed
valuesparameter ofaddAll()fromListtoIterable - Improved documentation
- Preparation for queries
1.0.0 (Original Hive - DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- First stable release
0.5.1+1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Change
keysparameter ofdeleteAllfromListtoIterable - Fixed bug in
BinaryWriter
0.5.1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Fixed
Hive.init()bug in browser - Fixed a bug with large lists or strings
- Improved box opening time in the browser
- Improved general write performance
- Improved docs
- Added integration tests
0.5.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Added
keyComparatorparameter for custom key order - Added
isEmptyandisNotEmptygetters to box - Added support for reading and writing subclasses
- Removed length limitation for Lists, Maps, and Strings
- Greatly improved performance of storing Uint8Lists in browser
- Removed CRC check in the browser (not needed)
- Improved documentation
- TypeIds are now allowed in the range of 0-223
- Fixed compaction
- Fixed writing longer Strings
- Breaking: Binary format changed
0.4.1+1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Document all public APIs
- Fixed flutter_web error
0.4.1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Allow different versions of the
pathpackage
0.4.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Added
BigIntsupport - Added
compactionStrategyparameter - Added automatic crash recovery
- Added
add()andaddAll()for auto-increment keys - Added
getAt(),putAt()anddeleteAt()for working with indices - Support for int (32 bit unsigned) keys
- Non-lazy boxes now notify their listeners immediately about changes
- Bugfixes
- More tests
- Breaking: Open boxes with
openBox() - Breaking: Writing
nullis no longer equivalent to deleting a key - Breaking: Temporarily removed support for transactions. New API design needed. Will be coming back in a future version.
- Breaking: Binary format changed
- Breaking: API changes
0.3.0+1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Bugfix:
Hive['yourBox']didn't work with uppercase box names
0.3.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Big step towards stable API
- Support for transactions
- Annotations for hive_generator
- Bugfixes
- Improved web support
- Breaking:
inMemory->lazy - Breaking: Binary format changed
0.2.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Support for dart2js
- Improved performance
- Added
inMemoryoption - Breaking: Minor API changes
- Breaking: Changed Endianness to little
- Breaking: Removed Migrator
0.1.1 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Downgrade to
meta: ^1.1.6to support flutter
0.1.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- First release