Project

xap_ruby

0.0
No commit activity in last 3 years
No release in over 3 years
This gem provides basic xAP Automation protocol support for EventMachine applications. It was developed for use in Nitrogen Logic controller software. There are no automated tests and the code could be improved in many ways, but it may still be useful to someone. This is a Ruby library written from scratch for communicating with a home automation network using the xAP protocol. Supports sending and receiving arbitrary xAP messages, triggering callbacks on certain received messages, etc. Also includes an implementation of an xAP Basic Status and Control device. Incoming xAP messages are parsed using an ad-hoc parser based on Ruby's String#split() and Array#map() (a validating Treetop parser is also available). Network events are handled using EventMachine.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 2.0
>= 0
~> 13.0.3

Runtime

>= 0.12.10
>= 1.4.10
 Project Readme

xap_ruby

This gem provides basic xAP Automation protocol support for EventMachine applications. It was developed for use in Nitrogen Logic controller software. There are no automated tests and the code could be improved in many ways, but it may still be useful to someone.

This is a Ruby library written from scratch for communicating with a home automation network using the xAP protocol. Supports sending and receiving arbitrary xAP messages, triggering callbacks on certain received messages, etc. Also includes an implementation of an xAP Basic Status and Control device. Incoming xAP messages are parsed using an ad-hoc parser based on Ruby's String#split() and Array#map() (a validating Treetop parser is also available). Network events are handled using EventMachine.

This library strives to support all address wildcard modes and data types specified by the xAP specification as correctly as possible.

Read the examples under test/ to understand how to create your own applications using xap_ruby. All user-facing classes should have documenting comments.

xAP

xAP is a broadcast UDP protocol for interfacing disparate home automation systems and devices. Despite its weaknesses, xAP support is available for many DIY and enthusiast automation systems. For more information on xAP, visit http://www.xapautomation.org/.

Installation

Add this line to your application's Gemfile:

gem 'xap_ruby'

Testing and Examples

There are no automated tests. You can test the code by running test/bscdev_test.rb to simulate an xAP BSC device, then running test/xap_receive.sh and test/xap_query.sh on another machine.

  • test/bsdev_test.rb creates a dummy xAP Basic Status and Control device.
  • test/parser_test.rb tests the Treetop parser with a variety of xAP data types.
  • test/xap_query.sh uses netcat to send a network-wide xAP query message.
  • test/xap_receive.rb prints all xAP messages received from the network.

Users of xap_ruby

Submit a pull request if you use this library somewhere and would like a mention here.

Copyright

(C)2012-2017 Mike Bourgeous (and any Git contributors), licensed under two-clause BSD (see LICENSE)