5
5
from twisted.internet.defer import succeed
7
7
from landscape.package.store import PackageStore
8
from landscape.package.changer import find_changer_command
8
from landscape.package.changer import PackageChanger
9
from landscape.package.releaseupgrader import ReleaseUpgrader
9
10
from landscape.manager.manager import ManagerPlugin
12
13
class PackageManager(ManagerPlugin):
14
15
run_interval = 1800
16
def __init__(self, package_store_filename=None):
17
super(PackageManager, self).__init__()
18
if package_store_filename:
19
self._package_store = PackageStore(package_store_filename)
21
self._package_store = None
22
self._changer_command = find_changer_command()
24
18
def register(self, registry):
25
19
super(PackageManager, self).register(registry)
31
25
self._package_store = PackageStore(filename)
33
27
registry.register_message("change-packages",
34
self._enqueue_message_as_changer_task)
28
self.handle_change_packages)
29
registry.register_message("release-upgrade",
30
self.handle_release_upgrade)
38
def _enqueue_message_as_changer_task(self, message):
39
self._package_store.add_task("changer", message)
34
def _handle(self, cls, message):
35
"""Queue C{message} as a task, and spawn the proper handler."""
36
self._package_store.add_task(cls.queue_name, message)
37
self.spawn_handler(cls)
39
def handle_change_packages(self, message):
40
return self._handle(PackageChanger, message)
42
def handle_release_upgrade(self, message):
43
return self._handle(ReleaseUpgrader, message)
43
46
result = self.registry.broker.get_accepted_message_types()
47
50
def _got_message_types(self, message_types):
48
51
if "change-packages-result" in message_types:
52
self.spawn_handler(PackageChanger)
53
if "operation-result" in message_types:
54
self.spawn_handler(ReleaseUpgrader)
51
def spawn_changer(self):
56
def spawn_handler(self, cls):
53
58
if self.config.config:
54
59
args.extend(["-c", self.config.config])
55
if self._package_store.get_next_task("changer"):
60
if self._package_store.get_next_task(cls.queue_name):
56
61
# path is set to None so that getProcessOutput does not
57
62
# chdir to "." see bug #211373
58
result = getProcessOutput(self._changer_command,
63
result = getProcessOutput(cls.find_command(),
59
64
args=args, env=os.environ,
62
result.addCallback(self._got_changer_output)
67
result.addCallback(self._got_output, cls)
64
69
result = succeed(None)
67
def _got_changer_output(self, output):
72
def _got_output(self, output, cls):
69
logging.warning("Package changer output:\n%s" % output)
74
logging.warning("Package %s output:\n%s" %
75
(cls.queue_name, output))