hive_plus_secure 1.1.14
hive_plus_secure: ^1.1.14 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.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_plus
to version^1.0.21
for improved stability and performance
1.1.13 #
Improvements #
- Updated dependency
isar_plus
to version^1.0.20
for improved stability and performance.
1.1.12 #
Improvements #
- Updated dependency
isar_plus
to version^1.0.19
for improved stability and performance.
1.1.11 #
Improvements #
- Enhanced Export API: Added export for
ChangeType
enum fromisar_plus
package for better API access and type safety when working with change details
1.1.10 #
Improvements #
- Updated dependency
isar_plus
to version^1.0.18
for improved stability and performance.
1.1.9 #
Improvements #
- Updated dependency
isar_plus
to version^1.0.17
for improved stability and performance.
1.1.8 #
Improvements #
- Updated dependency
isar_plus
to version^1.0.16
for improved stability and performance.
1.1.7 #
Improvements #
- Updated dependency
isar_plus
to version^1.0.15
for improved stability and performance.
1.1.6 #
Features #
- Enhanced Watch API: Added optional
documentParser
parameter 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_plus
to version^1.0.14
for enhanced functionality and stability
1.1.5 #
Improvements #
- exported
DocumentSerializable
fromisar_plus
package 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
ChangeDetail
class fromisar_plus
package 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_plus
to version^1.0.12
for improved stability and performance.
1.1.1 #
Improvements #
- Watcher Functionality: Added
WatcherDetails
class 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.key
and.value
properties - 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
.key
and.value
properties
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
hive
tohive_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
notify
parameter 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 hive@2.2.0 from pub.flutter-io.cn
- 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
meta
dependency version to^1.3.0-nullsafety
to 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
encryptionKey
parameter. UseHive.openBox('name', encryptionCipher: HiveAesCipher(yourKey))
. - Dropped
pointycastle
dependency - Dropped
path
dependency
1.3.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
Use latest version of hive_generator
Breaking changes #
TypeAdapters
and@HiveType()
now require atypeId
Hive.registerAdapter()
does not need atypeId
anymore.- 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.path
getter - Removed
Hive.openBoxFromBytes()
(use thebytes
parameter ofHive.openBox()
instead) LazyBox
andBox
now 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
path
parameter to open boxes in a custom path - Improved documentation
Fixes #
HiveObjects
have 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
BoxEvent
s have been broadcasted
More #
- Changed type of
encryptionKey
fromUint8List
toList<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
TypeAdapters
for 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
values
parameter ofaddAll()
fromList
toIterable
- 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
keys
parameter ofdeleteAll
fromList
toIterable
- 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
keyComparator
parameter for custom key order - Added
isEmpty
andisNotEmpty
getters 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
path
package
0.4.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- Added
BigInt
support - Added
compactionStrategy
parameter - 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
null
is 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
inMemory
option - 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.6
to support flutter
0.1.0 (DEPRECATED) #
⚠️ DEPRECATED: Use hive_plus instead ⚠️
- First release