Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/roccomuso/nupnp
Node.js discovery broker for IoT devices
https://github.com/roccomuso/nupnp
broker devices discovery iot js nodejs nupnp
Last synced: 8 days ago
JSON representation
Node.js discovery broker for IoT devices
- Host: GitHub
- URL: https://github.com/roccomuso/nupnp
- Owner: roccomuso
- License: mit
- Created: 2018-04-18T10:52:41.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-05-22T14:03:50.000Z (over 6 years ago)
- Last Synced: 2024-11-22T08:48:09.677Z (about 2 months ago)
- Topics: broker, devices, discovery, iot, js, nodejs, nupnp
- Language: JavaScript
- Homepage:
- Size: 28.3 KB
- Stars: 3
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 🤖 nupnp [![NPM Version](https://img.shields.io/npm/v/nupnp.svg)](https://www.npmjs.com/package/nupnp) ![node](https://img.shields.io/node/v/nupnp.svg) [![Dependency Status](https://david-dm.org/roccomuso/nupnp.png)](https://david-dm.org/roccomuso/nupnp) [![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)
Node.js Discovery broker for IoT devices. 🤖
![screen](screen.png)
## Install
`npm install nupnp` or `npm install -g nupnp`
## Programmatic usage
#### Server
```javascript
const {Server} = require('nupnp')let server = new Server({
port: 8180,
verbose: true,
enableProxy: true,
connectionString: 'sqlite://database.sqlite' // @keyv compatible storage conn. string
}).listen()
.then(() => console.log(`Server listening on port 8180 - Trust proxy: true`)).catch(console.error)```
From CLI:
`PORT=8180 VERBOSE=true ENABLE_PROXY=true nupnp &`
If globally installed, it will use by default in-memory storage.
Otherwise pick and install the [keyv adapter](https://github.com/lukechilds/keyv#usage) you like the most (We're using [keyv](https://github.com/lukechilds/keyv) as storage layer).#### Client
```javascript
const {Client} = require('nupnp')
const os = require('os')let client = new Client({
host: 'http://localhost:8180'
})let iface = os.networkInterfaces().wlp2s0 || os.networkInterfaces().eth0
// register a device
client.register({
name: 'MyDevice',
address: iface[0].address, // lan ip
port: 1234, // optional
ttl: null // optional
}).then(console.log).catch(console.error)// get devices
client.getDevices().then(console.log).catch(console.error)
```## Server API
Register device with:
```
curl -H "Content-Type: application/json" -X POST -d '{"name":"Testdevice","address":"192.168.100.151"}' http://localhost:8180/api/register
```Optional parameters:
* port
* ttl (in milliseconds)List device with:
```
http://localhost:8180/api/devices
```## Inspiration
> After about 1 minute open a web browser and point to find.z-wave.me. Below the login screen you will see the IP address of your RaZberry system. Click on the IP address link to open the configuration dialog.* http://www.meethue.com/api/nupnp
* http://find.z-wave.me
* http://setup.thinka.eu
* https://github.com/yene/nupnp## Options
- [x] Trust reverse Proxy
- [x] Support to IPv4 & IPv6## Security
Never allow another IP address to access the data. Remove the entries after 24h. If you use a proxy prevent external access to the API server.## Caddy Proxy configuration
```
proxy /api/register localhost:8180 {
proxy_header X-Forwarded-Proto {scheme}
proxy_header X-Forwarded-For {host}
proxy_header X-Real-IP {remote}
proxy_header Host {host}
}
```## License
MIT
## Author
Rocco Musolino ([@roccomuso](https://twitter.com/roccomuso))