Project

subaru

0.0
No commit activity in last 3 years
No release in over 3 years
RESTful API to industrial web relays
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

~> 1.1
~> 1.4
 Project Readme

Subaru

A gem to run RESTful (kinda) API server to industrial relays.

The subaru command will launch a Sinatra based server, functioning as a gateway to your web-enabled relays.

Supported Relays

  • Xytronix (a.k.a. ControlByWeb)
    • WebRelay
    • WebRelay-10

I welcome requests for other relay equipment. If development/evaluation units can be provided, that would increase the likelyhood of support.

Requirements

  • Ruby 2.0.0 <=
  • Kajiki 1.1 <=
  • Sinatra 1.4 <=

Getting Started

Install

$ gem install subaru

Configure

Store configuration in a YAML file. If you need a template, just try to start Subaru without the --config option and it'll output an example.

---
:global:
  :pretty_json: YES
  :auth_tokens:
    :any:
      - abcd # This is the auth token. List as many as you want, or remove it to disable auth.

:devices:
  factory: # This is the device name to use in the URL.
    :definition: Xytronix::WebRelay
    :url: http://192.168.0.10
    :password: password
    :read_timeout: 15

Run

$ subaru start -c config.yml

Consume

GET to read the state.

$ curl http://subaru/factory
{
  "relay": "off",
  "input": "off"
}

PUT to set the state.

$ curl -X PUT http://subaru/factory -d '{"relay":"on"}'
{
  "relay": "on",
  "input": "off"
}

Security

For obvious reasons, you should not expose this server to the public. If so, at least protect behind a reverse proxy, like NGINX, and/or require auth over HTTPS.