Openhab python rule engine
Project description
OpenHAB python rule engine
A python 3.x rule engine for OpenHAB. This rule engine allows defining rule by using python 3.x.
Please consider that the OpenHAB username/password auhentication (basic authentication) needs to be enabled. To do this, open API security settings and activate advanced setting Allow Basic Authentication.
To run this software you may use Docker or PIP package manager such as shown below
Docker approach
sudo docker run -e openhab_uri=http://192.168.1.17:8080 -e user=me -e pwd=secret -v /etc/openhab2/automation/rules/python:/rules grro/pythonrule_engine
PIP approach
sudo pip install openhab-pythonrule-engine
After this installation you may start the rule engine inside your python code or via command line using
sudo pyrule --command listen --openhab_uri http://localhost:8080 --python_rule_directory /etc/openhab2/automation/rules/python --user me --pwd secret
Here, the rule engine will connect the openhab instance running on the local machine on port 8080. Furthermore, the directory /etc/openhab2/automation/rules/python will be used to scan for python-based rules
By running a systemd-based Linux distribution you may use the register command to register and start the rule engine as systemd unit. By doing this the rule engine will be started automatically on boot. Starting the rule engine manually using the listen command is no longer necessary.
sudo pyrule --command register --openhab_uri http://localhost:8080 --python_rule_directory /etc/openhab2/automation/rules/python --user me --pwd secret
Rules
To trigger a rule methode the @when decorator has to be used. Currently, the conditions listed below are supported
condition | example | description |
---|---|---|
cron | @when('Time cron */1 * * * *') | fires based on cron expression |
item state change | @when('Item PhoneLisaLastSeen changed') | fires when the specified Item's State changes |
item command | @when('Item SelectDoorCam received command ON') @when('Item SelectDoorCam received command OFF') |
fires when the specified Item receives a Command |
Example: my_rule.py (located within /etc/openhab2/automation/rules/python)
from openhab_pythonrule_engine.condition import when
from openhab_pythonrule_engine.item_registry import ItemRegistry
@when("Time cron */1 * * * *") # each minute
@when("Item PhoneLisaLastSeen changed")
@when("Item PhoneTimLastSeen changed")
def update_presence_based_on_phone_seen(item_registry: ItemRegistry):
last_time_present = item_registry.get_state_as_datetime('LastDateTimePresence')
for phone_name in item_registry.get_group_membernames('Phones'):
last_seen = item_registry.get_state_as_datetime(phone_name)
print(last_seen)
if last_seen > last_time_present:
last_time_present = last_seen
item_registry.set_state('LastDateTimePresence', last_time_present)
# uncomment the code below for local debugging
#item_registry = ItemRegistry.new_singleton(openhab_uri="http://192.168.1.27:8080/", user="xxx", pwd="secret")
#update_presence_based_on_phone_seen(item_registry)
If the rule method defines a (single!) argument, the item_registry object will be injected automatically. The item_registry provides methods to get and set the item state. By setting the state the data value will be auto converted into the item specific data type
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file openhab_pythonrule_engine-1.2.8.tar.gz
.
File metadata
- Download URL: openhab_pythonrule_engine-1.2.8.tar.gz
- Upload date:
- Size: 15.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8195c5ce80811d9780aae65baa5de59b943ce43ed6468538058357f6b172a927 |
|
MD5 | e55a5fbff5b8b6a67e817c78a520d89c |
|
BLAKE2b-256 | 925c5db357b46bb0635b03c6e5c2151863b1c9cc093d4bc937f8e558a338b58e |
File details
Details for the file openhab_pythonrule_engine-1.2.8-py3-none-any.whl
.
File metadata
- Download URL: openhab_pythonrule_engine-1.2.8-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f73afe902ce334c047185be6e36eabb30dff5dd0788606ac28f642db39500ade |
|
MD5 | 58d3ae96bc85c971669bcf1921e4adbd |
|
BLAKE2b-256 | 31628e4c1de7422c7321ea70b8059962a69c10991cf9001fe30967cfaa01a0af |