123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- """
- BeeWatch
- --------
- Fancy text about BeeWatch.
- BeeWatch is realy cool.
- Promote BeeWatch.
- """
- import logging
- import logging.handlers
- import sys
- import time
- import traceback
- import blinker
- import curio
- import digilib.network
- log = logging.getLogger(__name__+"")
- _controllers = {}
- _commands = {}
- class Configure(object):
- """
- Configure BeeWatch from a dict. See also :doc:/configure
- This class is inspired by logging.config
- (https://github.com/python/cpython/blob/3.6/Lib/logging/config.py)
- Parameters
- ----------
- config: dict
- dictionary holding config information. for more information see :doc:`/configure`
- """
- warnings = True
- def __init__(self,config):
- super(Configure,self).__init__()
- self.configure(config)
- def configure(self,config):
- retconf = {
- "controllers":{},
- "commands":{},
- }
-
- for name,properties in config.get("controllers",{}).items():
- log.debug("configuring {}".format(name))
- target = properties.pop("target")
- if not callable(target):
- target = self.str_to_callable(target)
- ctrl = target(**properties)
- if name in _controllers.keys() and self.warnings:
- log.warn("overwriting controller "+name)
- _controllers[name] = ctrl
- retconf["controllers"][name] = ctrl
-
- for name,properties in config.get("commands",{}).items():
- log.debug("configuring {}".format(name))
- function = properties.pop("function")
- ctrl = properties.pop("controller")
- if not callable(ctrl):
- if ctrl not in _controllers.keys():
- raise ValueError("No controller found with name " + ctrl)
- ctrl = _controllers[ctrl]
- if not hasattr(ctrl,function):
- raise ValueError(
- "{} doesn't have attribute {}".format(ctrl,function))
- function = getattr(ctrl,function)
- if name in _commands.keys() and self.warnings:
- log.warn("overwriting command "+name)
- _commands[name] = function
- retconf["commands"][name] = function
- def str_to_callable(self,dotted_str):
- parts = dotted_str.split(".")
- next_to_import = parts.pop(0)
- converted = __import__(next_to_import)
- for p in parts:
- next_to_import += "." + p
- if not hasattr(converted,p):
- converted = __import__(next_to_import)
- converted = getattr(converted,p)
- return converted
|