/* * Author: Jon Trulson * Copyright (c) 2016 Intel Corporation. * * This program and the accompanying materials are made available under the * terms of the The MIT License which is available at * https://opensource.org/licenses/MIT. * * SPDX-License-Identifier: MIT */ var sensorObj = require('jsupm_ozw'); /************** Main code **************/ var defaultDev = "/dev/ttyACM0"; // if an argument was specified, use it as the device instead if (process.argv.length > 2) { defaultDev = process.argv[2]; } console.log("Using device " + defaultDev); // Instantiate an Aeotec Door/Window 2nd Edition sensor instance, on // device node 10. You will almost certainly need to change this to // reflect your own network. Use the ozwdump example to see what // nodes are available. var sensor = new sensorObj.AeotecDW2E(10); // The first thing to do is create options, then lock them when done. sensor.optionsCreate(); sensor.optionsLock(); // Next, initialize it. console.log("Initializing, this may take awhile depending on your ZWave network"); sensor.init(defaultDev); console.log("Initialization complete"); console.log("Querying data..."); setInterval(function() { if (sensor.isDeviceAvailable()) { console.log("Alarm status: " + sensor.isAlarmTripped()); console.log("Tamper Switch status: " + sensor.isTamperTripped()); console.log("Battery Level: " + sensor.getBatteryLevel() + "%"); console.log(); } else { console.log("Device has not yet responded to probe."); console.log("Try waking it, or wait until it wakes itself if " + "configured to do so."); console.log(); } }, 1000); // exit on ^C process.on('SIGINT', function() { sensor = null; sensorObj.cleanUp(); sensorObj = null; console.log("Exiting."); process.exit(0); });