All Projects → netbeast → Dashboard

netbeast / Dashboard

Licence: gpl-3.0
🌟 Create IoT applications. Wire devices together regardless their brand or technology.

Programming Languages

javascript
184084 projects - #8 most used programming language

Projects that are alternatives of or similar to Dashboard

Smarthome Tutorial
🎓 Tutorial: smart-home dashboard UI concept.
Stars: ✭ 190 (-32.86%)
Mutual labels:  smart-home, iot, dashboard
Rpieasy
Easy MultiSensor device based on Raspberry PI
Stars: ✭ 85 (-69.96%)
Mutual labels:  smart-home, mqtt, iot
Platypush
A versatile and extensible platform for home and life automation with hundreds of supported integrations
Stars: ✭ 192 (-32.16%)
Mutual labels:  mqtt, iot, dashboard
Openremote
100% open-source IoT Platform - Integrate your assets, create rules, and visualize your data
Stars: ✭ 254 (-10.25%)
Mutual labels:  mqtt, iot, dashboard
Tasmota
Alternative firmware for ESP8266 with easy configuration using webUI, OTA updates, automation using timers or rules, expandability and entirely local control over MQTT, HTTP, Serial or KNX. Full documentation at
Stars: ✭ 16,624 (+5774.2%)
Mutual labels:  smart-home, mqtt, iot
Thingsboard
Open-source IoT Platform - Device management, data collection, processing and visualization.
Stars: ✭ 10,526 (+3619.43%)
Mutual labels:  mqtt, iot, dashboard
Fuxa
Web-based Process Visualization (SCADA/HMI/Dashboard) software
Stars: ✭ 262 (-7.42%)
Mutual labels:  mqtt, iot, dashboard
Deskmate
A tiny MQTT-powered dashboard and control center.
Stars: ✭ 39 (-86.22%)
Mutual labels:  smart-home, mqtt
Zigbeenet
A .NET Standard library for working with ZigBee
Stars: ✭ 76 (-73.14%)
Mutual labels:  smart-home, iot
Irext
Universal IR Remote Control Solution
Stars: ✭ 1,240 (+338.16%)
Mutual labels:  smart-home, iot
Tuya Convert
A collection of scripts to flash Tuya IoT devices to alternative firmwares
Stars: ✭ 3,338 (+1079.51%)
Mutual labels:  mqtt, iot
Rumqtt
Mqtt ecosystem in rust
Stars: ✭ 264 (-6.71%)
Mutual labels:  mqtt, iot
Cbj smart Home
If you are searching for an easy way to deploy a smart home 🏡 by yourself CyBear Jinni 🦾🐻🧞‍♂️ is here for you. Join the community and make your home smarter than yesterday.
Stars: ✭ 37 (-86.93%)
Mutual labels:  smart-home, iot
Coapnet
CoAPnet is a high performance .NET library for CoAP based communication. It provides a CoAP client and a CoAP server. It also has DTLS support out of the box.
Stars: ✭ 23 (-91.87%)
Mutual labels:  smart-home, iot
Ztc1
斐讯TC1智能排插个人固件. 仅支持TC1硬件版本为a1的版本
Stars: ✭ 598 (+111.31%)
Mutual labels:  smart-home, mqtt
Xiaomi Flower Care Api
Xiaomi Flower Care (MiFlora) API wrapper.
Stars: ✭ 111 (-60.78%)
Mutual labels:  smart-home, iot
Entity Controller
Entity and lighting controller for managing devices via timers, scripts, and sun-based time restrictions.
Stars: ✭ 156 (-44.88%)
Mutual labels:  smart-home, iot
Ha4iot
Open Source Home Automation system for .NET
Stars: ✭ 146 (-48.41%)
Mutual labels:  smart-home, iot
Home Assistant Cli
💻 Command-line tool for Home Assistant
Stars: ✭ 243 (-14.13%)
Mutual labels:  smart-home, iot
Home Assistantconfig
🏠 Home Assistant configuration & Documentation for my Smart House. Write-ups, videos, part lists, and links throughout. Be sure to ⭐ it. Updated FREQUENTLY!
Stars: ✭ 3,687 (+1202.83%)
Mutual labels:  smart-home, iot

Netbeast Dashboard

Build Status Windows Build Status

Important notice

Netbeast Dashboard project is moving on.

Developing is hard. Being disruptive is harder. Industry won't stop trying to impose new protocols and standards. Indies won't stop creating open source projects that everyone should adopt --this repo was our own bet-- but it is really hard to take off and critical adoption rate is really difficult to achieve. So we changed our focus.

Firstly we developed Yeti Smart Home. It is a mobile app with effortless installation and a thoroughtly worked UI that is the perfect platform to build the next generation tools for IoT development that is actually usable by non-technical people. We also did it in an open way, sharing our know-how with the community and releasing a number of packages. You can read it more here: Developing Beyond the Screen.

Now we are going to take a second step. We just started The Bigfoot Project. We took everything we learnt from building the first Netbeast Dashboard, and the UX / UI experience of Yeti, developing a third beast. Instead of developing a new platform or protocol we are releasing a series of documentation, guides and wrapper of already standard tools to make them work with each other. So the Bigfoot project is a collection of already existing tools that work together out of the box and will help you develop your next connected thing as soon as possible. Please join us here.

We want to make compatible all the pieces of our ecosystem to serve best users and developers equally, as our mission is to make things work for people, instead making people work for things.

Netbeast team

Connect everything. Regardless its brand or technology.

One API, unlimited products and hacks. Netbeast middleware translates messages from different IoT protocols and device interfaces so they work as one. Have no more "hubs". Work across devices not brands.

var netbeast = require('netbeast')
netbeast.find().then(function () {
  netbeast('lights').set({ power: 1 }) // will turn on all lights in your home
})

Contents

Installation

Basic

Make sure you have installed git and nodejs.

npm install -g netbeast-cli
netbeast start

Find it live at http://localhost:8000 or run it as netbeast start --port <PORT>

Pro tip. To get started developing you will find handy to have it installed in a folder of your choice.

git clone https://github.com/netbeast/dashboard
cd dashboard
npm install --production
npm start

Dashboard live GIF

## Raspberry / Beagle Bone / Pine64 or your choice of board Make sure again you have installed git and nodejs. It can be tricky depending on your OS & architecture. If any doubts please reach forum or open an issue.

  1. Apply the basic installation from above, preferably using git.
git clone https://github.com/netbeast/dashboard . # clone in this folder
npm i --production # no front-end or test dependencies
  1. Keep it running 24h 7 days a week, to use it as Smart Home Hub. You can use utilities such as forever or pm2.
npm i -g pm2
sudo pm2 start index.js --port 80
  1. [Soon] Learn how to attach a DHCP name to your Netbeast as https://home.netbeast and how to deal with wireless configuration in Linux from our blog.

Using docker 🐳

Make sure you already have docker installed.

  1. Run our docker image, if it's the first time, it'll be downloaded from the Docker Hub
docker run -p 49160:8000 -d netbeast/netbeast

This will run Netbeast dashboard on port 49160 of the host running the container. You can now play with it.

Access the dashboard on http://localhost:49160

Et voilà!

Overview

Find inspiration, think about new projects, connect your new hardware.

Netbeast apps are HTML5 user interfaces that enable controlling IoT or visualizing their data. Netbeast plugins are apps that translate from the Netbeast IoT Unified Scheme, to each particular implementation of an IoT device.

Explore existing apps and plugins of our public registry.

Control devices regardless of their brand and technology

Take a look on our unified API on action in this demo on youtube, under a Netbeast app that creates new scenes.

IMAGE ALT TEXT HERE

https://www.youtube.com/watch?v=YNERwJdykuQ

Measure all your data

Use the Netbeast API along with the dashboard to publish data through MQTT or reuse it in your apps. Read more.

Dashboard live GIF

## Write IoT apps without spending on hardware or suffering expensive deployments Take advance of Netbeast IoT middleware to test your apps with software that mocks the hardware interface.

Virtual plugins

Find tutorials in the docs, read a blog post about it on TopTal or join the forum to ask how to do it.

Documentation

We publish a gitbook with fresh documentation on https://docs.netbeast.co. If you want to open an issue, contribute or edit it, find your way on its github repo https://github.com/netbeast/docs.

Create IoT with Node.js

In Netbeast we care about education, openness and interoperability. We have created a series of workshops to teach developers to better use HTTP, MQTT in combination with the Dashboard to create data bindings and incredible apps. Use your favorite boards and platforms as Arduino, Pi Zero, Pine64, Belkin Wemo, Homekit and a infinite list, connected.

Apps

A Netbeast app allows you to run the Dashboard unique API in the browser or backend equally. Just expose some user interface in your apps root. In the following snippet we serve in the root all files inside public folder.

var express = require('express')
var app = express()

// Netbeast apps need to accept the port to be launched by parameters
var argv = require('minimist')(process.argv.slice(2))

app.use(express.static('public'))

var server = app.listen(argv.port || 31416, function () {
  var host = server.address().address
  var port = server.address().port
  console.log('Example app listening at http://%s:%s', host, port)
})

Learn how to create new scenes and user interfaces as bots, speech recognition, smart triggers. Learn how to develop Netbeast apps, debug and publish them on the documentation

Connect Devices

A plugin is an app that enables your Dashboard to communicate with a different protocol or proprietary device. It's like if you, that want to learn Chinese, could speak Chinese by installing an app. Luis, cofounder of Netbeast

A basic plugin must implement at least a discovery primitive to declare itself on Netbeast's database. Fill the gaps to create your first hardware integration into Netbeast:

var netbeast = require('netbeast')
var express = require('express')
var cmd = require('commander') // reads --port from command line

// Netbeast tells you in which port to run your Plugin endpoint
cmd.option('-p, --port <n>', 'Port to start the HTTP server', parseInt)
.parse(process.argv)

var app = express()

/*
* Discover your resources / scan the network
* And declare your routes into the API
*/

app.get('/discover', function () {
	/* TODO, implement discovery */

	/* for each device */
	netbeast('topic').create({ app: 'my-first-plugin', hook: 'DEVICE_ID' })
	/* end of for */

	/* or */
	/* Register all device together and delete the resources no longer available */
	netbeast('topic').udateDB({ app: 'my-first-plugin', hook: ['DEVICE1_ID', 'DEVICE2_ID', 'DEVICE3_ID', 'DEVICE4_ID'] })
})

/*
* Create here your API routes
* app.get(...), app.post(...), app.put(...), app.delete(...)
*/

app.get('/:device_id', function (req, res) {
	// id of the device the dashboard wants
	// << req.params.device_id >>
	// dashboard will do GET on this route when
	// netbeast('topic').get({})

	/* TODO: Return device values from req.query */

	// res.json({ YOUR_PLUGIN_DATA })
})

app.post('/:device_id', function (req, res) {
	// id of the device the dashboard wants
	// << req.params.device_id >>
	// dashboard will do POST on this route when
	// netbeast('topic').set({})

	/* TODO: Change device values from req.body */

	// res.json({ YOUR_PLUGIN_DATA })
})


var server = app.listen(cmd.port || 4000, function () {
  console.log('Netbeast plugin started on %s:%s',
  server.address().address,
  server.address().port)
})

Learn how to launch it, debug it and publish it on the documentation.

Community

Join us in our forum
Ask for an invitation to join our Slack team here
Project website

Contribute

Take a look to our CONTRIBUTING.md file in order to see how can you be part of this project. Or take a look on Netbeast's discourse forum to find for inspiration, projects and help.

TL;DR Make a Pull Request. If your PR is eventually merged don't forget to write down your name on the AUTHORS.txt file.


   
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].