4 from dbuscron.bus import get_dbus_message_type, dbus_to_str
5 from dbuscron.logger import Logger
9 def __init__(self, cmd):
12 self.__file = os.environ.get('SHELL', '/bin/sh')
13 self.__args = [self.__file, '-c', self.__value]
15 self.__args = cmd.split(' ')
16 self.__file = self.__args[0]
17 if len(self.__args) == 1 \
18 and self.__file.startswith('!'):
19 self.__file = self.__file.lstrip('!')
20 self.__auto_args = True
22 self.__auto_args = False
24 def __call__(self, bus, message, environ):
25 args_list = map(dbus_to_str, message.get_args_list())
30 (('DBUS_ARG%d' % i, a) for i, a in enumerate(args_list)),
31 DBUS_ARGN = str(len(args_list)),
32 DBUS_SENDER = str(message.get_sender()),
33 DBUS_DEST = str(message.get_destination()),
34 DBUS_IFACE = str(message.get_interface()),
35 DBUS_PATH = str(message.get_path()),
36 DBUS_MEMBER = str(message.get_member()),
37 DBUS_BUS = bus.__class__.__name__.lower()[0:-3],
39 #DBUS_ERROR = str(message.get_error_name()),
40 DBUS_TYPE = get_dbus_message_type(message)
44 log.error('environ exception', e)
48 if dbus_env['DBUS_TYPE'] in ('signal', 'method_call'):
50 dbus_env['DBUS_IFACE'],
51 dbus_env['DBUS_MEMBER']]
53 #elif dbus_env['DBUS_TYPE'] == 'error':
54 # args_list.insert(0, dbus_env['DBUS_ERROR'])
58 dbus_env['DBUS_SENDER'],
59 dbus_env['DBUS_DEST']]
61 args_list = self.__args
63 result = os.spawnvpe(os.P_WAIT, self.__file, args_list, env)
65 log.warn('command returned non-zero status', self.__file, args_list, dbus_env, result)
69 def is_shell_cmd(self):
78 class Commands(object):
83 for m, c in self.__commands.iteritems():
86 def _get_environ(self):
89 def _set_environ(self, value):
90 self.__environ = dict()
91 self.__environ.update(os.environ)
92 self.__environ.update(value)
94 environ = property(_get_environ, _set_environ)
96 def handler(self, bus, message):
97 for rule, command in self.__commands.iteritems():
98 if rule.match(bus, message):
99 log('rule matched', rule, command)
100 command(bus, message, self.__environ)
103 def add(self, matcher, command):
104 self.__commands[matcher] = command