GithubHelp home page GithubHelp logo

artskydj / tiny-level-ttl Goto Github PK

View Code? Open in Web Editor NEW
6.0 5.0 0.0 42 KB

:hourglass: Enforces a time to live (TTL) on a levelup database

JavaScript 100.00%
level ttl levelup sublevel time-to-live lock js javascript node levelup-database

tiny-level-ttl's Introduction

tiny-level-ttl

A tiny javascript module that enforces a time to live (TTL) on a node-levelup database.

Build Status

Why use this instead of node-level-ttl? Because level-sublevel and node-level-ttl conflict.

Bug reproduction test code here.
The bug was found using level-sublevel@6 with level-ttl@2, and level-sublevel@5 with level-ttl 0.6.

api

var ttl = require('tiny-level-ttl')

ttl(db[, opts])

Adds a refreshTtl method to the db. When db.refreshTtl(key) is called, it will refresh the ttl on the key. This adds the ability to make the ttl act like a session manager by calling refreshTtl() every time you do db.get().

Also, this respects the locks that level-lock creates. If tiny-level-ttl attempts to delete a key, and the key's write access is locked, it will restart the key's life. (In most cases, this is the desired outcome. If the key is being written to, you would've restarted the key's life anyway. If the key is being deleted, restarting its life will not mess anything up.)

  • db is a levelup database.
  • opts is an object with the following properties:
    • ttl is a number of milliseconds for how long a key lives in the db. Optional; defaults to 3600000, (1 hour).
    • checkInterval is a number of milliseconds for how long the interval between checking keys is. Optional; defaults to 10000, (10 seconds).
    • separator can be a string, buffer, or array of strings/buffers. These represent the separator used in the sub-database. For example, level-spaces by default has the separator ~, so if you store the key bar, in the space foo, the key will be ~foo~bar. Defaults to [ '~', '\xff', '\x00' ].

example

Basic usage:

var level = require('level-mem')
var ttl = require('tiny-level-ttl')

var db = level('/levelmem/does/not/care')
ttl(db, {
	ttl: 1000,
	checkInterval: 50
})

db.put('hi', 'wuzzup') //this sets the ttl

setTimeout(function () { //before key expires
	db.get('hi', function (err, value) {
		console.log(err && err.notFound) // -> null
		console.log(value) // -> 'wazzup'
	})
}, 900)

setTimeout(function () { //after key expires
	db.get('hi', function (err, value) {
		console.log(err && err.notFound) // -> true
		console.log(value) // -> undefined
	})
}, 1100)

install

With npm do:

npm install tiny-level-ttl

license

VOL

tiny-level-ttl's People

Contributors

artskydj avatar tehshrike avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

tiny-level-ttl's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.