cookutils annotate web/cookiso.cgi @ rev 327

cookiso: add rsync.log var to CGI
author Christophe Lincoln <pankso@slitaz.org>
date Fri Mar 16 03:06:17 2012 +0100 (2012-03-16)
parents 57840483f248
children e5492d7d09a8
rev   line source
pankso@319 1 #!/bin/sh
pankso@319 2 #
pankso@319 3 # SliTaz Cookiso CGI/web interface.
pankso@319 4 #
pankso@319 5 echo "Content-Type: text/html"
pankso@319 6 echo ""
pankso@319 7
pankso@319 8 [ -f "/etc/slitaz/cook.conf" ] && . /etc/slitaz/cook.conf
pankso@319 9 [ -f "cook.conf" ] && . ./cook.conf
pankso@319 10
pankso@319 11 # Cookiso DB files.
pankso@319 12 cache="$CACHE/cookiso"
pankso@319 13 iso="$SLITAZ/iso"
pankso@319 14 activity="$cache/activity"
pankso@319 15 command="$cache/command"
pankso@319 16 rollog="$cache/rolling.log"
pankso@327 17 synclog="$cache/rsync.log"
pankso@319 18
pankso@319 19 #
pankso@319 20 # Functions
pankso@319 21 #
pankso@319 22
pankso@319 23 # Put some colors in log and DB files.
pankso@319 24 syntax_highlighter() {
pankso@319 25 case $1 in
pankso@319 26 log)
pankso@319 27 sed -e 's#OK#<span class="span-ok">OK</span>#g' \
pankso@319 28 -e 's#Failed#<span class="span-red">Failed</span>#g' \
pankso@319 29 -e 's|\(Filesystem size:\).*G\([0-9\.]*M\) *$|\1 \2|' \
pankso@319 30 -e 's|.\[1m|<b>|' -e 's|.\[0m|</b>|' -e 's|.\[[0-9Gm;]*||g' ;;
pankso@319 31 activity)
pankso@319 32 sed s"#^\([^']* : \)#<span class='log-date'>\0</span>#"g ;;
pankso@319 33 esac
pankso@319 34 }
pankso@319 35
pankso@319 36 # Latest build pkgs.
pankso@319 37 list_isos() {
pankso@319 38 cd $iso
pankso@319 39 ls -1t *.iso | head -6 | \
pankso@319 40 while read file
pankso@319 41 do
pankso@319 42 echo -n $(stat -c '%y' $file | cut -d . -f 1 | sed s/:[0-9]*$//)
pankso@319 43 echo " : $file"
pankso@319 44 done
pankso@319 45 }
pankso@319 46
paul@325 47 # xHTML header. Pages can be customized with a separate html.header file.
pankso@319 48 if [ -f "header.html" ]; then
pankso@319 49 cat header.html | sed s'/Cooker/ISO Cooker/'
pankso@319 50 else
pankso@319 51 cat << EOT
pankso@319 52 <!DOCTYPE html>
pankso@319 53 <html xmlns="http://www.w3.org/1999/xhtml">
pankso@319 54 <head>
pankso@319 55 <title>SliTaz ISO Cooker</title>
pankso@319 56 <meta charset="utf-8" />
pankso@319 57 <link rel="shortcut icon" href="favicon.ico" />
pankso@319 58 <link rel="stylesheet" type="text/css" href="style.css" />
pankso@319 59 </head>
pankso@319 60 <body>
pankso@319 61
pankso@319 62 <div id="header">
pankso@319 63 <div id="logo"></div>
pankso@319 64 <h1><a href="cookiso.cgi">SliTaz ISO Cooker</a></h1>
pankso@319 65 </div>
pankso@319 66
pankso@319 67 <!-- Content -->
pankso@319 68 <div id="content">
pankso@319 69 EOT
pankso@319 70 fi
pankso@319 71
pankso@319 72 #
pankso@319 73 # Load requested page
pankso@319 74 #
pankso@319 75
pankso@319 76 case "${QUERY_STRING}" in
pankso@319 77 distro=*)
pankso@319 78 distro=${QUERY_STRING#distro=}
pankso@319 79 log=$iso/slitaz-$distro.log
pankso@319 80 . $SLITAZ/flavors/${distro#*-}/receipt
pankso@319 81 echo "<h2>Distro: $distro</h2>"
pankso@319 82 echo "<p>Description: $SHORT_DESC</p>"
pankso@319 83 echo '<h3>Cookiso log</h3>'
pankso@319 84 echo '<pre>'
pankso@319 85 cat $log | syntax_highlighter log
pankso@319 86 echo '</pre>' ;;
pankso@319 87 *)
pankso@319 88 # Main page with summary.
pankso@319 89 echo -n "Running command : "
pankso@319 90 if [ -f "$command" ]; then
pankso@319 91 cat $command
pankso@319 92 else
pankso@319 93 echo "Not running"
pankso@319 94 fi
pankso@319 95 cat << EOT
pankso@319 96 <h2>Activity</h2>
pankso@319 97 <pre>
pankso@319 98 $(tac $activity | head -n 12 | syntax_highlighter activity)
pankso@319 99 </pre>
pankso@319 100
pankso@319 101 <h2>Latest ISO</h2>
pankso@319 102 <pre>
pankso@319 103 $(list_isos | syntax_highlighter activity)
pankso@319 104 </pre>
pankso@319 105 EOT
pankso@319 106 # Rolling Bot log.
pankso@319 107 if [ -f "$rollog" ]; then
pankso@319 108 echo "<h2>Rolling log</h2>"
pankso@319 109 echo '<pre>'
pankso@319 110 cat $rollog
pankso@319 111 echo '</pre>'
pankso@326 112 fi
pankso@326 113 # Rsync log.
pankso@326 114 if [ -f "$synclog" ]; then
pankso@326 115 echo "<h2>Rsync log</h2>"
pankso@326 116 echo '<pre>'
pankso@326 117 cat $synclog
pankso@326 118 echo '</pre>'
pankso@319 119 fi ;;
pankso@319 120 esac
pankso@319 121
pankso@319 122 # Close xHTML page
pankso@319 123 cat << EOT
pankso@319 124 </div>
pankso@319 125
pankso@319 126 <div id="footer">
pankso@319 127 <a href="http://www.slitaz.org/">SliTaz Website</a>
pankso@319 128 <a href="cookiso.cgi">Cookiso</a>
pankso@319 129 <a href="http://hg.slitaz.org/cookutils/raw-file/tip/doc/cookutils.en.html">
pankso@319 130 Documentation</a>
pankso@319 131 </div>
pankso@319 132
pankso@319 133 </body>
pankso@319 134 </html>
pankso@319 135 EOT
pankso@319 136
pankso@319 137 exit 0