localstorage-scuttlebutt

replicate localStorage with scuttlebutt

Usage no npm install needed!

<script type="module">
  import localstorageScuttlebutt from 'https://cdn.skypack.dev/localstorage-scuttlebutt';
</script>

README

localstorage-scuttlebutt

replicate localstorage through scuttlebutt.

The same api as scuttlebutt/model but data is saved in the browser using local storage.

Example

var LSSB = require('localstorage-scuttlebutt')
var ls = new LSSB({prefix: prefix, id: id, store: localStorage})

ls.set(key, value)
ls.get(key)
ls.on('change', function (key, value) {

})

prefix is the name of this instance. If you are using multiple instances, or have other data in localStorage you need to set this. By default, prefix='_lss'.

id is optional, but if provided, it should represent the user session. (by default, it's remembered in localStorage, so the same value will be used next time)

store defaults to localStorage, but sessionStorage may also be used. (store must have length property and a key() method.

Replication

replicate with a normal scuttlebutt/model, across anything that provides a Stream api.

//client
var reconnect = require('reconnect')
var LSSB = require('localstorage-scuttlebutt')
var ls = new LSSB(ID, prefix)

reconnect(function (stream) {
  stream.pipe(ls.createStream()).pipe(stream)
}).connect('/shoe')
//server.js
var shoe = require('shoe')
var Model = require('scuttlebutt/model')
var model = new Model(SERVER_ID)

shoe(function (stream) {
  stream.pipe(model.createStream()).pipe(stream)
}).install(http.createServer(function (req, res) {
  fs.createReadStream(__dirname + '/index.html').pipe(res)
  req.resume()
}).listen(3000))

License

MIT