Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/zhifengle/kv-expiration

A key-value storage with expiration time
https://github.com/zhifengle/kv-expiration

Last synced: about 2 months ago
JSON representation

A key-value storage with expiration time

Awesome Lists containing this project

README

        

# kv-expiration

A library for caching data with expiration time. You can use a custom key-value storage engine.

If you just want to use `localStorage`, you can use [lscache](https://github.com/pamelafox/lscache).

## Usage

```shell
npm i kv-expiration
```

```javascript
import { KvExpiration, JsonEngine, GmEngine } from 'kv-expiration';

const engine = new JsonEngine('my-storage.json');
const kvJson = new KvExpiration(engine, 'MY_PREFIX_', 'SOME_SUFFIX', 'BUCKET');
kvJson.set('expired in two day', 'some text', 2);
kvJson.set('never expired', 1);
// GmEngine only can be used in userscript manager. Tampermonkey, Violentmonkey
// suffix, bucket is optional
const kv = new KvExpiration(new GmEngine(), 'MY_PREFIX_');
// foo would expire in 1 day 10 hours and 1 minute.
kv.set(
'foo',
{ a: 1 },
{
dd: 1,
hh: 10,
mm: 1,
}
);
```

```javascript
import { KvExpirationAsync, JsonEngineAsync } from 'kv-expiration';
// if you storage engine's API is async.
// for example: engine.set('foo', 'bar') return a Promise

async function test() {
const engine = new JsonEngineAsync('my-storage-async.json');
const kv = new KvExpirationAsync(
engine,
'MY_PREFIX_',
'SOME_SUFFIX',
'BUCKET'
);
await kv.set('foo', 'bar', 1);
const v = await kv.get('foo');
console.log(v); // bar
}
```

Built-in key-value storage engine: `JsonEngine`, `GmEngine`, `LsEngine`

### JsonEngine

Use local json file for storage.

### LsEngine

Use localStorage

### GmEngine

Use userscript manager's API: GM_setValue, GM_getValue, GM_listValues and GM_deleteValue

### Custom Engine

```typescript
import { KvExpiration } from 'kv-expiration';
import type { KvEngine } from 'kv-expiration';

class LsEngine implements KvEngine {
set(key: string, value: any): boolean {
try {
value = JSON.stringify(value);
} catch (e) {
return false;
}
localStorage.setItem(key, value);
return true;
}
get(key: string) {
let value = localStorage.getItem(key);
try {
return JSON.parse(value);
} catch (e) {
return value;
}
}
remove(key: string): void {
localStorage.removeItem(key);
}
keys(): string[] {
var arr: string[] = [];
return arr;
}
}
const engine = new LsEngine();
const kvExpiration = new KvExpiration(
engine,
'MY_PREFIX_',
'SOME_SUFFIX',
'BUCKET'
);
// out of date in one day
kvExpiration.set('foo', 'bar', 1);
```

## API

```typescript
declare type TimeOpt =
| number
| {
hh?: number;
dd?: number;
mm?: number;
ss?: number;
ms?: number;
};
declare class KvExpiration {
private engine;
private prefix;
private suffix;
private bucket;
// suffix, bucket is optional
constructor(
engine: KvEngine,
prefix: string,
suffix?: string,
bucket?: string
);
// clear all data set by KvExpiration
flush(): void;
// clear expired data set by KvExpiration
flushExpired(): void;
// set key-value.
// if opt is number, the value will expire after `opt` days.
set(key: string, value: any, opt?: TimeOpt): boolean;
// get value by key
get(key: string): any;
// remove value by key
remove(key: string): void;
}

// If you want to custom engine, your engine must have to implement method.
interface KvEngine {
set(key: string, value: any): boolean;
get(key: string): any;
remove(key: string): void;
keys(): string[];
}
```