03d22f2
#!/bin/bash
03d22f2
03d22f2
DISTGIT_PATH=$(pwd)
03d22f2
500e8e6
FEDORA_VERSION=f29
b040fbf
DOCKER_FEDORA_VERSION=master
bbfe54b
DISTGIT_BRANCH=f29
e43270a
REPO_SELINUX_POLICY=${REPO_SELINUX_POLICY:-https://github.com/fedora-selinux/selinux-policy}
b719841
REPO_SELINUX_POLICY_BRANCH=${REPO_SELINUX_POLICY_BRANCH:-$FEDORA_VERSION}
e43270a
REPO_SELINUX_POLICY_CONTRIB=${REPO_SELINUX_POLICY_CONTRIB:-https://github.com/fedora-selinux/selinux-policy-contrib}
b719841
REPO_SELINUX_POLICY_CONTRIB_BRANCH=${REPO_SELINUX_POLICY_CONTRIB_BRANCH:-$FEDORA_VERSION}
e43270a
REPO_CONTAINER_SELINUX=${REPO_CONTAINER_SELINUX:-https://github.com/containers/container-selinux}
b719841
b719841
# When -l is specified, we use locally created tarballs and don't download them from github
b719841
DOWNLOAD_DEFAULT_GITHUB_TARBALLS=1
b719841
if [ "$1" == "-l" ]; then
b719841
    DOWNLOAD_DEFAULT_GITHUB_TARBALLS=0
b719841
fi
03d22f2
03d22f2
git checkout $DISTGIT_BRANCH -q
03d22f2
03d22f2
POLICYSOURCES=`mktemp -d policysources.XXXXXX`
03d22f2
pushd $POLICYSOURCES > /dev/null
03d22f2
b719841
git clone -q $REPO_SELINUX_POLICY selinux-policy
b719841
git clone -q $REPO_SELINUX_POLICY_CONTRIB selinux-policy-contrib
b719841
git clone -q $REPO_CONTAINER_SELINUX container-selinux
03d22f2
03d22f2
pushd selinux-policy > /dev/null
856e200
# prepare policy patches against upstream commits matching the last upstream merge
b719841
git checkout $REPO_SELINUX_POLICY_BRANCH
51dc83b
BASE_HEAD_ID=$(git rev-parse HEAD)
51dc83b
BASE_SHORT_HEAD_ID=$(c=${BASE_HEAD_ID}; echo ${c:0:7})
b719841
git archive --prefix=selinux-policy-$BASE_HEAD_ID/ --format tgz HEAD > $DISTGIT_PATH/selinux-policy-$BASE_SHORT_HEAD_ID.tar.gz
47948f5
popd > /dev/null
47948f5
47948f5
pushd selinux-policy-contrib > /dev/null
47948f5
# prepare policy patches against upstream commits matching the last upstream merge
b719841
git checkout $REPO_SELINUX_POLICY_CONTRIB_BRANCH
51dc83b
CONTRIB_HEAD_ID=$(git rev-parse HEAD)
51dc83b
CONTRIB_SHORT_HEAD_ID=$(c=${CONTRIB_HEAD_ID}; echo ${c:0:7})
b719841
git archive --prefix=selinux-policy-contrib-$CONTRIB_HEAD_ID/ --format tgz HEAD > $DISTGIT_PATH/selinux-policy-contrib-$CONTRIB_SHORT_HEAD_ID.tar.gz
03d22f2
popd > /dev/null
03d22f2
ab3db24
pushd container-selinux > /dev/null
ab3db24
# Actual container-selinux files are in master branch
d932255
#git checkout -b ${DOCKER_FEDORA_VERSION} -t origin/${DOCKER_FEDORA_VERSION} -q
ab3db24
tar -czf container-selinux.tgz container.if container.te container.fc
03d22f2
popd > /dev/null
03d22f2
03d22f2
pushd $DISTGIT_PATH > /dev/null
b719841
if [ $DOWNLOAD_DEFAULT_GITHUB_TARBALLS == 1 ]; then
2b7b0bb
    wget -O selinux-policy-${BASE_SHORT_HEAD_ID}.tar.gz https://github.com/fedora-selinux/selinux-policy/archive/${BASE_HEAD_ID}.tar.gz &> /dev/null
2b7b0bb
    wget -O selinux-policy-contrib-${CONTRIB_SHORT_HEAD_ID}.tar.gz https://github.com/fedora-selinux/selinux-policy-contrib/archive/${CONTRIB_HEAD_ID}.tar.gz &> /dev/null
b719841
fi
ab3db24
cp $POLICYSOURCES/container-selinux/container-selinux.tgz .
03d22f2
popd > /dev/null
03d22f2
03d22f2
popd > /dev/null
03d22f2
rm -rf $POLICYSOURCES
03d22f2
b719841
# Update commit ids in selinux-policy.spec file
b719841
sed -i "s/%global commit0 [^ ]*$/%global commit0 $BASE_HEAD_ID/" selinux-policy.spec
b719841
sed -i "s/%global commit1 [^ ]*$/%global commit1 $CONTRIB_HEAD_ID/" selinux-policy.spec
b719841
b719841
# Update sources
b719841
sha512sum --tag selinux-policy-${BASE_SHORT_HEAD_ID}.tar.gz selinux-policy-contrib-${CONTRIB_SHORT_HEAD_ID}.tar.gz container-selinux.tgz > sources
b719841
51dc83b
echo -e "\nSELinux policy tarballs  and container.tgz with container policy files have been created."
b719841
echo "Commit ids of selinux-policy and selinux-policy-contrib in spec file were changed to:"
51dc83b
echo "commit0 " ${BASE_HEAD_ID}
51dc83b
echo "commit1 " ${CONTRIB_HEAD_ID}