1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- # coding=utf-8
- #
- # The Qubes OS Project, http://www.qubes-os.org
- #
- # Copyright (C) 2015 Marek Marczykowski-Górecki
- # <marmarek@invisiblethingslab.com>
- #
- # This program is free software: you can redistribute it and/or modify
- # it under the terms of the GNU General Public License as published by
- # the Free Software Foundation, either version 2 of the License, or
- # (at your option) any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with this program. If not, see <http://www.gnu.org/licenses/>.
- #
- from __future__ import absolute_import
- from distutils.version import LooseVersion
- import logging
- import dnf
- import dnf.const
- import subprocess
- PLUGIN_CONF = 'qubes-hooks'
- class QubesHooks(dnf.Plugin):
- name = 'qubes-hooks'
- def __init__(self, base, cli):
- super(QubesHooks, self).__init__(base, cli)
- self.base = base
- self.log = logging.getLogger('dnf')
- def transaction(self):
- if LooseVersion(dnf.const.VERSION) < '2.0.0':
- config = self.read_config(self.base.conf, PLUGIN_CONF)
- else:
- config = self.read_config(self.base.conf)
- if config.getboolean('main', 'notify-updates'):
- if LooseVersion(dnf.const.VERSION) > '4.0.0':
- # self.base.transaction empty at this point in dnf4
- # https://bugzilla.redhat.com/1650446
- # until fixed, load the repositories again and again check for
- # updates
- base = dnf.Base()
- base.read_all_repos()
- base.fill_sack()
- query = base.sack.query()
- query = query.upgrades()
- updates = set(query.run())
- else:
- # Get all updates available _before_ this transaction
- query = self.base.sack.query()
- query = query.upgrades()
- updates = set(query.run())
- # Get packages installed in this transaction...
- just_installed = self.base.transaction
- # ...and filter them out of available updates
- for item in just_installed:
- for pkg in item.installs():
- updates.discard(pkg)
- subprocess.call([
- '/usr/lib/qubes/qrexec-client-vm',
- 'dom0',
- 'qubes.NotifyUpdates',
- '/bin/echo',
- str(len(updates))
- ])
- self.log.info("Notifying dom0 about installed applications")
- subprocess.call(['/etc/qubes-rpc/qubes.PostInstall'])
|