0.7.0 • Published 8 years ago

ble-mesh-serial-interface-js v0.7.0

Weekly downloads
6
License
BSD-3-Clause
Repository
github
Last release
8 years ago

ble-mesh-serial-interface-js

An npm package for Node.js that provides an API to control a router node in a BLE mesh network via the serial port.

Installation

npm install ble-mesh-serial-interface-js

Usage

'use strict';

const BLEMeshSerialInterface = require('./BLEMeshSerialInterface');

const MESH_ACCESS_ADDR = 0x8E89BED6;
const MESH_INTERVAL_MIN_MS = 100;
const MESH_CHANNEL = 38;

const bleMeshSerialInterfaceAPI = new BLEMeshSerialInterface();

bleMeshSerialInterfaceAPI.openSerialPort('COM45', err => {
  bleMeshSerialInterfaceAPI.init(MESH_ACCESS_ADDR, MESH_INTERVAL_MIN_MS, MESH_CHANNEL, err => {
    if (err) {
      console.log(err);
    }
    console.log('device initialized');
    bleMeshSerialInterfaceAPI.valueSet(0, new Buffer([0x00, 0x01, 0x02]), err => {
      if (err) {
        console.log(err);
      }
      console.log('valueSet() handle = 0, value = [0, 1, 2]');
      bleMeshSerialInterfaceAPI.valueGet(0, (err, res) => {
        if (err) {
          console.log(err);
        }
        console.log('valueGet() res: ', res);
        bleMeshSerialInterfaceAPI.radioReset(err => {
          if (err) {
            console.log(err);
          }
          console.log('device reset');
        });
      });
    });
  });
});
'use strict';

const BLEMeshSerialInterface = require('./BLEMeshSerialInterface');

const FIRST_COM_PORT = 'COM45';
const OPTIONAL_SECOND_COM_PORT = 'COM46';

const bleMeshSerialInterfaceAPI = new BLEMeshSerialInterface();

bleMeshSerialInterfaceAPI.openSerialPort('COM45', err => {
  if (err) {
    console.log(err);
  }
  const buf = new Buffer([0x01]);

  ble.echo(buf, (err, res) => {
    if (err) {
      console.log(err);
    }
    ble.openSerialPort(OPTIONAL_SECOND_COM_PORT, err => {
      if (err) {
        console.log(err);
      }
      ble.echo(buf, (err, res) => {
        if (err) {
          console.log(err);
        }
      });
    });
  });
});

API

TODO: Improve this.

BLEMeshSerialInterface is defined in 'index.js' and it has public methods for interfacing with the ble mesh device and opening/closing/writing the serial port. It also emits events on specific serial port events and ble mesh events. For now, see / API Methods / and / nRF Open Mesh Serial Interface / in 'index.js.' For info about the events BLEMeshSerialInterface emits, search 'index.js' for 'this.emit'

  • Only one serial port can be opened per instance of BLEMeshSerialInterface. If you have COM1 opened, and then call openSerialPort(COM2), COM1 will be automatically closed.
  • The constructor returns immediately, then to use any commands that send over serial you must explicitly call openSerialPort.

Tests

npm test

Contributing

In lieu of a formal style guide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code.

0.7.0

8 years ago

0.6.0

8 years ago

0.5.2

8 years ago

0.5.1

8 years ago

0.5.0

8 years ago

0.4.5

8 years ago

0.4.4

8 years ago

0.4.3

8 years ago

0.4.2

8 years ago

0.4.1

8 years ago

0.4.0

8 years ago

0.3.3

8 years ago

0.3.2

8 years ago

0.3.1

8 years ago

0.3.0

8 years ago

0.2.6

8 years ago

0.2.5

8 years ago

0.2.4-patch

8 years ago

0.2.4

8 years ago

0.2.3

8 years ago

0.1.3

8 years ago

0.0.3

8 years ago

0.0.2

8 years ago

0.0.1

8 years ago