virtualbox: Fix extension pack installation.

With hardening, we need to go a bit further rather than just allowing
/nix/store being world-writable. We now use fakeroot to make sure the
VBoxExtPackHelperApp won't moan that the files are not owned by root.

They are, but only outside of the chrooted build process.

Another issue with using fakeroot is that it doesn't seem to cope well
with arguments that contain spaces. That's why I've piped the call into
${stdenv.shell}.

Now, the really gory and confusing part is the introduction of
VBOX_PATH_APP_PRIVATE_ARCH_TOP and the change of VBOX_PATH_APP_PRIVATE.

The VBOX_PATH_APP_PRIVATE_ARCH is *only* for modules and is checked by
the hardened implementation against whether things like VMMR0.r0 or
VBoxVMM.so reside in that directory. As a side note: I admit that the
whole libexec directory is quite polluted with stuff that shouldn't be
there, but for now we've broken enough things and will tear apart the
whole structure at some day in the future[TM].

For the confusing part we have VBOX_PATH_APP_PRIVATE_ARCH_TOP, which
_should_ be the same as VBOX_PATH_APP_PRIVATE_ARCH but unfortunately,
the hardened implementation is checking against this directory (in
IsValidBaseDir) for the extension pack(why!?).

Of course, we could put even that into the libexec directory, somewhat
similar as the official package, but after all, let's at least *try* to
separate things.

Signed-off-by: aszlig <aszlig@redmoonstudios.org>
This commit is contained in:
aszlig 2014-12-01 03:13:51 +01:00
parent 725c55c810
commit 2b58a6ab0d
No known key found for this signature in database
GPG Key ID: D0EBD0EC8C2DC961
1 changed files with 20 additions and 15 deletions

View File

@ -4,7 +4,7 @@
, xorriso, makeself, perl, pkgconfig , xorriso, makeself, perl, pkgconfig
, javaBindings ? false, jdk ? null , javaBindings ? false, jdk ? null
, pythonBindings ? false, python ? null , pythonBindings ? false, python ? null
, enableExtensionPack ? false, requireFile ? null, patchelf ? null , enableExtensionPack ? false, requireFile ? null, patchelf ? null, fakeroot ? null
, pulseSupport ? false, pulseaudio ? null , pulseSupport ? false, pulseaudio ? null
, enableHardening ? true , enableHardening ? true
}: }:
@ -89,20 +89,21 @@ in stdenv.mkDerivation {
configurePhase = '' configurePhase = ''
sourcedir="$(pwd)" sourcedir="$(pwd)"
cat >> LocalConfig.kmk <<LOCAL_CONFIG cat >> LocalConfig.kmk <<LOCAL_CONFIG
VBOX_WITH_TESTCASES := VBOX_WITH_TESTCASES :=
VBOX_WITH_TESTSUITE := VBOX_WITH_TESTSUITE :=
VBOX_WITH_VALIDATIONKIT := VBOX_WITH_VALIDATIONKIT :=
VBOX_WITH_DOCS := VBOX_WITH_DOCS :=
VBOX_WITH_WARNINGS_AS_ERRORS := VBOX_WITH_WARNINGS_AS_ERRORS :=
VBOX_WITH_ORIGIN := VBOX_WITH_ORIGIN :=
VBOX_PATH_APP_PRIVATE_ARCH := $out/libexec/virtualbox VBOX_PATH_APP_PRIVATE_ARCH_TOP := $out/share/virtualbox
VBOX_PATH_SHARED_LIBS := $out/libexec/virtualbox VBOX_PATH_APP_PRIVATE_ARCH := $out/libexec/virtualbox
VBOX_WITH_RUNPATH := $out/libexec/virtualbox VBOX_PATH_SHARED_LIBS := $out/libexec/virtualbox
VBOX_PATH_APP_PRIVATE := $out VBOX_WITH_RUNPATH := $out/libexec/virtualbox
VBOX_PATH_APP_DOCS := $out/doc VBOX_PATH_APP_PRIVATE := $out/share/virtualbox
VBOX_PATH_APP_DOCS := $out/doc
${optionalString javaBindings '' ${optionalString javaBindings ''
VBOX_JAVA_HOME := ${jdk} VBOX_JAVA_HOME := ${jdk}
''} ''}
LOCAL_CONFIG LOCAL_CONFIG
@ -129,6 +130,7 @@ in stdenv.mkDerivation {
installPhase = '' installPhase = ''
libexec=$out/libexec/virtualbox libexec=$out/libexec/virtualbox
share=$out/share/virtualbox
# Install VirtualBox files # Install VirtualBox files
cd out/linux.*/release/bin cd out/linux.*/release/bin
@ -145,12 +147,15 @@ in stdenv.mkDerivation {
done done
${optionalString enableExtensionPack '' ${optionalString enableExtensionPack ''
mkdir -p "$share"
"${fakeroot}/bin/fakeroot" "${stdenv.shell}" <<EXTHELPER
"$libexec/VBoxExtPackHelperApp" install \ "$libexec/VBoxExtPackHelperApp" install \
--base-dir "$libexec/ExtensionPacks" \ --base-dir "$share/ExtensionPacks" \
--cert-dir "$libexec/ExtPackCertificates" \ --cert-dir "$share/ExtPackCertificates" \
--name "Oracle VM VirtualBox Extension Pack" \ --name "Oracle VM VirtualBox Extension Pack" \
--tarball "${extensionPack}" \ --tarball "${extensionPack}" \
--sha-256 "${extensionPack.outputHash}" --sha-256 "${extensionPack.outputHash}"
EXTHELPER
''} ''}
# Create and fix desktop item # Create and fix desktop item