Save extended attributes when creating tar
The way redhat-common's extract-image script was creating the base tarball caused file capabilities to get dropped, which meant that things like ping in RHEL 7 images was unusable for regular users. This change adds the necessary options to the tar call to maintain as many extended attributes as possible. --acls and --selinux are intentionally omitted, and the selinux xattrs are filtered out because all of those items cause issues in our chroot environment. We restore selinux attributes at the end of the build anyway so that shouldn't be a problem. bz reference: https://bugzilla.redhat.com/show_bug.cgi?id=1144149 Change-Id: Ibff99ce9bde01bc5ecf95dc3a5d3e2cebe5015b9
This commit is contained in:
parent
a31bae8f60
commit
edd7477891
1 changed files with 4 additions and 2 deletions
|
@ -73,7 +73,7 @@ function extract_image() {
|
|||
trap "$EACTION" EXIT
|
||||
|
||||
# Chroot in so that we get the correct uid/gid
|
||||
sudo chroot $WORKING/mnt bin/tar -cz . > $WORKING/tmp.tar
|
||||
sudo chroot $WORKING/mnt bin/tar --xattrs --xattrs-include='*' --xattrs-exclude='security.selinux' -cz . > $WORKING/tmp.tar
|
||||
mv $WORKING/tmp.tar $CACHED_TAR
|
||||
else
|
||||
echo "Using cached tar from $CACHED_TAR"
|
||||
|
@ -82,8 +82,10 @@ function extract_image() {
|
|||
|
||||
# Extract the base image (use --numeric-owner to avoid UID/GID mismatch between
|
||||
# image tarball and host OS e.g. when building Fedora image on an openSUSE host)
|
||||
# Include all xattrs except selinux because the selinux ones cause issues in our
|
||||
# chroot environment, and we restore all of those at the end of the build anyway.
|
||||
echo "Extracting base root image from $CACHED_TAR"
|
||||
sudo tar -C $TARGET_ROOT --numeric-owner -xzf $CACHED_TAR
|
||||
sudo tar -C $TARGET_ROOT --numeric-owner --xattrs --xattrs-include='*' --xattrs-exclude='security.selinux' -xzf $CACHED_TAR
|
||||
}
|
||||
|
||||
(
|
||||
|
|
Loading…
Reference in a new issue