Last active
December 6, 2018 11:34
-
-
Save dvas0004/20070e8471f5e003d6d458e4fb72276f to your computer and use it in GitHub Desktop.
Interacting with ZWave network via Python-Openzwave: http://blog.davidvassallo.me/2018/12/06/z-wave-lessons-learned-python-openzwave/
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import logging | |
import sys, os | |
logging.basicConfig(level=logging.INFO) | |
logger = logging.getLogger('openzwave') | |
import openzwave | |
from openzwave.node import ZWaveNode | |
from openzwave.value import ZWaveValue | |
from openzwave.scene import ZWaveScene | |
from openzwave.controller import ZWaveController | |
from openzwave.network import ZWaveNetwork | |
from openzwave.option import ZWaveOption | |
import time | |
import six | |
if six.PY3: | |
from pydispatch import dispatcher | |
else: | |
from louie import dispatcher | |
device="/dev/ttyACM0" | |
log="None" | |
#Define some manager options | |
options = ZWaveOption(device, \ | |
config_path="/usr/etc/openzwave/", \ | |
user_path=".", cmd_line="") | |
options.set_log_file("OZW_Log.log") | |
options.set_append_log_file(False) | |
options.set_console_output(False) | |
options.set_save_log_level(log) | |
options.set_logging(True) | |
options.lock() | |
def louie_network_started(network): | |
print("Hello from network : I'm started : homeid {:08x} - {} nodes were found.".format(network.home_id, network.nodes_count)) | |
def louie_network_failed(network): | |
print("Hello from network : can't load :(.") | |
def louie_network_ready(network): | |
print("Hello from network : I'm ready : {} nodes were found.".format(network.nodes_count)) | |
print("Hello from network : my controller is : {}".format(network.controller)) | |
dispatcher.connect(louie_node_update, ZWaveNetwork.SIGNAL_NODE) | |
dispatcher.connect(louie_node_event, ZWaveNetwork.SIGNAL_NODE_EVENT) | |
dispatcher.connect(louie_value_update, ZWaveNetwork.SIGNAL_VALUE) | |
def louie_network_awake(network): | |
print("Hello from network : I'm awake") | |
def louie_node_update(network, node): | |
print("Hello from node : {}.".format(node)) | |
def louie_value_update(network, node, value): | |
print("Hello from value : {}.".format( value )) | |
def louie_node_event(**kwargs): | |
print("Hello from node event : {}.".format( kwargs )) | |
#Create a network object | |
network = ZWaveNetwork(options, autostart=False) | |
#We connect to the louie dispatcher | |
dispatcher.connect(louie_network_started, ZWaveNetwork.SIGNAL_NETWORK_STARTED) | |
dispatcher.connect(louie_network_failed, ZWaveNetwork.SIGNAL_NETWORK_FAILED) | |
dispatcher.connect(louie_network_ready, ZWaveNetwork.SIGNAL_NETWORK_READY) | |
dispatcher.connect(louie_network_awake, ZWaveNetwork.SIGNAL_NETWORK_AWAKED) | |
network.start() | |
#We wait for the network. | |
print("***** Waiting for network to become ready : ") | |
for i in range(0,90): | |
if network.state>=network.STATE_READY: | |
print("***** Network is ready") | |
break | |
else: | |
sys.stdout.write(".") | |
sys.stdout.flush() | |
time.sleep(1.0) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment