Blame


1 0aaad168 2019-11-03 mischa #!/usr/bin/env python3
2 0aaad168 2019-11-03 mischa #
3 496ad2f3 2020-05-07 mischa # Copyright 2019-2020, Mischa Peters <mischa AT high5 DOT nl>, High5!.
4 0aaad168 2019-11-03 mischa # Version 1.0 - 20191103
5 496ad2f3 2020-05-07 mischa # Version 1.1 - 20200507 - added config file support
6 0aaad168 2019-11-03 mischa #
7 0aaad168 2019-11-03 mischa # Get temperaure from all sensors
8 0aaad168 2019-11-03 mischa #
9 0aaad168 2019-11-03 mischa # For exmaple:
10 496ad2f3 2020-05-07 mischa # $ temperature.py <bridge name>
11 0aaad168 2019-11-03 mischa #
12 0aaad168 2019-11-03 mischa # Requires:
13 0aaad168 2019-11-03 mischa # - Python 3.x
14 0aaad168 2019-11-03 mischa #
15 0aaad168 2019-11-03 mischa import argparse
16 0aaad168 2019-11-03 mischa import ssl
17 0aaad168 2019-11-03 mischa import urllib.request
18 0aaad168 2019-11-03 mischa import json
19 0aaad168 2019-11-03 mischa import re
20 0aaad168 2019-11-03 mischa import collections
21 0aaad168 2019-11-03 mischa import math
22 496ad2f3 2020-05-07 mischa import os
23 496ad2f3 2020-05-07 mischa import configparser
24 0aaad168 2019-11-03 mischa
25 0aaad168 2019-11-03 mischa parser = argparse.ArgumentParser(description="Get temperature from Hue Bridge")
26 496ad2f3 2020-05-07 mischa parser.add_argument("bridgename", type=str, help="Hue Bridge name in specified in hue.conf")
27 640649c8 2019-11-03 mischa parser.add_argument("-v", "--verbose", action='store_true', help="verbose")
28 640649c8 2019-11-03 mischa parser.add_argument("-d", "--debug", action='store_true', help="debug")
29 0aaad168 2019-11-03 mischa
30 0aaad168 2019-11-03 mischa try:
31 0aaad168 2019-11-03 mischa args = parser.parse_args()
32 496ad2f3 2020-05-07 mischa bridgename = args.bridgename
33 640649c8 2019-11-03 mischa verbose = args.verbose
34 640649c8 2019-11-03 mischa debug = args.debug
35 0aaad168 2019-11-03 mischa
36 0aaad168 2019-11-03 mischa except argparse.ArgumentError as e:
37 0aaad168 2019-11-03 mischa print(str(e))
38 0aaad168 2019-11-03 mischa
39 496ad2f3 2020-05-07 mischa config_files = ['./hue.conf', './.hue.conf', '/etc/hue.conf', '/etc/hue/hue.conf', os.path.expanduser('~/.hue.conf'), os.path.expanduser('~/hue.conf')]
40 496ad2f3 2020-05-07 mischa config = configparser.RawConfigParser()
41 496ad2f3 2020-05-07 mischa config.read(config_files)
42 496ad2f3 2020-05-07 mischa bridge = config.get(bridgename, 'ip')
43 496ad2f3 2020-05-07 mischa token = config.get(bridgename, 'token')
44 496ad2f3 2020-05-07 mischa
45 0aaad168 2019-11-03 mischa no_cert_check = ssl.create_default_context()
46 0aaad168 2019-11-03 mischa no_cert_check.check_hostname=False
47 0aaad168 2019-11-03 mischa no_cert_check.verify_mode=ssl.CERT_NONE
48 0aaad168 2019-11-03 mischa
49 0aaad168 2019-11-03 mischa url = f"https://{bridge}/api/{token}/sensors"
50 0aaad168 2019-11-03 mischa req = urllib.request.Request(url)
51 0aaad168 2019-11-03 mischa with urllib.request.urlopen(req, context=no_cert_check) as response:
52 0aaad168 2019-11-03 mischa content = response.read()
53 0aaad168 2019-11-03 mischa json_data = json.loads(content)
54 0aaad168 2019-11-03 mischa
55 0aaad168 2019-11-03 mischa p = re.compile("([a-fA-F0-9]{2}:?){8}")
56 0aaad168 2019-11-03 mischa sensors = collections.defaultdict(list);
57 0aaad168 2019-11-03 mischa
58 0aaad168 2019-11-03 mischa for key in json_data:
59 0aaad168 2019-11-03 mischa if "uniqueid" in json_data[key]:
60 0aaad168 2019-11-03 mischa if p.search(json_data[key]['uniqueid']):
61 0aaad168 2019-11-03 mischa if json_data[key]['type'] == 'ZLLPresence':
62 0aaad168 2019-11-03 mischa sensors[json_data[key]['uniqueid'][:-8]].insert(0, key)
63 0aaad168 2019-11-03 mischa else:
64 0aaad168 2019-11-03 mischa sensors[json_data[key]['uniqueid'][:-8]].append(key)
65 0aaad168 2019-11-03 mischa
66 0aaad168 2019-11-03 mischa for key in sensors:
67 0aaad168 2019-11-03 mischa for i in sensors[key]:
68 0aaad168 2019-11-03 mischa if json_data.get(i)['type'] == 'ZLLPresence':
69 0aaad168 2019-11-03 mischa name = json_data.get(i)['name']
70 0aaad168 2019-11-03 mischa if json_data.get(i)['type'] == 'ZLLTemperature':
71 0aaad168 2019-11-03 mischa updated = json_data.get(i)['state']['lastupdated'][-8:]
72 a50be9a2 2019-11-17 mischa if json_data.get(i)['state']['temperature']:
73 a50be9a2 2019-11-17 mischa temperature = round((json_data.get(i)['state']['temperature'] / 100), 1)
74 a50be9a2 2019-11-17 mischa else:
75 a50be9a2 2019-11-17 mischa temperature = 0
76 640649c8 2019-11-03 mischa if verbose:
77 440a9b96 2019-11-06 mischa print (f"{name:<32s} - {temperature:>4}C (updated: {updated} UTC)")
78 640649c8 2019-11-03 mischa elif debug:
79 440a9b96 2019-11-06 mischa print (f"{name:<32s} - {temperature:>4}C (updated: {updated} UTC - sensor: {i})")
80 640649c8 2019-11-03 mischa else:
81 440a9b96 2019-11-06 mischa print (f"{name:<32s} - {temperature:>4}C")