Mercurial > libervia-backend
comparison libervia/backend/plugins/plugin_misc_debug.py @ 4071:4b842c1fb686
refactoring: renamed `sat` package to `libervia.backend`
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 02 Jun 2023 11:49:51 +0200 |
parents | sat/plugins/plugin_misc_debug.py@524856bd7b19 |
children |
comparison
equal
deleted
inserted
replaced
4070:d10748475025 | 4071:4b842c1fb686 |
---|---|
1 #!/usr/bin/env python3 | |
2 | |
3 # SàT plugin for managing raw XML log | |
4 # Copyright (C) 2009-2016 Jérôme Poisson (goffi@goffi.org) | |
5 | |
6 # This program is free software: you can redistribute it and/or modify | |
7 # it under the terms of the GNU Affero General Public License as published by | |
8 # the Free Software Foundation, either version 3 of the License, or | |
9 # (at your option) any later version. | |
10 | |
11 # This program is distributed in the hope that it will be useful, | |
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 # GNU Affero General Public License for more details. | |
15 | |
16 # You should have received a copy of the GNU Affero General Public License | |
17 # along with this program. If not, see <http://www.gnu.org/licenses/>. | |
18 | |
19 import json | |
20 from libervia.backend.core.i18n import _ | |
21 from libervia.backend.core.log import getLogger | |
22 from libervia.backend.core.constants import Const as C | |
23 | |
24 | |
25 log = getLogger(__name__) | |
26 | |
27 PLUGIN_INFO = { | |
28 C.PI_NAME: "Debug Plugin", | |
29 C.PI_IMPORT_NAME: "DEBUG", | |
30 C.PI_TYPE: "Misc", | |
31 C.PI_PROTOCOLS: [], | |
32 C.PI_DEPENDENCIES: [], | |
33 C.PI_MAIN: "Debug", | |
34 C.PI_HANDLER: "no", | |
35 C.PI_DESCRIPTION: _("""Set of method to make development and debugging easier"""), | |
36 } | |
37 | |
38 | |
39 class Debug(object): | |
40 def __init__(self, host): | |
41 log.info(_("Plugin Debug initialization")) | |
42 self.host = host | |
43 host.bridge.add_method( | |
44 "debug_signal_fake", | |
45 ".plugin", | |
46 in_sign="sss", | |
47 out_sign="", | |
48 method=self._fake_signal, | |
49 ) | |
50 | |
51 def _fake_signal(self, signal, arguments, profile_key): | |
52 """send a signal from backend | |
53 | |
54 @param signal(str): name of the signal | |
55 @param arguments(unicode): json encoded list of arguments | |
56 @parm profile_key(unicode): profile_key to use or C.PROF_KEY_NONE if profile is not needed | |
57 """ | |
58 args = json.loads(arguments) | |
59 method = getattr(self.host.bridge, signal) | |
60 if profile_key != C.PROF_KEY_NONE: | |
61 profile = self.host.memory.get_profile_name(profile_key) | |
62 args.append(profile) | |
63 method(*args) |