Added inspect.get_config()
method to get the configuration programmatically
This commit is contained in:
parent
3c3ee09d90
commit
dc1b54961f
3 changed files with 29 additions and 6 deletions
|
@ -344,15 +344,19 @@ class Config(object):
|
||||||
_default_config_instance = Config(cfgfile)
|
_default_config_instance = Config(cfgfile)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get(key):
|
def get(key: Optional[str] = None):
|
||||||
"""
|
"""
|
||||||
Gets a config value
|
Get a config value or the whole configuration object.
|
||||||
Params:
|
|
||||||
key -- Config key to get
|
:param key: Configuration entry to get (default: all entries).
|
||||||
"""
|
"""
|
||||||
global _default_config_instance
|
global _default_config_instance
|
||||||
if _default_config_instance is None:
|
if _default_config_instance is None:
|
||||||
_default_config_instance = Config()
|
_default_config_instance = Config()
|
||||||
return _default_config_instance._config.get(key)
|
|
||||||
|
if key:
|
||||||
|
return _default_config_instance._config.get(key)
|
||||||
|
|
||||||
|
return _default_config_instance._config
|
||||||
|
|
||||||
# vim:sw=4:ts=4:et:
|
# vim:sw=4:ts=4:et:
|
||||||
|
|
|
@ -63,7 +63,11 @@ class Message(object):
|
||||||
if isinstance(obj, JSONAble):
|
if isinstance(obj, JSONAble):
|
||||||
return obj.to_json()
|
return obj.to_json()
|
||||||
|
|
||||||
return super().default(obj)
|
try:
|
||||||
|
return super().default(obj)
|
||||||
|
except Exception as e:
|
||||||
|
logger.warning('Could not serialize object type {}: {}: {}'.format(
|
||||||
|
type(obj), str(e), obj))
|
||||||
|
|
||||||
def __init__(self, timestamp=None, *args, **kwargs):
|
def __init__(self, timestamp=None, *args, **kwargs):
|
||||||
self.timestamp = timestamp or time.time()
|
self.timestamp = timestamp or time.time()
|
||||||
|
|
|
@ -4,6 +4,7 @@ import json
|
||||||
import pkgutil
|
import pkgutil
|
||||||
import re
|
import re
|
||||||
import threading
|
import threading
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
import platypush.backend
|
import platypush.backend
|
||||||
import platypush.plugins
|
import platypush.plugins
|
||||||
|
@ -339,5 +340,19 @@ class InspectPlugin(Plugin):
|
||||||
"""
|
"""
|
||||||
return json.loads(json.dumps(Config.get_procedures(), cls=ProcedureEncoder))
|
return json.loads(json.dumps(Config.get_procedures(), cls=ProcedureEncoder))
|
||||||
|
|
||||||
|
@action
|
||||||
|
def get_config(self, entry: Optional[str] = None) -> dict:
|
||||||
|
"""
|
||||||
|
Return the configuration of the application or of a section.
|
||||||
|
|
||||||
|
:param entry: [Optional] configuration entry name to retrieve (e.g. ``workdir`` or ``backend.http``).
|
||||||
|
:return: The requested configuration object.
|
||||||
|
"""
|
||||||
|
if entry:
|
||||||
|
return Config.get(entry)
|
||||||
|
|
||||||
|
cfg = Config.get()
|
||||||
|
return cfg
|
||||||
|
|
||||||
|
|
||||||
# vim:sw=4:ts=4:et:
|
# vim:sw=4:ts=4:et:
|
||||||
|
|
Loading…
Reference in a new issue