diff --git a/Makefile b/Makefile index b088288..e8205f1 100644 --- a/Makefile +++ b/Makefile @@ -115,7 +115,7 @@ install-common: install -D misc/polkit-1-qubes-allow-all.rules $(DESTDIR)/etc/polkit-1/rules.d/00-qubes-allow-all.rules install -D -m 0644 misc/mime-globs $(DESTDIR)/usr/share/qubes/mime-override/globs install misc/qubes-download-dom0-updates.sh $(DESTDIR)$(LIBDIR)/qubes/ - install -d $(DESTDIR)/var/lib/qubes/dom0-updates + install -g user -m 2775 -d $(DESTDIR)/var/lib/qubes/dom0-updates if [ -r misc/dispvm-dotfiles.$(DIST).tbz ] ; \ then \ diff --git a/debian/control b/debian/control index 92aae9c..22bcc11 100644 --- a/debian/control +++ b/debian/control @@ -10,7 +10,7 @@ Vcs-Git: git://git.qubes-os.org/marmarek/core-agent-linux.git Package: qubes-core-agent Architecture: any Depends: qubes-utils (>= 2.0.17), libvchan-xen, xenstore-utils, iptables-persistent, xserver-xorg-video-dummy, xen-utils-common, ethtool, python2.7, python-gi, init-system-helpers, xdg-user-dirs, iptables, net-tools, initscripts, imagemagick, fakeroot, systemd, locales, sudo, dmsetup, psmisc, ncurses-term, xserver-xorg-core, x11-xserver-utils, xinit, ${shlibs:Depends}, ${misc:Depends} -Recommends: tinyproxy, gnome-themes-standard, chrony, ntpdate, haveged, network-manager (>= 0.8.1-1), network-manager-gnome, xsettingsd, libnotify-bin, notify-osd, gnome-packagekit, gnome-terminal, python-nautilus, yum +Recommends: tinyproxy, gnome-themes-standard, chrony, ntpdate, haveged, network-manager (>= 0.8.1-1), network-manager-gnome, xsettingsd, libnotify-bin, notify-osd, gnome-packagekit, gnome-terminal, python-nautilus, yum, yum-utils Conflicts: qubes-core-agent-linux, firewalld, qubes-core-vm-sysvinit Description: Qubes core agent This package includes various daemons necessary for qubes domU support, diff --git a/misc/qubes-download-dom0-updates.sh b/misc/qubes-download-dom0-updates.sh index d5dfc97..55fe1b6 100755 --- a/misc/qubes-download-dom0-updates.sh +++ b/misc/qubes-download-dom0-updates.sh @@ -45,6 +45,12 @@ fi mkdir -p $DOM0_UPDATES_DIR/etc sed -i '/^reposdir\s*=/d' $DOM0_UPDATES_DIR/etc/yum.conf +if [ -e /etc/debian_version ]; then + # Default rpm configuration on Debian uses ~/.rpmdb for rpm database (as + # rpm isn't native package manager there) + mkdir -p "$DOM0_UPDATES_DIR$HOME" + ln -nsf "$DOM0_UPDATES_DIR/var/lib/rpm" "$DOM0_UPDATES_DIR$HOME/.rpmdb" +fi # Rebuild rpm database in case of different rpm version rm -f $DOM0_UPDATES_DIR/var/lib/rpm/__* rpm --root=$DOM0_UPDATES_DIR --rebuilddb @@ -85,17 +91,27 @@ if [ "$PKGS_FROM_CMDLINE" == 1 ]; then YUM_ACTION=install fi +YUM_COMMAND="fakeroot yum $YUM_ACTION -y --downloadonly --downloaddir=$DOM0_UPDATES_DIR/packages" +# check for --downloadonly option - if not supported (Debian), fallback to +# yumdownloader +if ! yum --help | grep -q downloadonly; then + if [ "$YUM_ACTION" = "upgrade" ]; then + PKGLIST=$UPDATES + fi + YUM_COMMAND="yumdownloader --destdir=$DOM0_UPDATES_DIR/packages --resolve" +fi + mkdir -p "$DOM0_UPDATES_DIR/packages" set -e if [ "$GUI" = 1 ]; then ( echo "1" - fakeroot yum $YUM_ACTION -y --downloadonly --downloaddir="$DOM0_UPDATES_DIR/packages" $OPTS $PKGLIST + $YUM_COMMAND $OPTS $PKGLIST echo 100 ) | zenity --progress --pulsate --auto-close --auto-kill \ --text="Downloading updates for Dom0, please wait..." --title="Qubes Dom0 updates" else - fakeroot yum $YUM_ACTION -y --downloadonly --downloaddir="$DOM0_UPDATES_DIR/packages" $OPTS $PKGLIST + $YUM_COMMAND $OPTS $PKGLIST fi if ls $DOM0_UPDATES_DIR/packages/*.rpm > /dev/null 2>&1; then