hue/get-id.py

61 lines
1.8 KiB
Python
Executable File

#!/usr/bin/env python3
#
# Copyright 2019-2020, Mischa Peters <mischa AT high5 DOT nl>, High5!.
# Version 1.0 - 20191103
# Version 1.1 - 20200507 - added config file support
#
# Collect all information of given id
#
# For example:
# $ get-id.py <bridge name> -t sensors -i 6
#
# Requires:
# - Python 3.x
#
import argparse
import ssl
import urllib.request
import json
import os
import configparser
parser = argparse.ArgumentParser(description="Get id information")
parser.add_argument("bridgename", type=str, help="Hue Bridge name in specified in hue.conf")
parser.add_argument("-i", "--id", type=int, default='1', help="id#")
parser.add_argument("-t", "--type", type=str, default='lights', help="lights|sensors|groups|rules")
parser.add_argument("-v", "--verbose", action='store_true', help="verbose")
try:
args = parser.parse_args()
bridgename = args.bridgename
id = args.id
type = args.type
verbose = args.verbose
except argparse.ArgumentError as e:
print(str(e))
config_files = ['./hue.conf', './.hue.conf', '/etc/hue.conf', '/etc/hue/hue.conf', os.path.expanduser('~/.hue.conf'), os.path.expanduser('~/hue.conf')]
config = configparser.RawConfigParser()
config.read(config_files)
bridge = config.get(bridgename, 'ip')
token = config.get(bridgename, 'token')
no_cert_check = ssl.create_default_context()
no_cert_check.check_hostname=False
no_cert_check.verify_mode=ssl.CERT_NONE
url = f"https://{bridge}/api/{token}/{type}/{id}"
req = urllib.request.Request(url)
with urllib.request.urlopen(req, context=no_cert_check) as response:
content = response.read()
json_data = json.loads(content)
if not 'state' in json_data:
print(f"{type[:-1]} id {id} doesn't exist")
else:
if verbose: print("json dump:")
if verbose: print(json.dumps(json_data, indent=4, sort_keys=True))
if verbose: print("state")
print(json_data['state'])