Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/diegorbaquero/node-v

πŸ”’ Secure ❄️ Synchronized ⚑️ Realtime ☁️ Cloud 🌈 Native JavaScript Variables & Events
https://github.com/diegorbaquero/node-v

cloud constants es6 javascript proxy realtime sync synchronization variables

Last synced: 2 months ago
JSON representation

πŸ”’ Secure ❄️ Synchronized ⚑️ Realtime ☁️ Cloud 🌈 Native JavaScript Variables & Events

Awesome Lists containing this project

README

        


V Logo



πŸ”’ Secure ❄️ Synchronized ⚑️ Realtime ☁️ Cloud 🌈 Native JavaScript Variables & Events

npm downloads Greenkeeper badge
Build Status codecov
NSP Status Known Vulnerabilities

V extends your in-memory variables to also be saved/persisted instantly. Variables are instantly synchronized between all running instances of V in a room. When you (re)start in a room, variables and constants are reloaded/rehydrated automatically.

### Current Features
- Keep your variables in the cloud
- Sync variables between instances
- Automatic reloaded/rehydrated on start-up

#### Requires ES6 Proxy (Node 6+ and new browsers)

### Coming Soon:
- Web GUI
- History - Time machine
- Events pub/sub

## Install

### Node
```sh
npm install --save v
or
npm i -S v
```

### Browser
jsDelivr CDN:
```html

```

Unpkg CDN:
```html

```

More CDNs coming soon

## API

### Constructor (3 Ways to do it)

If no roomId is passed, a new one will be assigned automatically and printed in the console.

##### NodeJS **only** with deasync support
```js
const V = require('v')
const v = new V([roomId])
```

##### Callback
```js
const V = require('v')
V([roomId,] v => {
...
})
```

##### Promise
```js
const V = require('v')
V([roomId]).then(v => {
...
}).catch(e => {
...
})
```

#### Custom Opts

The `opts` object has the following options and their default options listed
```js
myOpts = {
roomId: '',
server: 'ws(s)://my-domain.com'
}
```

Use it:
```js
const v = new V(myOpts)
```

## Debug logs

**V** comes with extensive debugging logs. Each **V** instance and constructor-call has it own debug namespace.

In **node**, enable debug logs by setting the `DEBUG` environment variable to `*`

```bash
DEBUG=* node myProgram.js
```

In the **browser**, enable debug logs by running this in the developer console:

```js
localStorage.debug = '*'
```

Disable by running this:

```js
localStorage.removeItem('debug')
```

## License
MIT Copyright Β© [Diego RodrΓ­guez Baquero](https://diegorbaquero.com)