makedist-annoucement: changes to support devel (snapshot) media and email testing support

This commit is contained in:
Silvan Calarco 2012-07-23 13:12:24 +02:00
parent 3069b88a8f
commit ea464fb47e
3 changed files with 179 additions and 150 deletions

View File

@ -48,16 +48,18 @@ if [ "$mediumname" ]; then
done
fi
echo $"Generating $distversion announcements index"
for outputlang in $outputlangs; do
indexfile=/var/ftp/pub/$distribution/media/$distversion/release-announcement-index.$outputlang.html.inc
> $indexfile
for i in `seq 0 ${#MEDIA_NAME[*]}`; do
mediumdir=/var/ftp/pub/$distribution/media/$distversion/${MEDIA_NAME[i]}
for f in $mediumdir/info/release-announcement-*.$outputlang.html; do
[ -r $f ] || continue
version=`echo $f | sed "s|.*/release-announcement-\(.*\)\.$outputlang.html|\1|"`
echo "<a href='?distrelease=${distversion}&medium=${MEDIA_NAME[i]}&version=${version}&lang=${outputlang}'>${MEDIA_NAME[i]} ${version}</a><br>" >> $indexfile
if [ ! "$SENDEMAIL" -a ! "$SENDTESTEMAIL" ]; then
echo $"Generating $distversion announcements index"
for outputlang in $outputlangs; do
indexfile=/var/ftp/pub/$distribution/media/$distversion/release-announcement-index.$outputlang.html.inc
> $indexfile
for i in `seq 0 ${#MEDIA_NAME[*]}`; do
mediumdir=/var/ftp/pub/$distribution/media/$distversion/${MEDIA_NAME[i]}
for f in $mediumdir/info/release-announcement-*.$outputlang.html; do
[ -r $f ] || continue
version=`echo $f | sed "s|.*/release-announcement-\(.*\)\.$outputlang.html|\1|"`
echo "<a href='?distrelease=${distversion}&medium=${MEDIA_NAME[i]}&version=${version}&lang=${outputlang}'>${MEDIA_NAME[i]} ${version}</a><br>" >> $indexfile
done
done
done
done
fi

View File

@ -44,10 +44,14 @@ if [ "$distversion" != "devel" ]; then
DISTVERSION=$distversion
MAKEDIST_TARGET=$distribution-$distversion
buildinfourl=/var/ftp/pub/$distribution/distromatic/${distversion}-updates
pkginforep=$distversion-makedist
mediadistversion=$distversion
else
RELEASE=
MAKEDIST_TARGET=$distribution
buildinfourl=/var/ftp/pub/$distribution/distromatic/devel-makedist
pkginforep=$distversion-makedist
mediadistversion=snapshot
fi
. /etc/sysconfig/makedist
@ -200,6 +204,21 @@ function print_group() {
done
}
print_include_section() {
local incfile=$1
local title=$2
local f destincfile
for f in $mediumdir/info/$incfile $fallbackmediumdir/info/$incfile; do
[ -r $f ] && destincfile=$f
done
if [ "$destincfile" ]; then
echo "<h3>$title</h3>" >> $outputfile
cat $destincfile >> $outputfile
fi
}
for i in `seq 0 ${#MEDIA_NAME[*]}`; do
[ "$mediumname" = "${MEDIA_NAME[i]}" ] && break;
done
@ -212,9 +231,8 @@ fi
mediumplatform=${MEDIA_PLATFORM[i]}
mediumsubplatform=${MEDIA_SUBPLATFORM[i]}
echo $"Generating announcement for"" $distribution $distversion ${MEDIA_NAME[i]}"" ($outputlang)"
mediumdir=/var/ftp/pub/$distribution/media/$distversion/${MEDIA_NAME[i]}
[ "$distversion" = "devel" ] && fallbackmediumdir=/var/ftp/pub/$distribution/media/milestone2/${MEDIA_NAME[i]}
if [ $mediumsubplatform ]; then
. /var/makedist/targets/$MAKEDIST_TARGET/platforms/$mediumsubplatform/settings.inc
@ -234,11 +252,11 @@ else
sub_medium_name=${medium_name}
fi
[ -e /var/makedist/.$medium_name-$mediumlang.$mediumarch.$sub_medium_suffix.distinfo ] || {
echo "Error: missing distinfo file /var/makedist/.$medium_name-$mediumlang.$mediumarch.$sub_medium_suffix.distinfo; aborting."
[ -e /var/makedist/.$sub_medium_name-$mediumlang.$mediumarch.$sub_medium_suffix.distinfo ] || {
echo "Error: missing distinfo file /var/makedist/.$sub_medium_name-$mediumlang.$mediumarch.$sub_medium_suffix.distinfo; aborting."
exit 1
}
. /var/makedist/.$medium_name-$mediumlang.$mediumarch.$sub_medium_suffix.distinfo
. /var/makedist/.$sub_medium_name-$mediumlang.$mediumarch.$sub_medium_suffix.distinfo
CONFIGFILE=/etc/makedist/config
. $CONFIGFILE
@ -248,13 +266,16 @@ CONFIGFILE=/etc/makedist/config
[ -e $mediumdir/info ] || mkdir $mediumdir/info
catalogfile=$mediumdir/info/sources.catalog
[ -e $catalogfile ] || for i in $SOURCES; do
get_pkg_buildinfo /var/ftp/pub/openmamba/distromatic/milestone2-makedist/ $mediumarch $i
echo $pkg_name $pkg_version $pkg_group ${pkg_builds[*]} >> $catalogfile
done
if [ ! -e $catalogfile -o "$REBUILDCATALOG" = "1" ]; then
echo $"Generating catalog file $catalogfile"
for s in $SOURCES; do
get_pkg_buildinfo /var/ftp/pub/openmamba/distromatic/$pkginforep/ $mediumarch $s
echo $pkg_name $pkg_version $pkg_group ${pkg_builds[*]} >> $catalogfile
done
fi
#for i in $SOURCES; do
# get_pkg_buildinfo /var/ftp/pub/openmamba/distromatic/milestone2-makedist/ i586 $i
# get_pkg_buildinfo /var/ftp/pub/openmamba/distromatic/$pkginforep/ i586 $i
# if [ "$pkg_name" ]; then
# echo $pkg_name $pkg_version $pkg_release $pkg_group
# else
@ -262,190 +283,193 @@ done
# fi
#done
version=`ls $mediumdir/en/latest-is-$distversion-*.txt 2>/dev/null| sed "s/.*latest-is-$distversion-\(.*\)\.txt/\1/"`
if [ "$distversion" = "devel" ]; then
version=`ls $mediumdir/en/latest-is-*.txt 2>/dev/null| sed "s/.*latest-is-\(.*\)\.txt/\1/"`
else
version=`ls $mediumdir/en/latest-is-$distversion-*.txt 2>/dev/null| sed "s/.*latest-is-$distversion-\(.*\)\.txt/\1/"`
fi
outputfile=$mediumdir/info/release-announcement-$version.$outputlang.html
echo "<h2>"$"$distribution $distversion ${MEDIA_NAME[i]} $version release announcement""</h2>" > $outputfile
echo "<div align=right><i><a href="http://$siteaddress">$sitedomain</a> - $announcementdate</i></div>" >> $outputfile
echo "<br><p>"$"The $distribution maintainer is happy to announce the immediate availability of the <b>$distversion $version</b> release of the $distribution <b>${MEDIA_NAME[i]}</b> distribution." >> $outputfile
[ -e $mediumdir/info/release-notes.$outputlang.html.inc ] && {
echo "<h3>"$"Release notes""</h3>" >> $outputfile
cat $mediumdir/info/release-notes.$outputlang.html.inc >> $outputfile
}
if [ ! -e $outputfile -o "$REBUILDACCOUNCEMENT" = "1" ]; then
echo $"Generating announcement for"" $distribution $distversion ${MEDIA_NAME[i]}"" ($outputlang)"
echo "<h3>"$"Description""</h3>" >> $outputfile
echo "<h2>"$"$distribution $distversion ${MEDIA_NAME[i]} $version release announcement""</h2>" > $outputfile
echo "<div align=right><i><a href="http://$siteaddress">$sitedomain</a> - $announcementdate</i></div>" >> $outputfile
echo "<br><p>"$"The $distribution maintainer is happy to announce the immediate availability of the <b>$distversion $version</b> release of the $distribution <b>${MEDIA_NAME[i]}</b> distribution." >> $outputfile
[ -e $mediumdir/info/release-notes.$outputlang.html.inc ] && {
echo "<h3>"$"Release notes""</h3>" >> $outputfile
cat $mediumdir/info/release-notes.$outputlang.html.inc >> $outputfile
}
print_include_section description.$outputlang.html.inc $"Description"
# [ -e $mediumdir/$outputlang/preview/preview.jpg ] && \
# echo "<img src='http://$siteaddress/pub/$distribution/media/$distversion/${MEDIA_NAME[i]}/$outputlang/preview/preview.jpg'>" >> $outputfile
cat $mediumdir/info/description.$outputlang.html.inc >> $outputfile
print_include_section target.$outputlang.html.inc $"Who it's for"
if [ -e $mediumdir/info/target.$outputlang.html.inc ]; then
echo "<h3>"$"Who is it for""</h3>" >> $outputfile
cat $mediumdir/info/target.$outputlang.html.inc >> $outputfile
fi
print_include_section requirements.$outputlang.html.inc $"Requirements"
if [ -e $mediumdir/info/requirements.$outputlang.html.inc ]; then
echo "<h3>"$"Requirements""</h3>" >> $outputfile
cat $mediumdir/info/requirements.$outputlang.html.inc >> $outputfile
fi
print_include_section features.$outputlang.html.inc $"Features"
if [ -e $mediumdir/info/features.$outputlang.html.inc ]; then
echo "<h3>"$"Features""</h3>" >> $outputfile
cat $mediumdir/info/features.$outputlang.html.inc >> $outputfile
fi
echo "<h3>"$"Downloads""</h3><table>\
echo "<h3>"$"Downloads""</h3><table>\
<tr><th width=100>"$"Language""</th><th width=50>"$"Arch""</th><th>"$"Download link""</th><th width=50>"$"Size""</th><th width=70>"$"Date""</th><th>MD5</th></tr>" >> $outputfile
for l in ${MEDIA_LANGUAGES[i]}; do
mediummd5=`cat $mediumdir/$l/$distribution-${MEDIA_NAME[i]}-$l-$distversion-$version.${mediumarch}.${medium_suffix}.MD5.txt | awk '{ print $1; }'`
mediumdate=`stat -c %z $mediumdir/$l/$distribution-${MEDIA_NAME[i]}-$l-$distversion-$version.${mediumarch}.${medium_suffix} | sed "s| .*||"`
mediumsize=`stat -c %s $mediumdir/$l/$distribution-${MEDIA_NAME[i]}-$l-$distversion-$version.${mediumarch}.${medium_suffix}`
mediumsizeMB=`expr $mediumsize / 1048576`
for l in ${MEDIA_LANGUAGES[i]}; do
mediummd5=`cat $mediumdir/$l/$distribution-${MEDIA_NAME[i]}-$l-$mediadistversion-$version.${mediumarch}.${medium_suffix}.MD5.txt | awk '{ print $1; }'`
mediumdate=`stat -c %z $mediumdir/$l/$distribution-${MEDIA_NAME[i]}-$l-$mediadistversion-$version.${mediumarch}.${medium_suffix} | sed "s| .*||"`
mediumsize=`stat -c %s $mediumdir/$l/$distribution-${MEDIA_NAME[i]}-$l-$mediadistversion-$version.${mediumarch}.${medium_suffix}`
mediumsizeMB=`expr $mediumsize / 1048576`
echo -n "<tr><td>" >> $outputfile
case $l in
en) echo -n $"english" >> $outputfile ;;
it) echo -n $"italian" >> $outputfile ;;
es) echo -n $"spanish" >> $outputfile ;;
*) echo -n $"unknown" >> $outputfile ;;
esac
echo "</td><td>${mediumarch}</td><td>\
<a href='http://$siteaddress/download.html?file=/pub/$distribution/media/$distversion/${MEDIA_NAME[i]}/$l/$distribution-${MEDIA_NAME[i]}-$l-$distversion-$version.${mediumarch}.${medium_suffix}'>\
$distribution-${MEDIA_NAME[i]}-$l-$distversion-$version.${mediumarch}.${medium_suffix}</a></td>
echo -n "<tr><td>" >> $outputfile
case $l in
en) echo -n $"english" >> $outputfile ;;
it) echo -n $"italian" >> $outputfile ;;
es) echo -n $"spanish" >> $outputfile ;;
*) echo -n $"unknown" >> $outputfile ;;
esac
echo "</td><td>${mediumarch}</td><td>\
<a href='http://$siteaddress/download.html?file=/pub/$distribution/media/$distversion/${MEDIA_NAME[i]}/$l/$distribution-${MEDIA_NAME[i]}-$l-$mediadistversion-$version.${mediumarch}.${medium_suffix}'>\
$distribution-${MEDIA_NAME[i]}-$l-$mediadistversion-$version.${mediumarch}.${medium_suffix}</a></td>
<td>$mediumsizeMB MB</td><td>$mediumdate</td><td>$mediummd5</td>" >> $outputfile
done
echo -n "</tr></table>" >> $outputfile
done
echo -n "</tr></table>" >> $outputfile
echo "<h3>"$"Operating system information""</h3><ul>\
echo "<h3>"$"Operating system information""</h3><ul>\
<li>"$"Name"": openmamba
<li>"$"Type"": "$"GNU/Linux operating system""
<li>"$"License"": "$"GNU General Public License (GPL) version 3""
<li>"$"Release branch"": $distversion
" >> $outputfile
if [ "$distversion" = "milestone2" ]; then
echo "\
if [ "$distversion" = "milestone2" ]; then
echo "\
<li>"$"Planned maintenance"": "$"long term""
<li>"$"Updates level"": "$"bugfix"", "$"security"", "$"end-user applications""
<li>"$"Default updates channels"": milestone2, milestone2-updates, milestone2-games
" >> $outputfile
elif [ "$distversion" = "devel" ]; then
echo "\
elif [ "$distversion" = "devel" ]; then
echo "\
<li>"$"Planned maintenance"": "$"long term""
<li>"$"Updates level"": "$"architectural changes""
<li>"$"Updates default channels"": devel, devel-games
" >> $outputfile
fi
echo -n "</ul>" >> $outputfile
fi
echo -n "</ul>" >> $outputfile
block_start
print_pkg_line $"Linux kernel" kernel
print_pkg_line $"bootloader (grub)" grub
print_pkg_line $"boot system (dracut)" dracut
print_pkg_line $"NVIDIA proprietary driver" NVIDIA
print_pkg_line $"AMD/ATI proprietary driver" ati-driver
block_end $"Kernel, boot and drivers"
block_start
print_pkg_line $"Linux kernel" kernel
print_pkg_line $"bootloader (grub)" grub
print_pkg_line $"boot system (dracut)" dracut
print_pkg_line $"NVIDIA proprietary driver" NVIDIA
print_pkg_line $"AMD/ATI proprietary driver" ati-driver
block_end $"Kernel, boot and drivers"
block_start
print_pkg_line gcc gcc
print_pkg_line glibc glibc
print_pkg_line binutils binutils
block_end $"GNU Toolchain"
block_start
print_pkg_line gcc gcc
print_pkg_line glibc glibc
print_pkg_line binutils binutils
block_end $"GNU Toolchain"
block_start
print_pkg_line "RPM" rpm
print_pkg_line "Smart Package Manager" smart
print_pkg_line "PackageKit" PackageKit
print_pkg_line "KDE PackageKit GUI" kpackagekit
print_pkg_line "Gnome PackageKit GUI" gnome-packagekit
block_end $"Packages and updates management"
block_start
print_pkg_line "RPM" rpm
print_pkg_line "Smart Package Manager" smart
print_pkg_line "PackageKit" PackageKit
print_pkg_line "KDE PackageKit GUI" kpackagekit
print_pkg_line "Gnome PackageKit GUI" gnome-packagekit
block_end $"Packages and updates management"
block_start
print_pkg_line X.org xorg-server
print_pkg_line Mesa Mesa
print_pkg_line KDE kde-workspace
print_pkg_line GNOME gnome-session
print_pkg_line LXDE lxde-common
block_end $"Graphical and Desktop environment"
block_start
print_pkg_line X.org xorg-server
print_pkg_line Mesa Mesa
print_pkg_line KDE kde-workspace
print_pkg_line GNOME gnome-session
print_pkg_line LXDE lxde-common
block_end $"Graphical and Desktop environment"
block_start
print_group "Graphical Desktop/Applications/Graphics"
block_end $"Graphics packages"
block_start
print_group "Graphical Desktop/Applications/Graphics"
block_end $"Graphics packages"
block_start
print_group "Graphical Desktop/Applications/Internet"
print_pkg_line "NetworkManager" NetworkManager
print_pkg_line "KDE network management applet" plasma-applet-networkmanagement
print_pkg_line "Gnome network management applet" network-manager-applet
print_pkg_line "KDE Firewall interface" kcm_ufw
print_pkg_line "Gnome Firewall interface" gufw
block_end $"Internet/Networking packages"
block_start
print_group "Graphical Desktop/Applications/Internet"
print_pkg_line "NetworkManager" NetworkManager
print_pkg_line "KDE network management applet" plasma-applet-networkmanagement
print_pkg_line "Gnome network management applet" network-manager-applet
print_pkg_line "KDE Firewall interface" kcm_ufw
print_pkg_line "Gnome Firewall interface" gufw
block_end $"Internet/Networking packages"
block_start
print_group "Graphical Desktop/Applications/Multimedia"
block_end $"Multimedia packages"
block_start
print_group "Graphical Desktop/Applications/Multimedia"
block_end $"Multimedia packages"
block_start
print_group "Graphical Desktop/Applications/Office"
print_group "Graphical Desktop/Applications/Publishing"
block_end $"Office/Publishing packages"
block_start
print_group "Graphical Desktop/Applications/Office"
print_group "Graphical Desktop/Applications/Publishing"
block_end $"Office/Publishing packages"
block_start
print_group "Graphical Desktop/Applications/Games"
block_end $"Games packages"
block_start
print_group "Graphical Desktop/Applications/Games"
block_end $"Games packages"
block_start
print_pkg_line VirtualBox VirtualBox
print_pkg_line qemu qemu
print_pkg_line Wine wine
block_end $"Emulation/Virtualization packages"
block_start
print_pkg_line VirtualBox VirtualBox
print_pkg_line qemu qemu
print_pkg_line Wine wine
block_end $"Emulation/Virtualization packages"
block_start
print_pkg_line $"Partition editor" gparted
print_pkg_line $"Data recovery" testdisk
print_pkg_line $"MBR boot loader" mbr
print_pkg_line $"NTFS recovery tools" ntfs-3g
print_pkg_line $"Serial terminal emulator" minicom
block_end $"Recovery and diagnostic tools"
block_start
print_pkg_line $"Partition editor" gparted
print_pkg_line $"Data recovery" testdisk
print_pkg_line $"MBR boot loader" mbr
print_pkg_line $"NTFS recovery tools" ntfs-3g
print_pkg_line $"Serial terminal emulator" minicom
block_end $"Recovery and diagnostic tools"
echo "<h3>"$"Links""</h3><ul>" >> $outputfile
echo "<li><a href='http://$siteaddress/distribution/media/${MEDIA_NAME[i]}.html?lang=$outputlang'>\
echo "<h3>"$"Links""</h3><ul>" >> $outputfile
echo "<li><a href='http://$siteaddress/distribution/media/${MEDIA_NAME[i]}.html?lang=$outputlang'>\
"$"${MEDIA_NAME[i]} page at $siteaddress""</a>\
<li><a href='http://$siteaddress/distribution/$distversion.html?lang=$outputlang'>"$"$distversion channels and packages""</a>\
<li><a href='http://$forumaddress'>"$"$distribution forum""</a>\
<li><a href='http://$bugsaddress'>"$"$distribution bug tracking system""</a>\
<li><a href='http://$wikiaddress'>"$"$distribution wiki""</a></ul>\
" >> $outputfile
" >> $outputfile
echo "</div><hr><p><i>"$"Announcement automatically generated by"" makedist-announcement $VERSION "$"and signed off by"" $signer</i>" >> $outputfile
echo "</div><hr><p><i>"$"Announcement automatically generated by"" makedist-announcement $VERSION "$"and signed off by"" $signer</i>" >> $outputfile
#gpg --clearsign $outputfile > $outputfile.sig
rm $mediumdir/info/release-announcement.$outputlang.html
ln -s release-announcement-$version.$outputlang.html $mediumdir/info/release-announcement.$outputlang.html
rm -f $mediumdir/info/release-announcement.$outputlang.html
ln -s release-announcement-$version.$outputlang.html $mediumdir/info/release-announcement.$outputlang.html
> $mediumdir/info/index.$outputlang.html.inc
for f in ls $mediumdir/info/release-announcement-*.$outputlang.html; do
version=`echo $f | sed "s|.*/release-announcement-\(.*\)\.$outputlang.html|\1|"`
echo "<a href='?distrelease=${distrelease}&medium=${MEDIA_NAME[i]}&version=${version}'>${MEDIA_NAME[i]}<a><br>" >>$mediumdir/info/index.$outputlang.html.inc
done
#> $mediumdir/info/index.$outputlang.html.inc
#for f in $mediumdir/info/release-announcement-*.$outputlang.html; do
# version=`echo $f | sed "s|.*/release-announcement-\(.*\)\.$outputlang.html|\1|"`
# echo "<a href='?distrelease=${distrelease}&medium=${MEDIA_NAME[i]}&version=${version}'>${MEDIA_NAME[i]}<a><br>" >>$mediumdir/info/index.$outputlang.html.inc
#done
fi
case $outputlang in
en) SENDADDRESSES="openmamba-users@openmamba.org openmamba-devel@openmamba.org" ;;
it) SENDADDRESSES="openmamba-users-it@openmamba.org openmamba-devel-it@openmamba.org" ;;
*) SENDADDRESSES=
esac
if [ "$SENDEMAIL" -o "$SENDTESTEMAIL" ]; then
if [ ! "$SENDADDRESSES" ]; then
if [ "$SENDTESTEMAIL" ]; then
SENDADDRESSES="test@openmamba.org"
else
case $outputlang in
en) SENDADDRESSES="openmamba-users@openmamba.org openmamba-devel@openmamba.org distro@distrowatch.com" ;;
it) SENDADDRESSES="openmamba-users-it@openmamba.org openmamba-devel-it@openmamba.org" ;;
*) SENDADDRESSES= ;;
esac
fi
fi
if [ "$SENDEMAIL" ]; then
for a in $SENDADDRESSES; do
echo -n "Send email to $a [y/N]?"
echo -n $"Send english ($outputlang) language email to $a [y/N]?"
read ans
if [ "$ans" = "y" -o "$ans" = "Y" ]; then
cat $tmpfile $outputfile | mail \
cat $outputfile | mail \
-a "From: openmamba <noreply@openmamba.org>" \
-a "Content-Type: text/html" \
-a "Content-Type: text/html; charset=utf8" \
-s $"$distribution $distversion ${MEDIA_NAME[i]} $version release announcement" \
$a
fi

View File

@ -14,7 +14,7 @@ msgstr "Note di rilascio"
msgid "Description"
msgstr "Descrizione"
#: /usr/sbin/makedist-announcement:216
msgid "Who is it for"
msgid "Who it's for"
msgstr "Per chi &egrave;"
#: /usr/sbin/makedist-announcement:219
msgid "Requirements"
@ -181,3 +181,6 @@ msgstr "Dimensione"
#
msgid "Date"
msgstr "Data"
#
msgid "Send english ($outputlang) language email to $a [y/N]?"
msgstr "Invio email in italiano ($outputlang) a $a [y/N]?"