cookutils annotate cookiso @ rev 844

cookiso: rotate logs
author Pascal Bellard <pascal.bellard@slitaz.org>
date Sun Dec 11 10:33:24 2016 +0100 (2016-12-11)
parents a328952982d6
children 63fb59f6fd67
rev   line source
pankso@318 1 #!/bin/sh
pankso@318 2 #
paul@325 3 # Cookiso utility - Build official ISOs in a chroot environment.
paul@325 4 # The goal is to have a tool well integrated with cookutils but which
paul@325 5 # can run on its own and automate official SliTaz ISO creation.
pankso@318 6 #
pankso@318 7
pankso@318 8 # --> cook.conf
pankso@318 9 # SSH/RSA configuration to upload on a server.
slaxemulator@457 10 # Assign this before cook.conf so it can be
paul@495 11 # reassigned in cook.conf.
al@728 12 SSH_CMD='dbclient -i /root/.ssh/id_rsa.dropbear'
al@728 13 SSH_ISO='/var/www/slitaz/mirror/iso'
al@728 14 SSH_HOST='slitaz@mirror1.slitaz.org'
pankso@318 15 #BWLIMIT="--bwlimit=40"
pankso@318 16
slaxemulator@457 17 . /usr/lib/slitaz/libcook.sh
pankso@318 18
al@728 19
pankso@318 20 # Parse cmdline options.
al@728 21
al@728 22 for opt in "$@"; do
pankso@318 23 case "$opt" in
pascal@714 24 --force)
al@728 25 force='yes' ;;
pankso@318 26 --pkgdb)
pankso@318 27 cook pkgdb --flavors ;;
pankso@318 28 --push)
al@728 29 push='yes' ;;
pankso@318 30 --flavors=*)
pankso@318 31 flavors=${opt#--flavors=} ;;
pankso@318 32 --version=*)
pankso@318 33 version=${opt#--version=} ;;
pankso@318 34 esac
pankso@318 35 done
pankso@318 36
al@728 37
pankso@318 38 # Default to rolling, or: cookiso [cmd] --version=stable
al@728 39
pankso@318 40 case "$version" in
al@728 41 stable) string='stable' ;;
al@728 42 cooking) string='cooking' ;;
al@728 43 *) string='rolling'; version='cooking' ;;
pankso@318 44 esac
pankso@318 45
al@728 46
pankso@318 47 # Running command
al@728 48
pankso@318 49 [ -d "$cache" ] && echo "$@" > $command
pankso@318 50 trap 'rm -f $command && exit 1' INT TERM
pankso@318 51
al@728 52
pankso@318 53 #
pankso@318 54 # Functions
pankso@318 55 #
pankso@318 56
pankso@318 57 usage() {
al@728 58 cat <<EOT
pankso@318 59
al@728 60 $(boldify "Usage:") cookiso [command] [--option]
pankso@318 61
al@728 62 $(boldify "Commands:")
pankso@318 63 usage Display this short usage.
pankso@318 64 setup Setup Cookiso build environment.
pankso@318 65 push Manually push ISO to a server via SSH.
pankso@318 66 gen Generate specified flavors.
pankso@318 67 4in1 Generate all 4in1 flavors.
paul@325 68 rolling Build the rolling ISOs if any changes.
pankso@318 69
al@728 70 $(boldify "Options:")
pascal@714 71 --force Build ISO rolling anyway.
pankso@318 72 --pkgdb Generate packages DB before building ISO.
pankso@318 73 --push Upload freshly generated ISO to a server.
pankso@318 74 --flavors= List of flavors to generate with 'gen' command.
pankso@318 75 --version= Specify SliTaz version: [rolling|cooking|stable]
pankso@318 76
pankso@318 77 EOT
pankso@318 78 }
pankso@318 79
al@728 80
pankso@318 81 spider() {
al@728 82 echo -e ' // \\\\\n _\\\\()//_\n/ // \\\\ \\\n | \\__/ |'
pankso@318 83 }
pankso@318 84
al@728 85
paul@325 86 # Check for some flavors on cmdline
al@728 87
pankso@318 88 flavors_list() {
al@728 89 if [ "$flavors" == 'all' ]; then
pankso@318 90 flavors=$(ls $SLITAZ/flavors)
pankso@318 91 fi
al@728 92 if [ -z "$flavors" ]; then
al@728 93 echo 'No flavor specified on cmdline. Use: --flavors='
al@728 94 rm -f $command
al@728 95 exit 0
pankso@318 96 fi
pankso@318 97 }
pankso@318 98
al@728 99
pankso@318 100 # Log activities, we want first letter capitalized.
al@728 101
pankso@318 102 log() {
pankso@318 103 grep ^[A-Z] | \
al@728 104 sed s"#^[A-Z]\([^']*\)#$(date '+%F %R') : \0#" >> $activity
pankso@318 105 }
pankso@318 106
al@728 107
pankso@318 108 log_bot() {
pankso@318 109 sed '/^.\//'d | sed '/^.hg/'d | tee -a $rollog
pankso@318 110 }
pankso@318 111
al@728 112
pankso@318 113 # Generate requested flavors.
al@728 114
pankso@318 115 gen_flavors() {
pankso@556 116 cd $SLITAZ/flavors
pankso@556 117 [ -d ".hg" ] && hg pull -u
al@728 118 mkdir -p $cache; cd $cache
mojo@511 119 rm -rf *.flavor *.list *.conf *.sh
al@728 120 for flavor in $flavors; do
al@728 121 if [ "$flavor" != 'core-4in1' ]; then
pankso@318 122 name="slitaz-$string-$flavor"
pankso@318 123 else
pankso@318 124 name="slitaz-$string"
pankso@318 125 fi
al@728 126 log="$iso/$name.log"
pascal@844 127 for i in $(seq 9 -1 1); do # Rotate log
pascal@844 128 j=$(($i - 1))
pascal@844 129 [ -e $log.$j ] && mv -f $log.$j $log.$i
pascal@844 130 done
pascal@844 131 [ -e $log ] && mv $log $log.0
pascal@844 132 touch $log
pankso@318 133 echo "Building $string <a href='?distro=$string-$flavor'>$flavor</a>" | log
al@728 134 echo "Cookiso started: $(date '+%F %R')" | tee -a $log
pankso@318 135 tazlito pack-flavor $flavor | tee -a $log
pankso@318 136 tazlito get-flavor $flavor | tee -a $log
paul@325 137 # BUG: script sometimes screws up conspy on Tank
pankso@329 138 #script -c "yes '' | tazlito gen-distro" -a $log
al@776 139 yes '' | tazlito gen-distro --forced 2>&1 | tee -a $log
pankso@318 140 # Rename ISO and md5
pankso@348 141 echo "Moving ISO to: $iso/$name.iso" | tee -a $log
pankso@318 142 mv -f $SLITAZ/distro/slitaz-$flavor.iso $iso/$name.iso
al@728 143 cd $iso; md5sum $name.iso > $name.md5
al@728 144 echo "Cookiso ended: $(date '+%F %R')" | tee -a $log
al@728 145 done
al@728 146 newline
al@728 147
pankso@335 148 # Push ISO to mirror if requested.
al@728 149 [ -n "$push" ] && push_iso
pankso@318 150 }
pankso@318 151
al@728 152
pankso@318 153 # Push an ISO to a server.
al@728 154
pankso@318 155 push_iso() {
pankso@322 156 echo "Pushing to host: ${SSH_HOST}"
pankso@318 157 export DROPBEAR_PASSWORD=none
al@728 158 for flavor in $flavors; do
al@728 159 distro="slitaz-${string}-$flavor"
al@728 160 file="${distro%-core-4in1}"
pascal@844 161 rsync $BWLIMIT -vtP -e "$SSH_CMD" $iso/$file.??? \
pankso@329 162 ${SSH_HOST}:$SSH_ISO/$string 2>&1 | tee $synclog
pankso@318 163 done
pankso@318 164 }
pankso@318 165
al@728 166
pankso@318 167 #
pankso@318 168 # Commands
pankso@318 169 #
pankso@318 170
pankso@318 171 case "$1" in
pankso@318 172 setup)
pankso@318 173 # Setup Hg repo and dirs
pankso@318 174 echo -e "\nSetting up Cookiso environment..."
pankso@318 175 cd $SLITAZ
pankso@318 176 if [ ! -d "flavors" ]; then
pankso@318 177 case $version in
pankso@318 178 cooking|rolling)
slaxemulator@520 179 hg clone $FLAVORS_URL ;;
pankso@318 180 stable)
slaxemulator@520 181 hg clone $FLAVORS_URL-stable flavors ;;
pankso@318 182 esac
pankso@318 183 fi
al@728 184
pankso@318 185 # Needed packages
al@728 186 for pkg in mercurial tazlito rsync dropbear; do
al@728 187 [ ! -d "$INSTALLED/$pkg" ] && tazpkg -gi $pkg
pankso@318 188 done
al@728 189
al@728 190 echo 'Creating directories and files...'
pankso@318 191 mkdir -p $cache $iso
pankso@318 192 touch $activity
al@735 193 sed -i s'/^WORK_DIR=.*/WORK_DIR="\/home\/slitaz"/' \
pankso@318 194 /etc/tazlito/tazlito.conf
al@728 195 newline
pankso@318 196 echo "Flavors files : $SLITAZ/flavors"
pankso@318 197 echo "Cache files : $cache"
pankso@318 198 echo "ISO images : $iso"
al@735 199 newline ;;
al@728 200
pankso@318 201 push)
pankso@318 202 # Manually upload an ISO to a server.
pankso@322 203 flavors_list
pankso@318 204 push_iso ;;
al@728 205
pankso@318 206 gen)
paul@325 207 # Build one or more flavors.
pankso@318 208 flavors_list
pankso@318 209 echo -e "\nGenerating flavors:\n$flavors"
pankso@318 210 gen_flavors ;;
al@728 211
pankso@318 212 4in1)
paul@325 213 echo -e "\nGenerating 4in1 distros..."
pankso@318 214 flavors="base justx gtkonly core core-4in1"
pankso@318 215 gen_flavors ;;
al@728 216
pankso@318 217 rolling)
pankso@318 218 #
paul@325 219 # Official SliTaz rolling release flavors are automatically built.
pankso@318 220 #
paul@325 221 # Check if packages list was modified or if any commits have been
paul@325 222 # done in one of the rolling flavors and rebuild ISOs if needed.
pankso@318 223 #
al@728 224 pkgs="$SLITAZ/packages/packages.md5"
al@728 225 last="$cache/packages.md5"
al@728 226 diff="$cache/packages.diff"
pascal@623 227 cook="preinit core-4in1 core core64"
al@728 228
pankso@318 229 # Log stuff
al@728 230 rm -f $rollog; touch $rollog
al@728 231 rm -f $commit $commits.tmp; touch $commits.tmp
al@728 232 echo 'Rolling tracking for changes' | log
al@728 233 echo "Cookiso rolling started: $(date '+%F %R')" | log_bot
al@728 234
pankso@318 235 # Packages changes
al@728 236 [ ! -f "$last" ] && cp -f $pkgs $cache
al@728 237 diff $last $pkgs > $diff
pascal@714 238 if [ "$force" ] || [ -s "$diff" ]; then
al@728 239 echo 'Found new or rebuilt packages' | log_bot
pankso@335 240 cat $diff | grep "^+" >> $rollog
pankso@318 241 #
pankso@318 242 # TODO: Check new pkg and see if it's part of one of the rolling
pankso@318 243 # flavors, if not we have nothing to build.
pankso@318 244 #
al@728 245 for flavor in $cook; do
pankso@318 246 echo "$flavor" >> $commits.tmp
pankso@318 247 echo "New packages for : $flavor" | log_bot
pankso@318 248 done
pankso@318 249 else
al@728 250 echo 'No changes found in packages MD5 sum' | log_bot
al@728 251 echo '' > $commits.tmp
pankso@318 252 fi
pankso@318 253 cp -f $pkgs $cache
al@728 254
pankso@318 255 # Hg changes
pankso@318 256 cd $repo || exit 1
pankso@318 257 cur=$(hg head --template '{rev}\n')
al@728 258 echo "Updating wok : $repo (rev $cur)" | log_bot
al@728 259 cd $repo; hg pull -u | log_bot
al@728 260 new=$(hg head --template '{rev}\n')
pankso@318 261 cur=$(($cur + 1))
al@728 262 for rev in $(seq $cur $new); do
al@728 263 for file in $(hg log --rev=$rev --template "{files}"); do
al@728 264 flavor=$(echo $file | cut -d/ -f1)
pankso@318 265 desc=$(hg log --rev=$rev --template "{desc}" $file)
paul@325 266 echo "Committed flavor : $flavor - $desc" | log_bot
pankso@318 267 # Build only rolling flavor
pankso@318 268 if echo "$cook" | fgrep -q $flavor; then
pankso@318 269 echo $flavor >> $commits.tmp
pankso@318 270 fi
pankso@318 271 done
pankso@318 272 done
al@728 273
pankso@318 274 # Keep previous commit and discard duplicate lines
pankso@318 275 cat $commits.tmp | sed /"^$"/d > $commits.new
pankso@318 276 uniq $commits.new > $commits && rm $commits.*
pankso@318 277 nb=$(cat $commits | wc -l)
pankso@318 278 echo "Flavors to cook : $nb" | log_bot
pankso@318 279 flavors=$(cat $commits)
pankso@321 280 gen_flavors ;;
al@728 281
pankso@318 282 spider)
pankso@318 283 # SliTaz Easter egg command :-)
pankso@318 284 spider ;;
al@728 285
pankso@318 286 *)
pankso@318 287 usage ;;
pankso@318 288 esac
pankso@318 289
pankso@318 290 rm -f $command
pankso@318 291 exit 0