README
IoT Platform
Lynxari GPIO Input/Output device driver
This device driver is specifically designed to be used with the Agilatech® Lynxari IoT Platform. Please see agilatech.com to download a copy of the system.
Install
Gpio input/output device driver for use in the Agilatech Lynxari system
<script type="module">
import agilatechLynxariGpioDevice from 'https://cdn.skypack.dev/@agilatech/lynxari-gpio-device';
</script>
IoT Platform
This device driver is specifically designed to be used with the Agilatech® Lynxari IoT Platform. Please see agilatech.com to download a copy of the system.
gt; npm install @agilatech/lynxari-gpio-device
This device driver is designed to control a single GPIO input/output. The device must be designated as either an output OR an input. If it is an output, it can be set to high or low. If it is an input, the driver will publish a new value immediately upon being triggered, and it may also be triggered via software. No assumptions are made as to the end use of the output, be it lighting an LED or controlling the coolant valves on a nuclear power plant. Therefore, it is up to the end user application to decide upon latency and frequency issues.
This device driver is designed to be consumed by the Agilatech® Lynxari IoT system. As such, it is not really applicable or useful in other environments.
To use it with Lynxari, insert its object definition as an element in the devices array in the devlist.json file.
{
"name": "GPIO",
"module": "@agilatech/lynxari-gpio-device",
"options": {
"devicePoll": 1000,
"streamPeriod": 60000
}
}
The device config object is an element in the devlist.json device configuration file, which is located in the Lynxari root directory. It is used to tell the Lynxari system to load the device, as well as several operational parameters.
name is simply the name given to the device. This name can be used in queries and for other identifcation purposes.
module is the name of the npm module. The module is expected to exist in this directory under the node_modules directory. If the module is not strictly an npm module, it must still be found under the node_modules directory.
options is an object within the device config object which defines all other operational parameters. In general, any parameters may be defined in this options object, and most modules will have many several. The three which are a part of every Lynxari device are 'devicePoll', 'streamPeriod', and 'deltaPercent'. The gpio options also can define gpio, direction, edge, and debounce.
"devicePoll":<period>
Period in milliseconds in which device will be polled
"streamPeriod":<period>
Period in milliseconds for broadcast of streaming values
"gpio":<gpio>
The GPIO pin or other definition, where the system can connect to the I/O
"direction": <in|out>
Direction is either "in" for inputs or "out" for outputs. Defaults to "out".
"edge": <trigger edge>
Trigger edge can be one of "rising", "falling", "both", or "none". Defaults to "none".
"debounce": <miliseconds>
Defines a time after which further inputs are ignored. Used to debounce a mechanical switch. Defaults to 10.
Either in the .use statement or the config.json file, gpio must be defined to be the valid gpio pin number of the input or output. Note that this number may not be the same as the physical connector pin number on the board.
If direction is "in", then the device is expecting to be switched or triggered by some external event. If the direction is "out", then the device will output a high or a low to the pin.
Trigger inputs have a rising (leading) and falling (trailing) edge. This option defines which edge will cause the input event to be raised. If "both", then an event will be raised on the rising and falling edges.
All mechanical switches display some "bounce" where the signal will briefly fluctuate as it is switched. This bounce usually lasts for only a few milliseconds, but every switch is different. For that reason, this option ignores any further level changes for the time period after the initial trigger. The time period is in milliseconds, and has no upper limit.
These options have little applicability for an input/output device such as this. Since this device only updates the level property when commanded to do so, it makes little sense to stream the value or poll the device for a new value. Because of this, it is advisable to set streamPeriod to 0, which disables streaming, and set the devicePoll to some arbitrarily large value. Regardless of the setting of these config, the level parameter will be updated when it is changed.
Every module released by Agilatech includes configuration in a file named 'config.json' and we encourage any other publishers to follow the same pattern. The parameters in this file are considered defaults, since they are overriden by definitions appearing in the options object of the Lynxari devlist.json file.
The construction of the config.json mirrors that of the options object, which is simply a JSON object with key/value pairs. Here is an example of an 'config.json' file which puts the device on pin 2, disables streaming, and polls the device every hour:
{
"gpio":2,
"streamPeriod":0,
"devicePoll":3600000
}
If not specified in the config object, the program uses the following default values:
All drivers contain the following 4 core properties:
In the on state, the driver software for this device monitors one value.
For this gpio device, it is usual to disable streaming. However, if it is not disabled, while in the on state, the driver software continuously streams this value in isochronal fashion with a period defined by streamPeriod. Note that a streamPeriod of 0 disables streaming.
This device driver has a binary state: on or off. When off, no parameter values are streamed or available, and no commands are accepted other than the turn-on transition. When on, the device is operational and accepts all commands. The initial state is off.
turn-on : Sets the device state to on. When on, the device is operational and accepts all commands. Values are streamed, and the device is polled periodically to keep monitored values up to date.
turn-off : Sets the device state to off, When off, no parameter values are streamed or available, and no commands are accepted other than the turn-on transition.
This driver is designed to run within the Lynxari IoT platform. While Lynxari will run on nearly any operating system, this driver employs UNIX-specific protocols and as such will run on the following operating systems:
Copyright © 2018 Agilatech®. All Rights Reserved.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.