Sync amd64 and x86 base and experimental scripts. Add a few missing popd calls to base scripts.

Signed-off-by: Jorge Manuel B. S. Vicetto (jmbsvicetto) <jmbsvicetto@gentoo.org>
This commit is contained in:
Jorge Manuel B. S. Vicetto (jmbsvicetto) 2017-12-27 01:54:39 -01:00
parent 0c3d971bfb
commit 93bc214182
4 changed files with 93 additions and 39 deletions

View file

@ -10,23 +10,27 @@ source /etc/catalyst/release/build.env
SPECS_DIR=${REPO_DIR}/releases/weekly/specs/${ARCH} SPECS_DIR=${REPO_DIR}/releases/weekly/specs/${ARCH}
SETS=" SETS="
multilib multilib minimal_multilib
nomultilib nomultilib minimal_nomultilib
x32 x32
hardened_multilib hardened_multilib minimal_hardened_multilib
hardened_nomultilib hardened_nomultilib minimal_hardened_nomultilib
hardened_multilib_selinux hardened_nomultilib_selinux hardened_multilib_selinux hardened_nomultilib_selinux
" "
SET_multilib_SPECS="stage1.spec stage2.spec stage3.spec" SET_multilib_SPECS="stage1.spec stage2.spec stage3.spec"
SET_multilib_OPTIONAL_SPECS="installcd-stage1.spec installcd-stage2-minimal.spec" SET_multilib_OPTIONAL_SPECS="installcd-stage1.spec installcd-stage2-minimal.spec"
SET_minimal_multilib_OPTIONAL_SPECS="stage4-minimal.spec"
SET_nomultilib_SPECS="stage1-nomultilib.spec stage2-nomultilib.spec stage3-nomultilib.spec" SET_nomultilib_SPECS="stage1-nomultilib.spec stage2-nomultilib.spec stage3-nomultilib.spec"
SET_minimal_nomultilib_OPTIONAL_SPECS="stage4-nomultilib-minimal.spec"
SET_x32_SPECS="stage1-x32.spec stage2-x32.spec stage3-x32.spec" SET_x32_SPECS="stage1-x32.spec stage2-x32.spec stage3-x32.spec"
SET_hardened_multilib_SPECS="hardened/stage1.spec hardened/stage2.spec hardened/stage3.spec" SET_hardened_multilib_SPECS="hardened/stage1.spec hardened/stage2.spec hardened/stage3.spec"
SET_hardened_multilib_OPTIONAL_SPECS="hardened/admincd-stage1.spec hardened/admincd-stage2.spec" SET_hardened_multilib_OPTIONAL_SPECS="hardened/admincd-stage1.spec hardened/admincd-stage2.spec"
SET_minimal_hardened_multilib_OPTIONAL_SPECS="hardened/stage4-minimal.spec"
SET_hardened_nomultilib_SPECS="hardened/stage1-nomultilib.spec hardened/stage2-nomultilib.spec hardened/stage3-nomultilib.spec" SET_hardened_nomultilib_SPECS="hardened/stage1-nomultilib.spec hardened/stage2-nomultilib.spec hardened/stage3-nomultilib.spec"
SET_minimal_hardened_nomultilib_OPTIONAL_SPECS="hardened/stage4-nomultilib-minimal.spec"
SET_hardened_multilib_selinux_SPECS="hardened/stage1-selinux.spec hardened/stage2-selinux.spec hardened/stage3-selinux.spec" SET_hardened_multilib_selinux_SPECS="hardened/stage1-selinux.spec hardened/stage2-selinux.spec hardened/stage3-selinux.spec"
SET_hardened_multilib_selinux_OPTIONAL_SPECS="hardened/admincd-stage1-selinux.spec hardened/admincd-stage2-selinux.spec" SET_hardened_multilib_selinux_OPTIONAL_SPECS="hardened/admincd-stage1-selinux.spec hardened/admincd-stage2-selinux.spec"
@ -38,7 +42,7 @@ EXTENSIONS="[.tar.xz,.tar.bz2,.tar.gz,.tar,.sfs]"
give_latest_from_dates() { give_latest_from_dates() {
sed 's,-20,~20,g' | \ sed 's,-20,~20,g' | \
sort -k +1 -n -t '~' |\ sort -k +1 -n -t '~' | \
awk -F\~ \ awk -F\~ \
'BEGIN{i=$1; o=$0}; 'BEGIN{i=$1; o=$0};
{ if($1 != i && i != "") { print o; }; i=$1; o=$0; } { if($1 != i && i != "") { print o; }; i=$1; o=$0; }
@ -46,51 +50,80 @@ give_latest_from_dates() {
tr '~' '-' tr '~' '-'
} }
pre_build() { update_symlinks() {
pushd ${REPO_DIR} >/dev/null
git pull
popd >/dev/null
# Symlink the latest stages3 to build from # Symlink the latest stages3 to build from
for d in ${BUILD_SRCDIR_BASE}/{default,hardened} ; do for d in ${BUILD_SRCDIR_BASE}/{default,hardened} ; do
pushd $d >/dev/null pushd $d >/dev/null
for f in $(ls stage3*${EXTENSIONS} | grep -v latest | give_latest_from_dates ) ; do for f in $(ls stage3*${EXTENSIONS} | grep -v latest | give_latest_from_dates ) ; do
of=${f/20[0-9][0-9].[0-9]/latest} # for 20XX.Y stuff # 20yymmddThhmmssZ
of=${of/20[0-9][0-9][0-1][0-9][0-9][0-9]/latest} # for 20YYMMDD stuff # 20yymmddhhmmss
ln -sf $f $of # 20yymmdd
# 20yy.n
of=$(perl -p \
-e 's/20\d{6}T\d{6}Z/latest/g;' \
-e 's/20\d{6}\d{6}/latest/g;' \
-e 's/20\d{6}/latest/g;' \
-e 's/20\d{2}\.\d{2}/latest/g;' \
<<<"$f")
ln -svf "$f" "$of"
done done
popd >/dev/null popd >/dev/null
done done
} }
post_build() { pre_build() {
pushd ${BUILD_SRCDIR_BASE}/default >/dev/null pushd ${REPO_DIR} >/dev/null
git pull
popd >/dev/null
update_symlinks
}
mkdir -p ${BUILD_DESTDIR_BASE}/default/${DATESTAMP} post_build() {
for file in $(ls stage{3,4}*${DATESTAMP}*${EXTENSIONS} ); do cmd=(
rsync
-e 'ssh -i /root/.ssh/id_rsa'
-a
--omit-dir-times
--delay-updates
)
case $HOSTNAME in
nightheron)
DEST_DEFAULT=${BUILD_DESTDIR_BASE}
DEST_HARDENED=${BUILD_DESTDIR_BASE}/hardened
;;
*)
DEST_DEFAULT=${ARCH}@nightheron.gentoo.org:${BUILD_DESTDIR_BASE}
DEST_HARDENED=${ARCH}@nightheron.gentoo.org:${BUILD_DESTDIR_BASE}/hardened
;;
esac
pushd ${BUILD_SRCDIR_BASE}/default >/dev/null
mkdir -p ${TMPDIR}/empty
"${cmd[@]}" ${TMPDIR}/empty ${DEST_DEFAULT}
for file in $(ls stage{3,4}*${DATESTAMP}*${EXTENSIONS} stage{3,4}*${TIMESTAMP}*${EXTENSIONS} ); do
if [ -f $file ]; then if [ -f $file ]; then
cp $file* ${BUILD_DESTDIR_BASE}/default/${DATESTAMP} "${cmd[@]}" ${file}* ${DEST_DEFAULT}
fi fi
done done
if [ -f *${DATESTAMP}*.iso ]; then if [ -f *${DATESTAMP}*.iso ]; then
cp *${DATESTAMP}*.iso* ${BUILD_DESTDIR_BASE}/${TYPE}/${ARCH}/default/${DATESTAMP} "${cmd[@]}" *${DATESTAMP}*.iso* ${DEST_DEFAULT}
elif [ -f *${TIMESTAMP}*.iso ]; then
"${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_DEFAULT}
fi fi
popd >/dev/null popd >/dev/null
pushd ${BUILD_SRCDIR_BASE}/hardened >/dev/null pushd ${BUILD_SRCDIR_BASE}/hardened >/dev/null
"${cmd[@]}" ${TMPDIR}/empty ${DEST_HARDENED}
mkdir -p ${BUILD_DESTDIR_BASE}/hardened/${DATESTAMP} for file in $(ls stage{3,4}*${DATESTAMP}*${EXTENSIONS} stage{3,4}*${TIMESTAMP}*${EXTENSIONS} ); do
for file in $(ls stage{3,4}*${DATESTAMP}*${EXTENSIONS} ); do
if [ -f $file ]; then if [ -f $file ]; then
cp $file* ${BUILD_DESTDIR_BASE}/hardened/${DATESTAMP} "${cmd[@]}" $file* ${DEST_HARDENED}
fi fi
done done
if [ -f *${DATESTAMP}*.iso ]; then if [ -f *${DATESTAMP}*.iso ]; then
cp *${DATESTAMP}*.iso* ${BUILD_DESTDIR_BASE}/hardened/${DATESTAMP} "${cmd[@]}" *${DATESTAMP}*.iso* ${DEST_HARDENED}
elif [ -f *${TIMESTAMP}*.iso ]; then
"${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_HARDENED}
fi fi
popd >/dev/null
} }
# vim:ft=sh: # vim:ft=sh:

View file

@ -127,6 +127,7 @@ post_build() {
elif [ -f *${TIMESTAMP}*.iso ]; then elif [ -f *${TIMESTAMP}*.iso ]; then
"${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_HARDENED} "${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_HARDENED}
fi fi
popd >/dev/null
} }
# vim:ft=sh: # vim:ft=sh:

View file

@ -55,32 +55,51 @@ pre_build() {
} }
post_build() { post_build() {
cmd=(
rsync
-e 'ssh -i /root/.ssh/id_rsa'
-a
--omit-dir-times
--delay-updates
)
case $HOSTNAME in
nightheron)
DEST_DEFAULT=${BUILD_DESTDIR_BASE}
DEST_HARDENED=${BUILD_DESTDIR_BASE}/hardened
;;
*)
DEST_DEFAULT=${ARCH}@nightheron.gentoo.org:${BUILD_DESTDIR_BASE}
DEST_HARDENED=${ARCH}@nightheron.gentoo.org:${BUILD_DESTDIR_BASE}/hardened
;;
esac
pushd ${BUILD_SRCDIR_BASE}/default >/dev/null pushd ${BUILD_SRCDIR_BASE}/default >/dev/null
mkdir -p ${TMPDIR}/empty
mkdir -p ${BUILD_DESTDIR_BASE}/default/${DATESTAMP} "${cmd[@]}" ${TMPDIR}/empty ${DEST_DEFAULT}
for file in $(ls stage{3,4}*${DATESTAMP}*${EXTENSIONS} ); do for file in $(ls stage{3,4}*{${DATESTAMP},${TIMESTAMP}}*${EXTENSIONS} ); do
if [ -f $file ]; then if [ -f $file ]; then
cp $file* ${BUILD_DESTDIR_BASE}/default/${DATESTAMP} "${cmd[@]}" ${file}* ${DEST_DEFAULT}
fi fi
done done
if [ -f *${DATESTAMP}*.iso ]; then if [ -f *${DATESTAMP}*.iso ]; then
cp *${DATESTAMP}*.iso* ${BUILD_DESTDIR_BASE}/default/${DATESTAMP} "${cmd[@]}" *${DATESTAMP}*.iso* ${DEST_DEFAULT}
elif [ -f *${TIMESTAMP}*.iso ]; then
"${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_DEFAULT}
fi fi
popd >/dev/null popd >/dev/null
pushd ${BUILD_SRCDIR_BASE}/hardened >/dev/null pushd ${BUILD_SRCDIR_BASE}/hardened >/dev/null
"${cmd[@]}" ${TMPDIR}/empty ${DEST_HARDENED}
mkdir -p ${BUILD_DESTDIR_BASE}/hardened/${DATESTAMP} for file in $(ls stage{3,4}*{${DATESTAMP},${TIMESTAMP}}*${EXTENSIONS} ); do
for file in $(ls stage{3,4}*${DATESTAMP}*${EXTENSIONS} ); do
if [ -f $file ]; then if [ -f $file ]; then
cp $file* ${BUILD_DESTDIR_BASE}/hardened/${DATESTAMP} "${cmd[@]}" $file* ${DEST_HARDENED}
fi fi
done done
if [ -f *${DATESTAMP}*.iso ]; then if [ -f *${DATESTAMP}*.iso ]; then
cp *${DATESTAMP}*.iso* ${BUILD_DESTDIR_BASE}/hardened/${DATESTAMP} "${cmd[@]}" *${DATESTAMP}*.iso* ${DEST_HARDEND}
elif [ -f *${TIMESTAMP}*.iso ]; then
"${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_HARDENED}
fi fi
popd >/dev/null
} }
# vim:ft=sh: # vim:ft=sh:

View file

@ -99,6 +99,7 @@ post_build() {
elif [ -f *${TIMESTAMP}*.iso ]; then elif [ -f *${TIMESTAMP}*.iso ]; then
"${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_HARDENED} "${cmd[@]}" *${TIMESTAMP}*.iso* ${DEST_HARDENED}
fi fi
popd >/dev/null
} }
# vim:ft=sh: # vim:ft=sh: