Project

ban

0.0
No commit activity in last 3 years
No release in over 3 years
A home control system based on firmata
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.3
>= 0
>= 0

Runtime

 Project Readme

Ban

Ban is a arduino firmware (based on firmata) that receives incoming remote control switch commands, infrared commands, door open/close signaling and can send out remote control commands also. Ban distributes all this information over a websocket. The Websocket protocol is described below:

The Arduino Layout

Laoyut

Websocket Protocol

Basically the protocol has no authentication and is based on JSON.

Send messages

The following commands and there json representation are send by the ban server to all clients:

rc-turned-on

{ 'rc-turned-on': { 'decimal': 21780,
                    'bits': 24,
                    'binary': '000000000101010100010100',
                    'tristate': '0000FFFF0FF0',
                    'delay': 322,
                    'protocol': 1 } }

rc-turned-off

{ 'rc-turned-off': { 'decimal': 21780,
                     'bits': 24,
                     'binary': '000000000101010100010001',
                     'tristate': '0000FFFF0F0F',
                     'delay': 322,
                     'protocol': 1 } }

ir-received

{ 'ir-received': { 'code': 4294967295, 'hex': 'ffffffff' } }

door-opened

{ 'door-opened': { 'state': 'open' } }

door-closed

{ 'door-closed': { 'state': 'closed' } }

Received messages

The following commands can be send to the ban server:

rc-turn-off

{ 'rc-turn-off': { 'address': '11110D' } }

rc-turn-on

{ 'rc-turn-on': { 'address': '11110D' } }

Installation

Add this line to your application's Gemfile:

gem 'ban'

And then execute:

$ bundle

Or install it yourself as:

$ gem install ban

Flash the arduino

  1. Install the inotool

  2. Install the arduino library rc-switch

  3. Install the arduino library IRremote

  4. Fetch the git repository

  5. Configure the arduino board in the ino.ini file.

  6. And build and upload the Firmware to your arduino. using

     $ ino clean && ino build && ino upload
    

Usage

Start the ban server using:

	$ ban server

Then by default a websocket server is started on the port 8080 on all interfaces. The websocket server will then send and receive the json messages.

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request