GitXplorerGitXplorer
A

tiny-level-ttl

public
6 stars
0 forks
0 issues

Commits

List of commits on branch master.
Unverified
7c25fc3cc8356c22634dccf2af58f4fdb1d3ff91

Remove dependency badges

AArtskydJ committed 9 years ago
Unverified
579f3013802b3390426fb7616e81838c1cff34fd

3.1.5

AArtskydJ committed 9 years ago
Unverified
742d3fbbeaf5af8cf02696efcccba634365a18f0

Add changes to CHANGELOG.md

AArtskydJ committed 9 years ago
Unverified
eab6bfec3277a186557d2b60bf24d0318d0a830d

Adjust timeout

AArtskydJ committed 9 years ago
Unverified
be2a25c72fdb1ee81eaede387c191a500947ec0f

Fix failing test

AArtskydJ committed 9 years ago
Unverified
bab956769b79cd2cdd7cb3806b330685b45759b4

3.1.4

AArtskydJ committed 9 years ago

README

The README file for this repository.

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