Skip to content

MiBand 2 JS library for Node.JS and HTML5 (WebBluetooth)

License

Notifications You must be signed in to change notification settings

emilpaw/miband-js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Mi Band 2 JS library

A clean implementaation of Mi Band 2 library for Browsers and Node.js, using WebBluetooth API.

Features

  • Authentication
  • Device info: time, battery status, hw/sw versions, etc.
  • Button tap event
  • Notifications: message, phone, vibrate
  • Heart Rate Monitor
  • Realtime data (soon)

demo

Setting up

It's best to unbind your Mi Band 2 from MiFit App first.
You should be able to bind it back again, but no guaranee here ;)

Browser

Head to https://tiny.cc/miband-js

You need a browser with WebBluetooth support. Tested with:

  • Chrome on OS X (Yosemite or later)
  • Chrome on Android (6.0 Marshmallow or later)
  • Chrome on Windows 10 and Linux (the chrome://flags/#enable-experimental-web-platform-features flag must be enabled)

Node.js

npm install -g https://github.com/vshymanskyy/miband-js.git
miband-test

This should work on Windows, Linux and OSX.
On Linux, you need to grant Bluetooth access for Node.js:

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

API usage example

const MiBand = require('miband');

const device = await bluetooth.requestDevice({
  filters: [
    { services: [ MiBand.advertisementService ] }
  ],
  optionalServices: MiBand.optionalServices
});

const server = await device.gatt.connect();

let miband = new MiBand(server);
await miband.init();

log('Notifications demo...')
await miband.showNotification('message');

For more API examples, see https://github.com/vshymanskyy/miband-js/blob/master/src/test.js


Contributing

Please check out DEVELOPMENT.md

About

MiBand 2 JS library for Node.JS and HTML5 (WebBluetooth)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 85.8%
  • CSS 7.9%
  • HTML 6.3%