Skip to content

How to create a module

Ewan Bain edited this page Dec 22, 2016 · 5 revisions

Automation modules are intended to incapsulate functionality of some kind, bind to the Event Bus to emit and respond to events. Also only a module is able to spawn one or more virtual devices.

Every module has a folder named after the module itself under the modules/ folder in the ZAutomation's code folder (typically: automation).

For example: the module named "BatteryPolling" resides in "modules/BatteryPolling" folder.

Minimal module consists of two files:

  • index.js which should setup a _module variable which should be a reference to the module's class
  • module.json which defines module's meta information and default settings

Step 1. Provide an AutomationModule subclass

// Important: constructor SHOULD always be successful
function BatteryPolling (id, controller) {
    // Always call superconstructor first
    BatteryPolling.super_.call(this, id, controller);

    // Perform internal structures initialization...
}

inherits(BatteryPolling, AutomationModule);

_module = BatteryPolling;

Special function named inherits is a routine which creates a super_ property which references the superclass and does other prototypal inheritance preparations.

The last line of code exposes BatteryPolling class as a _module variable which will be requested at module's loading time.

Step 2. Define init function

// Init is a designated initializer and will be called once for each module's instance
// at the end of the ZAutomation startup process
BatteryPolling.prototype.init = function (config) {
    // Always call superclass' init first
    BatteryPolling.super_.prototype.init.call(this, config);

    // Subscribe to events, setup timers, instantiate virtual devices, register widgets and so on...

    this.batIds = this.scanForBatteries();
}

Step 3. Define other routines

BatteryPolling.prototype.scanForBatteries = function () {
    var self = this;
    return this.controller.devices.filter(function (vDev) {
        return vDev.get("deviceType") === "battery";
    }).map(function(vDev) {
        return vDev.id;
    });
}

Every AutomationModule has a controller property which refers to the AutomationController's singleton.

In the example above, this reference used to get the virtual devices list and iterate through it in case of searching for the virtual devices type "battery".