Packages

Our project consists of three main packages, each designed to enhance your database experience:

Package NameDescriptionLink
wasmThe rust source for DB, contains its core logic, optimisations, algorithms and cryptography functionality.View on GitHub
ridbMain project with RIDB core functionality.View on GitHub
ridb-levelAn Storage for level-based storage (NODEJS).View on GitHub
ridb-reactUse RIDB in react directly with JSX.View on GitHub

Security

We take security very seriously and have implemented robust measures to ensure data protection. Below are the specifications for our security features:

FeatureDescription
Password HashingWe use PBKDF2 (Password-Based Key Derivation Function 2) with HMAC-SHA3-256 for password hashing. This method involves multiple iterations to enhance security against brute-force attacks. Learn more about PBKDF2
EncryptionData is encrypted using AES-256-GCM (Advanced Encryption Standard with Galois/Counter Mode), which provides both confidentiality and integrity. Learn more about AES-GCM
IntegrityWe ensure data integrity by hashing data with SHA3-512 and comparing it with the stored hash to detect any tampering. Learn more about SHA-3

Supported features

By default RIDB is bundled with a default InMemory storage with support for write, create, update, fetch one, remove, find and count operations.

FeatureDescription
SchemasCreation of declarative schemas with required fields, default and encrypted fields
ValidationImplement validation across all the flows extracting properties and required fields when needed
Primary Key ManagementPrimary key and index management
Plugin EngineExtend the functionality of your Database implementation with wasm or Javascript plugins
Data Encryption PluginSecure data with encryption plugins
Migration PluginSupport for data migrations
Integrity PluginSupport for data has not been tampered with
IndexDB StorageRobust type safe replacement for Dexie
InMemory StorageRobust type safe implementation of an inMemory storage
LevelDB StorageRobust type safe implementation for LevelDB 'classic-level'
SharedWorkerUse the database in a SharedWorker for better performance in the browser

Contributing

I'm very welcome to contributions from anyone, feel free to always open an Issue or create a Pull request. I'll try to be as transparent as I can around the things that are needed for the project.

Main priorities:

  • Improve documentation
  • Adding more examples
  • Testing and code coverage