Skip to content

Nagios compatible Check for Homematic devices and values using XMLAPI-Plugin

License

Notifications You must be signed in to change notification settings

Tommi2Day/hmcli

Repository files navigation

hmcli

Tool and Nagios/Icinga check plugin for Homematic/Raspberrymatic based on XMLAPI AddOn

pipeline status coverage report Latest Release

Setup

  • install XMLAPI-Addon on your Homematic/Raspberrymatic (see https://github.com/homematic-community/XML-API#installation)
  • create a token for the XMLAPI-Addon using tokenregister.cgi and notice the value (see https://github.com/homematic-community/XML-API#authentication)
  • put the binary in your nagios/icinga plugin directory
  • you may create a config file hmcli.yaml (usually in the same directory,$HOME/.hmcli or /etc/nagios-plugins/config or provide full path via --config flag) with the content in hmcli.yaml and modify for your site. You may provide all thes flags also on the command line
  • test the plugin with hmcli version --debug to see if the correct config file has been taken and hmcli device list to see if your CCU access is working. It should return a list of your devices. You may enable --debug to see details

Configuration

  • create the your command and service definitions as usual. For Icinga2 see special hints in Icinga2.md and Icinga Director configuration basket Icinga2_basket.json
  • to define a service, you have usually provide the ise_id (--id flag) of your devices, datapoints or system variables. You can get them with hmcli device list or hmcli datapoint list or hmcli sysvar list

hmcli tool reference

>hmcli --help
Query Tool and Nagios/Icinga check plugin for Homematic/Raspberrymatic with XMLAPI

Usage:
  hmcli [command]

Available Commands:
  completion    Generate the autocompletion script for the specified shell
  datapoint     command related to datapoints
  device        command related to devices
  help          Help about any command
  notifications check hmWarnThreshold notifications
  rssi          list rssi values of deviceList
  sysvar        command related to system variables
  value         command related to device master values
  version       version print version string

Flags:
  -C, --config string    config file name
  -c, --crit string      critical level
  -d, --debug            verbose debug output
  -h, --help             help for hmcli
  -T, --show-threshold   show threshold section
  -t, --token string     Homematic XMLAPI Token
      --unit-test        redirect output for unit tests
  -u, --url string       Homematic URL (default "http://ccu")
  -w, --warn string      warning level


#-------------------
>hmcli datapoint
command related to datapoints

Usage:
  hmcli datapoint [command]

Available Commands:
  check       check a single datapoint
  list        List all data points for a device

#-------------------
hmcli datapoint list --help
List all data points for a device

Usage:
  hmcli datapoint list [flags]

Flags:
  -h, --help           help for list
  -m, --match string   list data points with name matching regexp
#-------------------
>hmcli  datapoint check --help
select a single datapoint by name or id and check its value
You can set -w or -c to set the warning or critical threshold on numeric values

Usage:
  hmcli datapoint check [flags]

Flags:
  -h, --help           help for check
  -i, --id string      datapoint id (one) to query
  -m, --match string   datapoint value must match this regexp
  -n, --name string    datapoint name(one) to query

#-------------------
>hmcli  devices list --help
list all devices or a specify one

Usage:
  hmcli device list [flags]

Flags:
  -a, --address string   device addresses to query, comma separated
  -h, --help             help for list
  -i, --id string        device ids to query, comma separated
      --internal         also list internal channels
  -n, --name string      device name to query, comma separated

#-------------------

>hmcli mastervalue
command related to device master values

Usage:
  hmcli value [command]

Aliases:
  value, values, mastervalue, mastervalues

Available Commands:
  check       check a single device Value
  list        List all  device mastervalues or a specify one

Flags:
  -h, --help   help for value
#-------------------
>hmcli  mastervalue list --help
List for a given device all mastervalues  or a named value. 
Address or id must be given

Usage:
  hmcli value list [flags]

Flags:
  -a, --address string   device addresses to query, comma separated
  -h, --help             help for list
  -i, --id string        device ids to query, comma separated
  -n, --name string      requested mastervalue names, comma separated

#-------------------
>hmcli  mastervalue check --help
this retrives a given device mastervalue and may check if it contains a string (-m)
You can set -w or -c to set the warning or critical threshold on numeric values

Usage:
  hmcli value check [flags]

Flags:
  -a, --address string   device address (only one) to query, alternative to id
  -h, --help             help for check
  -i, --id string        device id (one) to query, alternative to address
  -m, --match string     returned master value must match this regexp
  -n, --name string      requested master value (not device) name ( only one)
#-------------------
>hmcli notifications --help
List all current notifications. 
You can set -w or -c to set the warning or critical threshold on notification count

Usage:
  hmcli notifications [flags]

Flags:
  -h, --help            help for notifications
  -I, --ignore string   regexp to ignore notifications
  -p, --print           print ignored notifications


#-------------------
>hmcli rssi --help
List available rssi values of devices

Usage:
  hmcli rssi [flags]

Flags:
  -h, --help   help for rssi

#-------------------
>hmcli sysvar --help
command related to system variables

Usage:
  hmcli sysvar [command]

Available Commands:
  check       check a single system variable
  list        List all system variables
#-------------------
hmcli.exe sysvar list --help
List all system variables

Usage:
  hmcli sysvar list [flags]

Flags:
  -h, --help   help for list
#-------------------
>hmcli sysvar check --help
select a single system variable by name or id and check its value

Usage:
  hmcli sysvar check [flags]

Flags:
  -h, --help           help for check
  -i, --id string      variable id (one) to query
  -m, --match string   value must match this regexp
  -n, --name string    value name(one) to query

hmcli examples

# list datapoints of a device (using regexp). omit --match to see all
>hmcli datapoint list --match "000955699D3D84"
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage:0 Datapoint: HmIP-RF.000955699D3D84:0.CONFIG_PENDING(4742) = true 
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage:0 Datapoint: HmIP-RF.000955699D3D84:0.DUTY_CYCLE(4746) = false 
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage:0 Datapoint: HmIP-RF.000955699D3D84:0.ERROR_CODE(4747) = 0
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage:0 Datapoint: HmIP-RF.000955699D3D84:0.LOW_BAT(4748) = false
....
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage Datapoint: HmIP-RF.000955699D3D84:1.CURRENT_ILLUMINATION(7799) = 0.140000
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage Datapoint: HmIP-RF.000955699D3D84:1.CURRENT_ILLUMINATION_STATUS(7800) = 0
Device: Bewegungsmelder Garage Channel: Bewegungsmelder Garage Datapoint: HmIP-RF.000955699D3D84:1.ILLUMINATION_STATUS(7801) = 0

# check a single datapoint (using exact name) and set warning level if value is not "true"
>hmcli datapoint check --name HmIP-RF.000955699D3D84:0.LOW_BAT --match "true"
CRITICAL: HmIP-RF.000955699D3D84:0.LOW_BAT returned value 'false', does not match 'true' 

Datapoint:HmIP-RF.000955699D3D84:0.LOW_BAT ID:4748 Value:=false
 | 'time'=847ms;;;;

# list devices by name (omit --name to see all)
>hmcli device list --name "Bewegungsmelder Garage"
ID:4740, Name: Bewegungsmelder Garage, Address: 000955699D3D84, Type: HmIP-SMO

# list master values of a device by id (id or name required)
>hmcli mastervalues list --id="4740"
Device (ID=4740): Bewegungsmelder Garage, Type: HmIP-SMO
  ARR_TIMEOUT=10
  CYCLIC_BIDI_INFO_MSG_DISCARD_FACTOR=1
  CYCLIC_BIDI_INFO_MSG_DISCARD_VALUE=57
  CYCLIC_INFO_MSG=1
  CYCLIC_INFO_MSG_DIS=1
  CYCLIC_INFO_MSG_DIS_UNCHANGED=20
  CYCLIC_INFO_MSG_OVERDUE_THRESHOLD=2
  DISABLE_MSG_TO_AC=0
  DUTYCYCLE_LIMIT=180
  ENABLE_ROUTING=1
  LOCAL_RESET_DISABLED=0
  LOW_BAT_LIMIT=2.200000

# check a single master value (usinng id) and set warning level if value is  >=9
>xheck_hm.exe mastervalues check --id 4740 --name ARR_TIMEOUT -w 9
ARR_TIMEOUT=10 


Device:4740 ID:Bewegungsmelder Garage ValueName:ARR_TIMEOUT=10
 | 'Bewegungsmelder Garage(4740).ARR_TIMEOUT'=10;9;;; 'time'=156ms;;;;
 
# check notifications and warn if there is one or more pending
>hmcli.exe notifications -w 1
1 notifications pending 

CONFIG_PENDING: HmIP-RF.000955699D3D84:0.CONFIG_PENDING(Bewegungsmelder Garage) since 2024-02-17T18:25:31+01:00

 | 'notifications'=1;1;;; 'time'=2029ms;;;;

# check notifications as before, but ignore sticky and config pending notifications
>hmcli.exe notifications -I 'STICKY|PENDING' -w 1
0 notifications pending | 'notifications'=0;1;;; 'time'=1853ms;;;;

# print ignored notifications
>hmcli.exe notifications -I 'STICKY|PENDING' -p
0 notifications pending, 1 ignored | 'notifications'=0;;;; 'time'=1764ms;;;; 

IGNORED: 
CONFIG_PENDING: HmIP-RF.000955699D3D84:0.CONFIG_PENDING(Bewegungsmelder Garage) since 2024-02-17T18:25:31+01:00
# list rssi values of devices
>hmcli.exe rssi
Address:BidCoS-RF rx:65536 tx: -56
Address:KEQ1070683 rx:65536 tx: -73
Address:MEQ0272433 rx:65536 tx: -58

# list system variables and find id of a variable
>hmcli.exe sysvar list
ID:7931, Name: DutyCycle-Alarm, Value: nicht ausgelöst, INFO: DutyCycle 98% (CCU)
ID:7794, Name: WatchDog-Alarm, Value: nicht ausgelöst, INFO: Unclean shutdown or system crash identified
ID:1233, Name: Alarmzone 1, Value: ausgelöst, INFO: Alarmmeldung Alarmzone 1, Since:2024-02-17 19:15:22
ID:950, Name: Anwesenheit, Value: anwesend, INFO: Anwesenheit, Since:2024-01-31 21:33:04
ID:6548, Name: DutyCycle, Value: 36.000000 %, INFO: DutyCycle CCU, Since:2024-02-17 21:54:00

# check HM DutyCyle variable and set warning level if value is >=30
# DutyCycle needs to be published by removing the "internal" flag in CCU Systemvariables settings
>hmcli.exe sysvar check --id 6548 -w 30
DutyCycle=34.000000 (%) 

ID:6548, Name: DutyCycle, Value: 34.000000 %, INFO: DutyCycle CCU, Since:2024-02-17 21:58:00
 | 'DutyCycle(6548).'=34.000000;30;;; 'time'=229ms;;;;

see also

About

Nagios compatible Check for Homematic devices and values using XMLAPI-Plugin

Resources

License

Stars

Watchers

Forks

Packages

No packages published