Coder Social home page Coder Social logo

mikeroyal / gateway Goto Github PK

View Code? Open in Web Editor NEW

This project forked from webthingsio/gateway

0.0 2.0 0.0 5.11 MB

Things Gateway

Home Page: http://iot.mozilla.org/gateway

License: Mozilla Public License 2.0

JavaScript 75.02% Dockerfile 0.08% Shell 4.74% Python 11.93% TypeScript 1.23% HTML 2.68% CSS 4.32%

gateway's Introduction

Things Gateway by Mozilla

Build Status codecov dependencies devdependencies license

Web of Things gateway.

If you have a Rasberry Pi, the easiest way to use the gateway is to download and flash a pre-built software image from Mozilla to an SD card. Otherwise you can build it from source yourself (see below).

Prerequisites for Building

Install OS

(If you're just installing on your PC, you can skip this step).

If you're installing on a Raspberry Pi then you may need to set up the OS on the Raspberry Pi first. See here for instructions.

Update Package Cache (Linux only)

Under Ubuntu/Debian Linux:

$ sudo apt-get update

Under Fedora Linux:

$ sudo dnf --refresh upgrade

Install pkg-config

Under Ubuntu/Debian Linux:

$ sudo apt-get install pkg-config

Under Fedora Linux:

$ sudo dnf install pkgconfig

Under macOS:

See here.

Install curl (needed to install nvm)

Under Ubuntu/Debian Linux:

$ sudo apt-get install curl

Under Fedora Linux:

$ sudo dnf install curl

Install nvm (Recommended)

nvm allows you to easily install different versions of node. To install nvm:

$ curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash

Reinitialize your terminal session.

$ . ~/.bashrc

Use nvm to install and use an LTS version of node and then set the default version. The .nvmrc file will be used by nvm to determine which version of node to install.

$ nvm install
$ nvm use
$ nvm alias default $(node -v)

Verify that node and npm have been installed:

$ node --version
v8.12.0
$ npm --version
6.4.1

Note: these versions might differ from the LTS version installed locally.

Install node (if you didn't use nvm)

(If you already installed node via nvm you can skip this step)

Follow the directions from NodeJS to install on your platform.

Set up Bluetooth permissions

The following is required in order to let node and python3 use the Bluetooth adapter.

$ sudo setcap cap_net_raw+eip $(eval readlink -f `which node`)
$ sudo setcap cap_net_raw+eip $(eval readlink -f `which python3`)

Install Bluetooth and BT Low Energy support libraries (Linux only)

The following are required in order to install the Python modules that support Bluetooth

Under Ubuntu/Debian Linux:

$ sudo apt-get install libboost-python-dev libboost-thread-dev libbluetooth-dev libglib2.0-dev

Under Fedora Linux:

$ sudo dnf install boost-python-devel boost-devel bluez-libs-devel glib2-devel

Install libusb and libudev (Linux only)

Under Ubuntu/Debian Linux:

$ sudo apt-get install libusb-1.0-0-dev libudev-dev

Under Fedora Linux:

$ sudo dnf install libudev-devel libusb1-devel

Install autoconf

Under Ubuntu/Debian Linux:

$ sudo apt-get install autoconf

Under Fedora Linux:

$ sudo dnf install autoconf

Under macOS:

$ brew install autoconf

Install libpng (Linux only)

Under x86-64 or x86 Ubuntu/Debian Linux:

$ sudo apt-get install libpng12-0

Under ARM Ubuntu/Debian Linux:

$ sudo apt-get install libpng-dev

Under Fedora Linux:

$ sudo dnf install libpng-devel

Install git

You'll need git to checkout the repositories.

Under Ubuntu/Debian Linux:

$ sudo apt-get install git

Under Fedora Linux:

$ sudo dnf install git

Install gcc (needed to build open-zwave)

Under Ubuntu/Debian Linux:

$ sudo apt-get install build-essential

Under Fedora Linux:

$ sudo dnf group install "C Development Tools and Libraries"

Build and Install openzwave

$ cd
$ git clone https://github.com/OpenZWave/open-zwave.git
$ cd open-zwave
$ CFLAGS=-D_GLIBCXX_USE_CXX11_ABI=0 make && sudo CFLAGS=-D_GLIBCXX_USE_CXX11_ABI=0 make install
$ sudo ldconfig

Note: You may need to manually add /usr/local/lib to your LD_LIBRARY_PATH enviroment variable by adding the following to your ~/.profile file:

export LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH

You can run this on the command line as well so it has immediate effect. After running it, you should run sudo ldconfig again to make sure the configuration change goes through.

Install OpenSSL (Windows only)

The Gateway depends on ursa, which requires OpenSSL.

Install OpenSSL =< 1.0.2 (normal, not light) in the same bitness as your Node.js.

See here.

Install Python 2.7 (Windows only)

PageKite works with Python 2.7.

Install Python 2.7 from here.

Enable "register extensions" on installing package, or associate file extension .py with python.

Install Python 3.X and packages (Optional, Windows only)

This is required in order to use Python 3 add-ons, e.g. tplink-adapter.

  • Install Python 3.X (ideally 3.4+) from here.
    • Enable "Install launcher for all users" and "Add Python 3.X to PATH" on installing.
    • Enable python3 command using the following.
mklink "C:\path\to\python3\python3.exe" "C:\path\to\python3\python.exe"
  • Install nanomsg.
    • Follow the directions from nanomsg to install in the same bitness as your Python 3.X.
    • If you want to build for 64-bit, you need to execute cmake with -DCMAKE_GENERATOR_PLATFORM=x64.
    • Add C:\path\to\nanomsg\bin to PATH.
  • Install nnpy
git clone https://github.com/nanomsg/nnpy.git
cd nnpy

Add a file: site.cfg

[DEFAULT]
include_dirs = C:\path\to\nanomsg\include\nanomsg
library_dirs = C:\path\to\nanomsg\lib
host_library = C:\path\to\nanomsg\bin\nanomsg.dll

Execute the following command as an administrator.

python3 -m pip install .
python3 -m pip install git+https://github.com/mozilla-iot/gateway-addon-python.git

Note: 2018-04-12: pip3 has an issue with some languages.

Download and Build Gateway

  • Clone the GitHub repository (or fork it first):

    $ cd
    $ git clone https://github.com/mozilla-iot/gateway.git
    
  • Change into the gateway directory:

    $ cd gateway
    
  • Install dependencies:

    • NOTE: yarn is preferred but npm install will also work. To temporarily use yarn run npx yarn or for a permanent installation follow the directions for your OS.
    $ yarn
    
  • Add Firewall exceptions (Fedora Linux Only)

    $ sudo firewall-cmd --zone=public --add-port=4443/tcp --permanent
    $ sudo firewall-cmd --zone=public --add-port=8080/tcp --permanent
    $ sudo firewall-cmd --zone=public --add-port=5353/udp --permanent
    
  • Set up domain:

    • If you plan to use Mozilla's provided tunneling service to set up a *.mozilla-iot.org domain:
      • Start the web server:

        $ npm start
        
      • Load http://localhost:8080 in your web browser (or use the server's IP address if loading remotely). Then follow the instructions on the web page to set up domain and register. Once this is done you can load https://localhost:4443 in your web browser (or use the server's IP address if loading remotely).

    • If you plan to use your own SSL certificate:
      • The HTTPS server looks for privatekey.pem and certificate.pem in the ssl sub-directory of the userProfile directory specified in your config. You can use a real certificate or generate a self-signed one by following the steps below.

        $ MOZIOT_HOME="${MOZIOT_HOME:=${HOME}/.mozilla-iot}"
        $ SSL_DIR="${MOZIOT_HOME}/ssl"
        $ [ ! -d "${SSL_DIR}" ] && mkdir -p "${SSL_DIR}"
        $ openssl genrsa -out "${SSL_DIR}/privatekey.pem" 2048
        $ openssl req -new -sha256 -key "${SSL_DIR}/privatekey.pem" -out "${SSL_DIR}/csr.pem"
        $ openssl x509 -req -in "${SSL_DIR}/csr.pem" -signkey "${SSL_DIR}/privatekey.pem" -out "${SSL_DIR}/certificate.pem"
        
      • Start the web server:

        $ npm start
        
      • Load https://localhost:4443 in your web browser (or use the server's IP address if loading remotely). Since you're using a self-signed certificate, you'll need to add a security exception in the browser.

Browser Support

The Gateway only supports the following browsers, due to its use of the Fetch API and WebSocket API:

  • Firefox 52+
  • Chrome 43+
  • Edge 14+
  • Safari 10.1+
  • Opera 29+

Debugging

If you are using VS Code, simply use the "launch" target. It will build the gateway in debugger mode.

If you are not using VS Code, run npm run debug and it will build the gateway and launch it with --inspect.

Install additional dependencies for Test (Debian)

These steps are required on Debian (where python points to python 2.7)

apt install python-pip
apt install python3-pip
pip3 install git+https://github.com/mycroftai/adapt#egg=adapt-parser
apt install firefox
apt install openjdk-8-jre

Running Tests

To run the linter and all tests:

$ npm test

To run a single test:

$ jest src/test/{test-name}.js

(assumes you have the jest command on your PATH, otherwise use ./node_modules/jest/bin/jest.js)

Source Code Structure

  • config/ - Gateway configuration files
  • image/ - Tools for building the Raspberry Pi image
  • src/
    • addons-test/ - Add-ons used strictly for testing
    • controllers/ - App URL routes and their logic
    • models/ - Data model and business logic
    • plugin/ - Utility classes and methods used by add-ons
    • rules-engine/ - The rules engine
    • test/ - Integration tests
    • views/ - HTML views
    • wifi-setup/ - Initial WiFi setup code for Raspberry Pi
    • addon-loader.js - Script used for starting up Node-based add-ons
    • addon-manager.js - Manages add-ons (e.g. ZigBee, Z-Wave)
    • app.js - The main back end
    • app-instance.js - Application wrapper for integration tests
    • command-utils.js - Utilities used by commands parser
    • constants.js - System-wide constants
    • db.js - Manages the SQLite3 database
    • deferred.js - Wraps up a promise in a slightly more convenient manner for passing around, or saving
    • ec-crypto.js - Elliptic curve helpers for the ES256 curve
    • jwt-middleware.js - Express middleware for determining authentication status
    • log-timestamps.js - Utilities for adding timestamps to console logging functions
    • mdns-server.js - mDNS server
    • oauth-types.js - OAuth types
    • passwords.js - Password utilities
    • platform.js - Platform-specific utilities
    • push-service.js - Push notification service
    • router.js - Routes app URLs to controllers
    • ssltunnel.js - Utilities to determine state of tunnel and manage the PageKite process
    • user-profile.js - Manages persistent user data
    • utils.js - Various utility functions
  • static/ - Static CSS, JavaScript & image resources for web app front end
  • tools/ - Helpful utilities (not part of the build)
  • package.json - npm module manifest

gateway's People

Contributors

hobinjk avatar mrstegeman avatar dhylands avatar sogaani avatar benfrancis avatar lightsofapollo avatar andrenatal avatar rzr avatar tamarahills avatar pchri avatar swaagie avatar cmatheson avatar artynet avatar bschwehn avatar kevingrandon avatar freaktechnik avatar masterkale avatar nherriot avatar roderm avatar ric96 avatar senden9 avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.