npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

simple-storage-cache

v1.2.4

Published

Simple Storage Cache to save API responses and avoid unnecessary requests.

Downloads

233

Readme

Simple Storage Cache npm version

build and release codecov CodeFactor

Simple Storage Cache to save API responses and avoid unnecessary requests.

Dependencies-free and super small.

install size

Usage

Install simple-storage-cache:

npm install simple-storage-cache

Create an instance with the key that you want to use and the expiration time in milliseconds:

import Cache from 'simple-storage-cache';

const ONE_MINUTE = 60000;
const KEY = 'somekey'; 
const cache = new Cache(KEY, ONE_MINUTE);

The key will be transformed to use the 'ssc-' prefix: 'ssc-somekey'.

By default, the module will use localStorage, but you can change the Storage interface to be sessionStorage by explicitly passing it on the constructor:

const cache = new Cache('somekey', 60000, sessionStorage);

Methods

Simple Storage cache provides two convenient methods: get and update.

get()

The get() method is used to get the data stored in Storage. It will return null if there is not data to retrieve or if the key has expired.

If there is data to retrieve and it hasn't expired, then it will return an object with two properties, the data property, containing the data that was originally stored, and the expiration property, with the expiration time as a number of milliseconds.

const cached = cache.get();
console.log(cached);
// { data: { ... }, expiration: 1595179891655, }

update(data)

The update(data) method allows to set new data or update it:

const response = await fetch(url);
const data = await response.json();

cache.update(data);

Example

import Cache from "simple-storage-cache";
import axios from "axios";

async function getChuckNorrisFact() {
  const ONE_MINUTE = 60000;
  const URL = "https://api.chucknorris.io/jokes/random";
  const cache = new Cache("chuck", ONE_MINUTE);

  const cached = cache.get();

  if (cached) {
    return cached.data;
  }

  const response = await axios.get(url);

  cache.update(response.data);

  return response.data;
}

You can also use it with TypeScript:

import Cache from "simple-storage-cache";
import axios, { AxiosResponse } from "axios";

interface ChuckNorrisFact {
  categories: string[];
  created_at: string;
  icon_url: string;
  id: string;
  updated_at: string;
  url: string;
  value: string;
}

async function getChuckNorrisFact() {
  const ONE_MINUTE = 60000
  const URL = "https://api.chucknorris.io/jokes/random";
  
  const cache = new Cache<ChuckNorrisFact>("chuck", ONE_MINUTE);
  
  const cached = cache.get();

  if (cached) {
    return cached.data;
  }

  const response = await axios.get<string, AxiosResponse<ChuckNorrisFact>>(url);

  cache.update(response.data);

  return response.data;
}

Acknowledgements

Some of the best ideas for this module came from an outstanding code review by r3dst0rm.

Contributing

Contributions, issues and feature requests are welcome!

Show your support

Give a ⭐️ if you like this project!

License

MIT.