1012

Vera Serial Interface Module

This page explains how we are implementing our upcoming LuaUpNP feature in Vera. The document gets a bit technical so that users can comment on it and we can make adjustments as the feature comes closer to release.

Suitable for the Vera Lite and Vera Edge running User Interface Version 7. The DB9M to RJ12 cable to the USB cable and a spare serial port on the automation controller (use serial port 2-5). You can now power on the Vera. Your Vera is. Pairing Z Wave Modules to the Vera 3 which can be found on the ADA Website.

User feedback is appreciated and a sticky topic has been created in the 'Vera Developers' section of for comments. This new feature is very significant for Vera because it expands the possibilities of Vera greatly, and makes it very simple to create really powerful automation systems. This one module provides infrared (IR) control for audio-visual (A/V) devices, serial/USB/Ethernet control for any type of device, and a Lua scripting engine that can be used to do just about anything. And it's all based on UPnP, so anything you can create can be controlled from a standard UPnP control point.

Some background information: UPnP allows you to describe any type of device in a generic way, explaining what the device can do and how to control it. Then, there are a variety of UPnP control points, which are remote controls, such as a wall-mounted touch-panel, which are able to scan the network for UPnP devices, find out what those devices can do, and present you with a remote control. Lua is a fast, lightweight scripting language for creating macros, code snippets, and even stand alone applications. Our LuaUPnP solution consists of 3 parts: 1) The device builder web site; 2) the LuaUPnP engine; 3) any number of input-output (I/O) devices (infrared transmitters/receivers, RS232 ports, etc.). Here is a general work flow showing how the user creates and uses devices. Contents • • • • • • Adding a basic infrared A/V device or RS232 that already exists in the database 1.

Telecharger Processim Gratuit more. The user adds an infrared transmitter/receiver, such as plugging a Global Cache GC-100 into the LAN, or a USBUIRT into the extra USB port on Vera. The device is recognized and appears automatically on Vera's devices list. For communicating with a serial/RS232 device, the user can also connect a generic USB->RS232 (usb->serial) cable in Vera's spare USB port, or connect the device to one of the serial ports on a GC-100. The user goes to the 'Devices' tab in Vera's 'Setup' user interface (UI), chooses the 'Add LuaUPnP device', and is presented with a web form to help locate the device. After picking the manufacturer, type of device, model #, etc., Vera asks to assign a room and choose the I/O device associated with it (e.g. The USBUIRT or the port on the GC-100 or the usb->serial device).

The device is now broadcast as a UPnP device and can be controlled from any UPnP control point. In Vera's 'Scenes' tab, an 'Add actions' button appears next to the device, allowing a choice of action(s) to send the device as part of the scene (i.e. 'TV on', 'Mute', etc.). Adding a new, basic infrared A/V device or RS232 that does not exist yet Step 1 above is the same, and step 2 starts out the same, but when picking the device, choose 'Device not on the list'. The user fills in a form with basic information about the device, such as the manufacturer, model, type, etc.

The user also picks how to send commands to the device: Infrared codes, RS232 data, network calls, etc., or picks 'None' if this is purely a logic device that doesn't directly control any other device. An example might be a 'Cold weather logic' device that may wait for sunset, and then check weather.com to see if the temperature is expected to drop below freezing, and if so, turn on the thermostat. This is a 'logic' device because it's not directly controlling any device (as when a Z-Wave module controls the thermostat), it's merely providing logic.

The user can also indicate if this device will be 'public' for other users to use too, or 'private', just for his Vera. This data is stored in an XML file that is a standard UPnP device description. The user picks one or more of the standard service definitions (ie 'TV', 'CD Player', etc.). These have a list of actions, like 'On', 'Off', 'Mute', etc.

If there is no standard service definition, a new one can be created, in which all of the device's supported actions ('On', 'Off', 'Dim', etc.) are added, and for each action, any number of optional arguments. For example, 'On' and 'Off' may not have any arguments, but 'Dim' takes a 'Level' argument. This data is stored in an XML file that is a standard UPnP service description.

Now the user has a form that lists each action, and next to each action is a pull-down where the user can choose what to do in response to that action. The choices are: a) Send data to the device. There's an input box for the user to type in the data. The format of the data corresponds to the communication method picked above. If the communication is 'infrared', the user types an IR code in the box. If it's RS232, type in the data to send to the device.

B) Run some Lua code. These can be mixed and matched. Monopoly Pc Spiel Deutsch Vollversion. For example, this may be an infrared TV and basic commands, like 'channel up' just require sending a code. But other commands, like 'input #4' may require some logic to toggle inputs; for this, the user might write a Lua script. If the device is infrared, there's also a button 'Learn the IR code', which learns the code from an infrared learner. The user also has the option of adding, for each action, Lua code to be run when: a) incoming data is received and the command is being executed, b) the command is completed, c) the command is aborted, d) the command times out.

There are a couple other options for a command, such as specifying if the command should be aborted when another one of the same or other commands comes in before it's finished (e.g. If the user wants to turn the device off, but an 'on' command comes in before the device has turned 'off', abort the 'off'). After this is done, the user can add the device as described previously. Writing the Lua Code Whenever a command is received, it's assigned an internal Job #. This is true whether or not there's any Lua script to be run. So, calling an action results in a Job, and the Job will either send the data (the IR code, serial data, etc), or call the Lua script for that action if you wrote any. For each action, there are 3 functions, or blocks of Lua script, you can create.

1) The _Run script, which is called when the action is received and needs to run. 2) The _Callback script, when the job is waiting for some data to come back. 3) The _Timeout script, when data was not received in time. If the user wrote some _Run Lua script in step 3 above, it's called and passed as arguments to the job number plus any parameters for the action. All Lua scripts for a device run in the same instance, so they can all share global variables.

The Lua script does whatever is needed in response to the command. It can call Lua functions as well as functions which LuaUPnP exports to the Lua engine. The Lua script can also set a global variable called 'Status' to some free form text, like 'sending command', or 'device not responding'. When the Lua script exits, it returns 2 parameters: 1) the job status, which is: job_WaitingToStart, job_Error, job_Aborted, job_Done, or job_WaitingForCallback.

2) the second parameter is a delay, in seconds, for the job to timeout. If the job status is job_Done, that is the normal situation when everything is okay. The timeout is not used.

If it's job_Abort or job_Error, the job is also marked as 'completed', but it ended in an error condition, or because the user aborted it. The timeout is not used. If it's job_WaitingToStart, then the same Lua script will be called again after [timeout] seconds have passed. This is a way to say 'I'm not ready to do this now, let me try again later'.

If it's job_WaitingForCallback, then this means the script is waiting for some incoming data. For example, maybe the protocol requires sending something over the serial port and waiting for an 'OK' to come back.

If the job does not complete within [timeout] seconds, the _Timeout Lua script is called, which, if not defined, simply sets the status to 'Timed out' and returns job_Error. When data comes in through the I/O device (i.e.

Serial port, etc.), that data is first sent to the _Callback script of the job in the 'job_WaitingForCallback' state. The 'callback' code returns a) whether it processed the incoming data, b) the job status, and c) the timeout. If it returns 'false' to the first parameter, the framework will keep looking for other pending jobs that are in the 'job_WaitingForCallback' state, and if all of them return false, it goes to a generic 'Incoming data' script.

If the job status returned is 'job_WaitingForCallback', then the job is still waiting and will be called again when data comes in. The web engine takes care of creating the function names to shelter non-programmers from as much coding as possible. However, internally, all the script is stored in Lua functions. So, for example, if there's an On action, and the user adds _Run, _Timeout and _Callback script, there will be 3 Lua functions the framework creates: On_Run, On_Timeout and On_Callback.

The user can also create with the web user interface a block of Lua script to run on startup (Startup), shutdown (Shutdown), as well as to run when data is received that wasn't handled by a job (IncomingData), and also an idle loop when the device is idle (IdleLoop). So here is some pseudo code to explain the concept.

Let's say that you want to add control for a TV with an RS232 interface. To turn the TV on you send the string: and when it's processed, it responds with if was processed, or if it couldn't be processed. The TV may also send unsolicited data on the serial port when the status changes, such as when the TV is turned on.

You add the device, add the actions, 'On', 'Off', etc. Now when adding the implementation, you could take the really simple approach and next to the On action, choose 'Send' from the pull down and just put in the input box. This would work. But, perhaps you want to write Lua script to be able to process the return values or to know if the command went through, and maybe you want to be able to process incoming events, like to update the state of the UPnP device so if the user turns it on by hand, the status of the UPnP device changes to On.

Since we have changed USB chips in the AD2USB, the default driver on the Vera does not successfully find our device right off the bat and there are a few steps that need to be completed to get the AD2USB to show up in the serial port configuration of the Ademco plugin. So, here we are: 1. Type: lsusb - this will list all the vendor and product id for usb ports and adapters on your vera - the AD2USB will show up as 0403:6015, 0403:6010 or 0403:60xx for example. Write this down as it is your 'vendor id:product id' - if you're not sure which your AD2USB is, unplug your AD2USB and type 'lsusb'.

Plug it in and type 'lsusb'. See which line was added.

That is your adapter's info. It is important to get the correct vendor id and product id! Type: rmmod -f ftdi_sio - we are removing the existing ftdi driver for the AD2USB. We will add one specifically for the AD2USB adapter next. Ignore errors as when we reboot at the end this will not matter. Type: insmod vendor=0x403 product=0x6015 (replace the values with your found vendor id and product id) - this loads the driver specifically for your AD2USB adapter 4.

Type: echo 'ftdi_sio vendor=0x403 product=0x6015' >/etc/modules.d/65-usb-serial-ftdi (replace the values with your found vendor id and product id) - this allows your vera to autoload drivers for the AD2USB even after reboot or power cycles. The original file just has 'ftdi_sio' 5. Type: echo 'vendor:0403 product:6015' >/etc/cmh/serproxy.ports (replace the values with your found vendor id and product id) - this allows vera 3 to see the new adapter as a serial adapter and adds it to the UI. 6: Reboot your Vera and you should have the correct modules loaded.

A special thank you to user helraiser on the Vera plugin forum at: Site Admin Posts: 878 Joined: Fri Aug 16, 2013 10:10 am.