464
464
if timeout is None:
465
465
timeout = self.timeout
466
466
self.last_checked_ok = datetime.datetime.utcnow()
467
if self.disable_initiator_tag is not None:
468
gobject.source_remove(self.disable_initiator_tag)
469
if getattr(self, "enabled", False):
470
self.disable_initiator_tag = (gobject.timeout_add
471
(_timedelta_to_milliseconds
472
(timeout), self.disable))
473
self.expires = datetime.datetime.utcnow() + timeout
467
gobject.source_remove(self.disable_initiator_tag)
468
self.expires = datetime.datetime.utcnow() + timeout
469
self.disable_initiator_tag = (gobject.timeout_add
470
(_timedelta_to_milliseconds
471
(timeout), self.disable))
475
473
def need_approval(self):
476
474
self.last_approval_request = datetime.datetime.utcnow()
893
891
""" Modify a variable so that it's a property which announces
894
892
its changes to DBus.
896
transform_fun: Function that takes a value and a variant_level
897
and transforms it to a D-Bus type.
894
transform_fun: Function that takes a value and transforms it
898
896
dbus_name: D-Bus name of the variable
899
897
type_func: Function that transform the value before sending it
900
898
to the D-Bus. Default: no transform
901
899
variant_level: D-Bus variant level. Default: 1
903
attrname = "_{0}".format(dbus_name)
904
902
def setter(self, value):
903
old_value = real_value[0]
904
real_value[0] = value
905
905
if hasattr(self, "dbus_object_path"):
906
if (not hasattr(self, attrname) or
907
type_func(getattr(self, attrname, None))
908
!= type_func(value)):
909
dbus_value = transform_func(type_func(value),
906
if type_func(old_value) != type_func(real_value[0]):
907
dbus_value = transform_func(type_func
912
910
self.PropertyChanged(dbus.String(dbus_name),
914
setattr(self, attrname, value)
916
return property(lambda self: getattr(self, attrname), setter)
913
return property(lambda self: real_value[0], setter)
919
916
expires = notifychangeproperty(datetime_to_dbus, "Expires")
1398
1396
#wait until timeout or approved
1398
# ._timedelta_to_milliseconds(delay))
1399
1399
time = datetime.datetime.now()
1400
1400
client.changedstate.acquire()
1401
1401
(client.changedstate.wait
1430
1430
sent_size += sent
1432
1432
logger.info("Sending secret to %s", client.name)
1433
# bump the timeout using extended_timeout
1433
# bump the timeout as if seen
1434
1434
client.checked_ok(client.extended_timeout)
1435
1435
if self.server.use_dbus:
1436
1436
# Emit D-Bus signal
1517
1517
self.handle_error(request, address)
1518
1518
self.close_request(request)
1520
1520
def process_request(self, request, address):
1521
1521
"""Start a new process to process the request."""
1522
proc = multiprocessing.Process(target = self.sub_process_main,
1522
multiprocessing.Process(target = self.sub_process_main,
1523
args = (request, address)).start()
1529
1526
class MultiprocessingMixInWithPipe(MultiprocessingMixIn, object):
1536
1533
parent_pipe, self.child_pipe = multiprocessing.Pipe()
1538
proc = MultiprocessingMixIn.process_request(self, request,
1535
super(MultiprocessingMixInWithPipe,
1536
self).process_request(request, client_address)
1540
1537
self.child_pipe.close()
1541
self.add_pipe(parent_pipe, proc)
1538
self.add_pipe(parent_pipe)
1543
def add_pipe(self, parent_pipe, proc):
1540
def add_pipe(self, parent_pipe):
1544
1541
"""Dummy function; override as necessary"""
1545
1542
raise NotImplementedError
1634
1631
def server_activate(self):
1635
1632
if self.enabled:
1636
1633
return socketserver.TCPServer.server_activate(self)
1638
1634
def enable(self):
1639
1635
self.enabled = True
1641
def add_pipe(self, parent_pipe, proc):
1636
def add_pipe(self, parent_pipe):
1642
1637
# Call "handle_ipc" for both data and EOF events
1643
1638
gobject.io_add_watch(parent_pipe.fileno(),
1644
1639
gobject.IO_IN | gobject.IO_HUP,
1645
1640
functools.partial(self.handle_ipc,
1650
1644
def handle_ipc(self, source, condition, parent_pipe=None,
1651
proc = None, client_object=None):
1645
client_object=None):
1652
1646
condition_names = {
1653
1647
gobject.IO_IN: "IN", # There is data to read.
1654
1648
gobject.IO_OUT: "OUT", # Data can be written (without
1663
1657
for cond, name in
1664
1658
condition_names.iteritems()
1665
1659
if cond & condition)
1666
# error, or the other end of multiprocessing.Pipe has closed
1660
# error or the other end of multiprocessing.Pipe has closed
1667
1661
if condition & (gobject.IO_ERR | condition & gobject.IO_HUP):
1668
# Wait for other process to exit
1672
1664
# Read a request from the child