Implemented Philips Hue plugin
This commit is contained in:
parent
9183599664
commit
1e75d2bda1
3 changed files with 118 additions and 10 deletions
|
@ -1,9 +1,11 @@
|
|||
import os
|
||||
import sys
|
||||
import logging
|
||||
|
||||
class Plugin(object):
|
||||
def __init__(self, config):
|
||||
self.config = config
|
||||
self._set_logging()
|
||||
|
||||
for cls in reversed(self.__class__.mro()):
|
||||
if cls is not object:
|
||||
|
@ -12,6 +14,11 @@ class Plugin(object):
|
|||
except AttributeError as e:
|
||||
pass
|
||||
|
||||
def _set_logging(self):
|
||||
if 'logging' in self.config:
|
||||
logging.basicConfig(level=getattr(logging, self.config['logging']))
|
||||
else:
|
||||
logging.basicConfig(level=logging.INFO)
|
||||
|
||||
def run(self, method, *args, **kwargs):
|
||||
res = getattr(self, method)(*args, **kwargs)
|
||||
|
|
|
@ -1,16 +1,6 @@
|
|||
from .. import Plugin
|
||||
|
||||
class LightPlugin(Plugin):
|
||||
def run(self, args):
|
||||
if 'on' in args and args['on']:
|
||||
self.on()
|
||||
elif 'off' in args and args['off']:
|
||||
self.off()
|
||||
elif 'toggle' in args and args['toggle']:
|
||||
self.toggle()
|
||||
|
||||
return self.status()
|
||||
|
||||
def on(self):
|
||||
raise NotImplementedError()
|
||||
|
||||
|
|
111
runbullet/plugins/light/hue/__init__.py
Normal file
111
runbullet/plugins/light/hue/__init__.py
Normal file
|
@ -0,0 +1,111 @@
|
|||
import logging
|
||||
|
||||
from phue import Bridge
|
||||
|
||||
from .. import LightPlugin
|
||||
|
||||
class LightHuePlugin(LightPlugin):
|
||||
""" Python dependencies """
|
||||
_requires = [
|
||||
'phue'
|
||||
]
|
||||
|
||||
MAX_BRI = 255
|
||||
MAX_SAT = 255
|
||||
MAX_HUE = 65535
|
||||
|
||||
def _init(self):
|
||||
self.bridge_address = self.config['bridge']
|
||||
self.bridge = None
|
||||
logging.info('Initializing Hue lights plugin - bridge: "{}"'.
|
||||
format(self.bridge_address))
|
||||
|
||||
self.connect()
|
||||
self.lights = []; self.groups = []
|
||||
|
||||
if 'lights' in self.config:
|
||||
self.lights = self.config['lights']
|
||||
elif 'groups' in self.config:
|
||||
self.groups = self.config['groups']
|
||||
self._expand_groups(self.groups)
|
||||
else:
|
||||
self.lights = [l.name for l in self.bridge.lights]
|
||||
|
||||
logging.info('Configured lights: "{}"'. format(self.lights))
|
||||
|
||||
def _expand_groups(self, group_names):
|
||||
groups = [g for g in self.bridge.groups
|
||||
if g.name in group_names]
|
||||
|
||||
for g in groups:
|
||||
self.lights.extend([l.name for l in g.lights])
|
||||
|
||||
def connect(self):
|
||||
# Lazy init
|
||||
if not self.bridge:
|
||||
self.bridge = Bridge(self.bridge_address)
|
||||
logging.info('Bridge connected')
|
||||
|
||||
# uncomment these lines if you're running huectrl for
|
||||
# the first time and you need to pair it to the switch
|
||||
|
||||
# self.bridge.connect()
|
||||
# self.bridge.get_api()
|
||||
else:
|
||||
logging.info('Bridge already connected')
|
||||
|
||||
|
||||
def _execute(self, setting, *args, **kwargs):
|
||||
try:
|
||||
self.connect()
|
||||
except Exception as e:
|
||||
logging.exception(e)
|
||||
# Reset bridge connection
|
||||
self.bridge = None
|
||||
return
|
||||
|
||||
lights = []; groups = []
|
||||
if 'lights' in kwargs and kwargs['lights']:
|
||||
lights = kwargs['lights'].split(',') \
|
||||
if isinstance(lights, str) else kwargs['lights']
|
||||
elif 'groups' in kwargs and kwargs['lights']:
|
||||
groups = kwargs['groups'].split(',') \
|
||||
if isinstance(groups, str) else kwargs['groups']
|
||||
else:
|
||||
lights = self.lights
|
||||
groups = self.groups
|
||||
|
||||
logging.info('[Setting: {}] [Values: {}] [Lights: {}] [Groups: {}]'.
|
||||
format(setting, args, lights, groups))
|
||||
|
||||
try:
|
||||
if groups:
|
||||
self.bridge.set_group(groups, setting, *args)
|
||||
elif lights:
|
||||
self.bridge.set_light(lights, setting, *args)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
logging.exception(e)
|
||||
# Reset bridge connection
|
||||
self.bridge = None
|
||||
|
||||
def on(self, lights=[], groups=[]):
|
||||
self._execute('on', True, lights=lights, groups=groups)
|
||||
|
||||
def off(self, lights=[], groups=[]):
|
||||
self._execute('on', False, lights=lights, groups=groups)
|
||||
|
||||
def bri(self, value, lights=[], groups=[]):
|
||||
self._execute('bri', int(value) % (MAX_BRI+1), lights=lights, groups=groups)
|
||||
|
||||
def sat(self, value, lights=[], groups=[]):
|
||||
self._execute('sat', int(value) % (MAX_SAT+1), lights=lights, groups=groups)
|
||||
|
||||
def hue(self, value, lights=[], groups=[]):
|
||||
self._execute('hue', int(value) % (MAX_HUE+1), lights=lights, groups=groups)
|
||||
|
||||
def status(self):
|
||||
return ['']
|
||||
|
||||
# vim:sw=4:ts=4:et:
|
||||
|
Loading…
Add table
Reference in a new issue