#!/bin/sh # # roll.sh : build a release tarball # # USAGE: roll.sh SOURCE [SIGNING-USER] # # The "signing user" is the name of the key that you'll be signing the # release with. # # Run tests to ensure that our requirements are met RELEASECHECK="`echo $0 | sed 's/roll.sh$/releasecheck.sh/'`" ${RELEASECHECK} || exit 1 dirname="$1" user="$2" separate_deps="$3" if test "$#" != 1 && test "$#" != 2 && test "$#" != 3; then echo "USAGE: $0 SOURCE [SIGNING-USER] [separate_dependencies]" >&2 echo " see the comments in this script for more info." >&2 exit 1 fi split="---------------------------------------------------------------------" echo $split echo "" # make sure that the perms are good for the tarball umask 022 echo "Eliminating unwanted files (e.g. .cvsignore) and generating initial" echo "files via buildconf ..." echo "" find $dirname -name autom4te*.cache | xargs rm -rf find $dirname -name STATUS | xargs rm -rf (cd ${dirname} && ./buildconf) || exit 1 find $dirname -name autom4te*.cache | xargs rm -rf echo "" echo "Fixup the timestamps preventing remake of generated files." if test -f "${dirname}/modules/ssl/ssl_expr_parse.y"; then echo "Found ssl expression parser" touch $dirname/modules/ssl/ssl_expr_parse.c touch $dirname/modules/ssl/ssl_expr_parse.h touch $dirname/modules/ssl/ssl_expr_scan.c elif test -f "${dirname}/server/util_expr_parse.y"; then echo "Found generic expression parser" touch $dirname/server/util_expr_parse.c touch $dirname/server/util_expr_parse.h touch $dirname/server/util_expr_scan.c else echo "Found no expression parser!" fi echo "" echo $split echo "" echo "Removing Manual Source Files." echo "" find $dirname/docs/manual -name \*.xml -o -name \*.xml.\* | xargs rm -rf find $dirname/docs/manual -name \*.xsl -o -name \*.xsl.\* | xargs rm -rf if test "${separate_deps}" = 1; then echo $split echo "" echo "Moving dependencies to their own tarball, .gz, and .bz2 files ..." echo "" depsdir="${dirname}-deps/${dirname}" mkdir -p ${depsdir}/srclib mv "${dirname}/srclib/apr" "${depsdir}/srclib" mv "${dirname}/srclib/apr-util" "${depsdir}/srclib" tar -C "${dirname}-deps" -cf ${dirname}-deps.tar ${dirname} gzip -9 --to-stdout ${dirname}-deps.tar > ${dirname}-deps.tar.gz bzip2 -9 ${dirname}-deps.tar fi echo $split echo "" echo "Building the tarball, .gz, and .bz2 files ..." echo "" tar cf ${dirname}.tar ${dirname} gzip -9 --to-stdout ${dirname}.tar > ${dirname}.tar.gz bzip2 -9 ${dirname}.tar echo $split echo "" echo "Generating MD5/SHA1 checksum files ..." echo "" # check for executables gpg2="`which gpg2 2> /dev/null | head -1`" gpg="`which gpg 2> /dev/null | head -1`" pgp="`which pgp 2> /dev/null | head -1`" openssl="`which openssl 2> /dev/null | head -1`" md5sum="`which md5sum 2> /dev/null | head -1`" sha1sum="`which sha1sum 2> /dev/null | head -1`" md5="`which md5 2> /dev/null | head -1`" sha1="`which sha1 2> /dev/null | head -1`" set -- ${dirname}.tar.gz ${dirname}.tar.bz2 ${dirname}-deps.tar.gz ${dirname}-deps.tar.bz2 # if found we use openssl for generating the checksums # and convert the results into machine-readable format. if test -x "${openssl}"; then for file; do if test -f "${file}"; then echo "openssl: creating md5 checksum file for ${file} ..." ${openssl} md5 ${file} |\ sed -e 's#^MD5(\(.*\))= \([0-9a-f]*\)$#\2 *\1#' > ${file}.md5 echo "openssl: creating sha1 checksum file for ${file} ..." ${openssl} sha1 ${file} |\ sed -e 's#^SHA1(\(.*\))= \([0-9a-f]*\)$#\2 *\1#' > ${file}.sha1 fi done # no openssl found - check if we have gpg2 elif test -x "${gpg2}"; then for file; do if test -f "${file}"; then echo "gpg2: creating md5 checksum file for ${file} ..." ${gpg2} --print-md md5 ${file} |\ sed -e '{N;s#\n##;}' |\ sed -e 's#\(.*\): \(.*\)#\2::\1#;s#[\r\n]##g;s# ##g' \ -e 'y#ABCDEF#abcdef#;s#::# *#' > ${file}.md5 echo "gpg2: creating sha1 checksum file for ${file} ..." ${gpg} --print-md sha1 ${file} |\ sed -e '{N;s#\n##;}' |\ sed -e 's#\(.*\): \(.*\)#\2::\1#;s#[\r\n]##g;s# ##g' \ -e 'y#ABCDEF#abcdef#;s#::# *#' > ${file}.sha1 fi done # no gpg2 found - check if we have gpg elif test -x "${gpg}"; then for file; do if test -f "${file}"; then echo "gpg: creating md5 checksum file for ${file} ..." ${gpg} --print-md md5 ${file} |\ sed -e '{N;s#\n##;}' |\ sed -e 's#\(.*\): \(.*\)#\2::\1#;s#[\r\n]##g;s# ##g' \ -e 'y#ABCDEF#abcdef#;s#::# *#' > ${file}.md5 echo "gpg: creating sha1 checksum file for ${file} ..." ${gpg} --print-md sha1 ${file} |\ sed -e '{N;s#\n##;}' |\ sed -e 's#\(.*\): \(.*\)#\2::\1#;s#[\r\n]##g;s# ##g' \ -e 'y#ABCDEF#abcdef#;s#::# *#' > ${file}.sha1 fi done else # no openssl or gpg found - check for md5sum if test -x "${md5sum}"; then for file; do if test -f "${file}"; then echo "md5sum: creating md5 checksum file for ${file} ..." ${md5sum} -b ${file} > ${file}.md5 fi done # no openssl or gpg found - check for md5 elif test -x "${md5}"; then for file; do if test -f "${file}"; then echo "md5: creating md5 checksum file for ${file} ..." ${md5} -r ${file} | sed -e 's# # *#' > ${file}.md5 fi done fi # no openssl or gpg found - check for sha1sum if test -x "${sha1sum}"; then for file; do if test -f "${file}"; then echo "sha1sum: creating sha1 checksum file for ${file} ..." ${sha1sum} -b ${file} > ${file}.sha1 fi done # no openssl or gpg found - check for sha1 elif test -x "${sha1}"; then for file; do if test -f "${file}"; then echo "sha1: creating sha1 checksum file for ${file} ..." ${sha1} -r ${file} | sed -e 's# # *#' > ${file}.sha1 fi done fi fi echo $split echo "" echo "Cleaning up and signing the files ..." echo "" # First look for gpg2 if test -x "${gpg2}"; then if test -z "${user}"; then args="--default-key ${args}" else args="-u ${user} ${args}" fi for file; do if test -f "${file}"; then echo "gpg2: creating asc signature file for ${file} ..." ${gpg2} --armor ${args} --detach-sign ${file} fi done # no gpg2 found - check for gpg elif test -x "${gpg}"; then if test -z "${user}"; then args="--default-key ${args}" else args="-u ${user} ${args}" fi for file; do if test -f "${file}"; then echo "gpg: creating asc signature file for ${file} ..." ${gpg} --armor ${args} --detach-sign ${file} fi done # ... no GnuPG? Try PGP elif test -x "${pgp}"; then if test -n "${user}"; then args="-u ${user}" fi for file; do if test -f "${file}"; then echo "pgp: creating asc signature file for ${file} ..." ${pgp} -sba ${file} ${args} fi done # no pgp found - check for gpg else echo "PGP or GnuPG not found! Not signing release!" fi