Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

vault-storage

Package Overview
Dependencies
Maintainers
1
Versions
22
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

vault-storage

Vault, a tiny yet robuts storage library for your browser applications

  • 1.0.3
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
7
decreased by-75.86%
Maintainers
1
Weekly downloads
 
Created
Source

vault

vault is a sophisticated browser-based storage library that leverages the power of IndexedDB, offering significant improvements over traditional LocalStorage. As a high-performance, asynchronous solution for client-side storage, vault provides an intuitive and easy-to-use API to interact with IndexedDB, making client-side data storage efficient and scalable.

Features

  • Similar API: Easy to use, similar to LocalStorage.
  • Lightweight: No dependencies, small footprint (~800 bytes minified, ~400 bytes gzipped).
  • Asynchronous: Non-blocking, asynchronous API.
  • Structured Data: Supports structured data, including objects and arrays.

Installation

Install vault-storage using npm:

npm install vault-storage --save

Or using yarn:

yarn add vault-storage

Usage

First, import vault-storage in your project:

import vault from 'vault-storage';

Initializing and Setup

By default, the vault does not need any special initialization or setup!!! In this way, it behaves similar to the local and session storages, It uses default database and store names.

Just start using it!

// Set the values.
vault.key1 = "value1";
vault.key2 = "value2";

// Get the values. Remember to use await! As it's asynchronous.
const value1 = await vault.key1; // "value1"
const value2 = await vault.key2; // "value2"

However, if you want to change the default database and store names, you can initialize the vault with your custom database and store names before using it.

// Initialize the vault with custom database and store names.
vault.init('myDatabase', 'myStore');

Note: This will change the default database and store names for all instances of vault in your application.

Setting Values

Store data using the setItem method, indexer syntax, or dot notation:


 // For set operation you can ignore await unless you want to wait for the
 // operation to complete or you want to catch any errors.
vault.setItem('yourKey', { any: 'data' });

// Indexer syntax.
vault['yourKey'] = { any: 'data' };

// Dot notation.
vault.yourKey = { any: 'data' };

Getting Values

Retrieve data using the getItem method, indexer syntax, or dot notation. For get operations you must use await as it's asynchronous.

// Get the value using the getItem method.
const data = await vault.getItem('yourKey');

// Indexer syntax.
const data = await vault['yourKey'];

// Dot notation.
const data = await vault.yourKey;

Removing Values

Remove data using the removeItem method:

// Remove the value using the remove method.
vault.removeItem('yourKey');

// Indexer syntax.
delete vault['yourKey'];

// Dot notation.
delete vault.yourKey;

Clearing All Data

Clear all data from the store:

await vault.clear();

Getting Store Length

Get the count of entries in the store:

const count = await vault.length();
console.log(count);

API Reference

  • setItem(key: string, value: any): Store data in the database.
  • getItem(key: string): Retrieve data from the database.
  • removeItem(key: string): Remove data from the database.
  • clear(): Clear all data from the database.
  • length(): Get the count of entries in the database.

Comparing vault with LocalStorage

Featurevault (IndexedDB)LocalStorage
API ComplexitySimple, intuitive APISimple, intuitive API
CapacityLarge (up to browser limit, often no less than 250MB)Limited (5MB typical)
Data TypesSupports structured data, including objects and arraysOnly stores strings
PerformanceAsynchronous, non-blockingSynchronous, can block UI
Transaction SupportComplete transaction support for reliable data operationsNone
Query CapabilitiesComplex querying and indexingOnly key-based access
Data IntegrityRobust with versioning and error handlingProne to data conflicts

Contributing

Contributions to vault-storage are welcome. Please ensure that your code adheres to the existing style and includes tests covering new features or bug fixes.

License

vault-storage is MIT licensed.

FAQs

Package last updated on 01 Jan 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc