2037
|
1 #!/usr/bin/env python2 |
|
2 # -*- coding: utf-8 -*- |
|
3 |
|
4 # SàT plugin for managing raw XML log |
|
5 # Copyright (C) 2009-2016 Jérôme Poisson (goffi@goffi.org) |
|
6 |
|
7 # This program is free software: you can redistribute it and/or modify |
|
8 # it under the terms of the GNU Affero General Public License as published by |
|
9 # the Free Software Foundation, either version 3 of the License, or |
|
10 # (at your option) any later version. |
|
11 |
|
12 # This program is distributed in the hope that it will be useful, |
|
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
15 # GNU Affero General Public License for more details. |
|
16 |
|
17 # You should have received a copy of the GNU Affero General Public License |
|
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
19 |
|
20 from sat.core.i18n import _ |
|
21 from sat.core.log import getLogger |
|
22 log = getLogger(__name__) |
|
23 from sat.core.constants import Const as C |
|
24 import json |
|
25 |
|
26 PLUGIN_INFO = { |
|
27 "name": "Debug Plugin", |
|
28 "import_name": "DEBUG", |
|
29 "type": "Misc", |
|
30 "protocols": [], |
|
31 "dependencies": [], |
|
32 "main": "Debug", |
|
33 "handler": "no", |
|
34 "description": _("""Set of method to make development and debugging easier""") |
|
35 } |
|
36 |
|
37 |
|
38 class Debug(object): |
|
39 |
|
40 def __init__(self, host): |
|
41 log.info(_("Plugin Debug initialization")) |
|
42 self.host = host |
|
43 host.bridge.addMethod("debugFakeSignal", ".plugin", in_sign='sss', out_sign='', method=self._fakeSignal) |
|
44 |
|
45 |
|
46 def _fakeSignal(self, signal, arguments, profile_key): |
|
47 """send a signal from backend |
|
48 |
|
49 @param signal(str): name of the signal |
|
50 @param arguments(unicode): json encoded list of arguments |
|
51 @parm profile_key(unicode): profile_key to use or C.PROF_KEY_NONE if profile is not needed |
|
52 """ |
|
53 args = json.loads(arguments) |
|
54 method = getattr(self.host.bridge, signal) |
|
55 if profile_key != C.PROF_KEY_NONE: |
|
56 profile = self.host.memory.getProfileName(profile_key) |
|
57 args.append(profile) |
|
58 method(*args) |
|
59 |
|
60 |
|
61 |