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

@crumb/warehouse

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@crumb/warehouse

Simple and unified API for accessing browser storage. Supports sessionStorage, localStorage, and cookies.

  • 1.0.0
  • unpublished
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
Maintainers
1
Weekly downloads
 
Created
Source

@crumb/warehouse

Simple and unified API for accessing browser storage. Supports sessionStorage, localStorage, and cookies.

Description

Warehouse is a simple and unified API used for accessing browser storage. Due to it's synchronous nature, Warehouse does not support asynchronous browser storage types such as IndexedDB or WebSQL. While this does prevent the use of other storage mechanisms, it greatly simplifies Warehouse for basic applications where synchronous storage mechanisms are sufficient.

Installation

# Yarn
yarn add @crumb/warehouse

# npm
npm install @crumb/warehouse

Basic Usage

To start, create a new Warehouse instance using the storage type you wish to use (i.e. sessionStorage, cookie).

import { Warehouse } from '@crumb/warehouse'

const warehouse = new Warehouse({ type: 'sessionStorage' })

After the warehouse is created, you can store, retrieve, and delete items from the warehouse.

warehouse.put('foo', 'bar')
warehouse.get('foo') // 'bar'
warehouse.remove('foo')

Data Types

Unlike the native browser APIs, Warehouse supports more than just string data by using JSON.stringify and JSON.parse when storing and retrieving items. For example, the code block below shows storing and retrieving an object.

If using TypeScript, you will notice that the example below shows how the get method accepts a type argument which will be used as the return type.

interface User {
  firstName: string
  lastName: string
}

warehouse.put('foo', {
  firstName: 'bar',
  lastName: 'baz',
})

warehouse.get<User>('foo') // { firstName: 'bar', lastName: 'baz' }

To set a cookie expiration when creating cookies, simply add the expireDays option when calling the put method. If not provided, an expiration will not be added to the cookie and thus will use the browser's default expiration of "Session".

warehouse.put('foo', 'bar', { expireDays: 7 })

Key Prefixing

One useful feature of Warehouse is the ability to define a key prefix to be added to all items that are stored. This is especially helpful for organizing items if you have multiple applications storing items on the same domain.

const warehouse = new Warehouse({
  type: 'sessionStorage',
  prefix: 'my-app-name-',
})

Multiple Warehouses

While some applications may only use a single type of storage, your application may require storing items in multiple browser storage types. To do so, simply create a separate Warehouse instance for each storage type you need.

The approach we recommend is to create a file to house all your instantiated warehouses (i.e. warehouses.js) so individual files or components can import and use the warehouses as they have need.

// warehouses.js
export const localStorageWarehouse = new Warehouse({ type: 'localStorage' })
export const cookieWarehouse = new Warehouse({ type: 'cookie' })
// app.js
import { localStorageWarehouse } from './warehouses'

console.log(localStorageWarehouse.get('foo'))

Keywords

FAQs

Package last updated on 29 Oct 2019

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