cookutils annotate web/cooker.cgi @ rev 392
one more line to display in summary (we have host arch) and test --output=html in cooker
author | Christophe Lincoln <pankso@slitaz.org> |
---|---|
date | Sun May 13 02:00:39 2012 +0200 (2012-05-13) |
parents | e4f6883a36fc |
children | f96794734ee6 |
rev | line source |
---|---|
pankso@5 | 1 #!/bin/sh |
pankso@5 | 2 # |
pankso@5 | 3 # SliTaz Cooker CGI/web interface. |
pankso@5 | 4 # |
pankso@5 | 5 |
pankso@5 | 6 [ -f "/etc/slitaz/cook.conf" ] && . /etc/slitaz/cook.conf |
pankso@5 | 7 [ -f "cook.conf" ] && . ./cook.conf |
pankso@5 | 8 |
pankso@5 | 9 # The same wok as cook. |
pankso@5 | 10 wok="$WOK" |
pankso@5 | 11 |
pankso@5 | 12 # Cooker DB files. |
pankso@5 | 13 activity="$CACHE/activity" |
pankso@5 | 14 commits="$CACHE/commits" |
pankso@5 | 15 cooklist="$CACHE/cooklist" |
pankso@5 | 16 cookorder="$CACHE/cookorder" |
pankso@14 | 17 command="$CACHE/command" |
pankso@5 | 18 blocked="$CACHE/blocked" |
pankso@5 | 19 broken="$CACHE/broken" |
pankso@22 | 20 cooknotes="$CACHE/cooknotes" |
pankso@164 | 21 wokrev="$CACHE/wokrev" |
pankso@5 | 22 |
paul@256 | 23 # We're not logged and want time zone to display correct server date. |
pankso@249 | 24 export TZ=$(cat /etc/TZ) |
pankso@249 | 25 |
pascal@354 | 26 if [ "${QUERY_STRING%%=*}" == "download" ]; then |
pascal@354 | 27 file=$PKGS/${QUERY_STRING#*=} |
pascal@354 | 28 cat <<EOT |
pascal@354 | 29 Content-Type: application/octet-stream |
pascal@354 | 30 Content-Length: $(stat -c %s $file) |
pascal@354 | 31 Content-Disposition: attachment; filename=$(basename $file) |
pascal@354 | 32 |
pascal@354 | 33 EOT |
pascal@354 | 34 cat $file |
pascal@354 | 35 exit |
pascal@354 | 36 fi |
pascal@354 | 37 |
pascal@354 | 38 echo "Content-Type: text/html" |
pascal@354 | 39 echo "" |
pankso@5 | 40 |
pankso@310 | 41 # RSS feed generator |
pankso@310 | 42 if [ "$QUERY_STRING" == "rss" ]; then |
pankso@310 | 43 pubdate=$(date "+%a, %d %b %Y %X") |
pankso@310 | 44 cat << EOT |
pankso@310 | 45 <?xml version="1.0" encoding="utf-8" ?> |
pankso@310 | 46 <rss version="2.0"> |
pankso@310 | 47 <channel> |
pankso@310 | 48 <title>SliTaz Cooker</title> |
pankso@310 | 49 <description>The SliTaz packages cooker feed</description> |
pankso@310 | 50 <link>$COOKER_URL</link> |
pankso@310 | 51 <lastBuildDate>$pubdate GMT</lastBuildDate> |
pankso@310 | 52 <pubDate>$pubdate GMT</pubDate> |
pankso@310 | 53 EOT |
pankso@310 | 54 for rss in $(ls -lt $FEEDS/*.xml | head -n 12) |
pankso@310 | 55 do |
pankso@310 | 56 cat $rss |
pankso@310 | 57 done |
pankso@310 | 58 cat << EOT |
pankso@310 | 59 </channel> |
pankso@310 | 60 </rss> |
pankso@310 | 61 EOT |
pankso@310 | 62 exit 0 |
pankso@310 | 63 fi |
pankso@310 | 64 |
pascal@354 | 65 # |
pascal@354 | 66 # Functions |
pascal@354 | 67 # |
pascal@354 | 68 |
pankso@5 | 69 # Put some colors in log and DB files. |
pankso@5 | 70 syntax_highlighter() { |
pankso@17 | 71 case $1 in |
pankso@17 | 72 log) |
pankso@17 | 73 sed -e 's#OK$#<span class="span-ok">OK</span>#g' \ |
pankso@17 | 74 -e 's#yes$#<span class="span-ok">yes</span>#g' \ |
pankso@17 | 75 -e 's#no$#<span class="span-no">no</span>#g' \ |
pankso@129 | 76 -e 's#error$#<span class="span-red">error</span>#g' \ |
pankso@129 | 77 -e 's#ERROR:#<span class="span-red">ERROR:</span>#g' \ |
pankso@129 | 78 -e 's#WARNING:#<span class="span-red">WARNING:</span>#g' \ |
pankso@65 | 79 -e s"#^Executing:\([^']*\).#<span class='sh-val'>\0</span>#"g \ |
pankso@17 | 80 -e s"#^====\([^']*\).#<span class='span-line'>\0</span>#"g \ |
pankso@29 | 81 -e s"#^[a-zA-Z0-9]\([^']*\) :: #<span class='span-sky'>\0</span>#"g \ |
pankso@17 | 82 -e s"#ftp://\([^']*\).*#<a href='\0'>\0</a>#"g \ |
pankso@17 | 83 -e s"#http://\([^']*\).*#<a href='\0'>\0</a>#"g ;; |
pankso@17 | 84 receipt) |
pankso@258 | 85 sed -e s'|&|\&|g' -e 's|<|\<|g' -e 's|>|\>|'g \ |
pankso@258 | 86 -e s"#^\#\([^']*\)#<span class='sh-comment'>\0</span>#"g \ |
pankso@17 | 87 -e s"#\"\([^']*\)\"#<span class='sh-val'>\0</span>#"g ;; |
pankso@129 | 88 diff) |
pankso@129 | 89 sed -e 's|&|\&|g' -e 's|<|\<|g' -e 's|>|\>|g' \ |
pankso@129 | 90 -e s"#^-\([^']*\).#<span class='span-red'>\0</span>#"g \ |
pankso@129 | 91 -e s"#^+\([^']*\).#<span class='span-ok'>\0</span>#"g \ |
pankso@129 | 92 -e s"#@@\([^']*\)@@#<span class='span-sky'>@@\1@@</span>#"g ;; |
pankso@129 | 93 activity) |
pankso@129 | 94 sed s"#^\([^']* : \)#<span class='log-date'>\0</span>#"g ;; |
pankso@17 | 95 esac |
pankso@5 | 96 } |
pankso@5 | 97 |
pankso@5 | 98 # Latest build pkgs. |
pankso@5 | 99 list_packages() { |
pankso@5 | 100 cd $PKGS |
pankso@5 | 101 ls -1t *.tazpkg | head -20 | \ |
pankso@5 | 102 while read file |
pankso@5 | 103 do |
pankso@5 | 104 echo -n $(stat -c '%y' $PKGS/$file | cut -d . -f 1 | sed s/:[0-9]*$//) |
pankso@5 | 105 echo " : $file" |
pankso@5 | 106 done |
pankso@5 | 107 } |
pankso@5 | 108 |
pankso@253 | 109 # xHTML header. Pages can be customized with a separated html.header file. |
pankso@253 | 110 if [ -f "header.html" ]; then |
pankso@253 | 111 cat header.html |
pankso@253 | 112 else |
pankso@253 | 113 cat << EOT |
pankso@5 | 114 <!DOCTYPE html> |
pankso@5 | 115 <html xmlns="http://www.w3.org/1999/xhtml"> |
pankso@5 | 116 <head> |
pankso@5 | 117 <title>SliTaz Cooker</title> |
pankso@5 | 118 <meta charset="utf-8" /> |
pankso@252 | 119 <link rel="shortcut icon" href="favicon.ico" /> |
pankso@5 | 120 <link rel="stylesheet" type="text/css" href="style.css" /> |
pankso@5 | 121 </head> |
pankso@5 | 122 <body> |
pankso@5 | 123 |
pankso@5 | 124 <div id="header"> |
pankso@253 | 125 <div id="logo"></div> |
pankso@5 | 126 <h1><a href="cooker.cgi">SliTaz Cooker</a></h1> |
pankso@5 | 127 </div> |
pankso@5 | 128 |
pankso@5 | 129 <!-- Content --> |
pankso@5 | 130 <div id="content"> |
pankso@5 | 131 EOT |
pankso@253 | 132 fi |
pankso@5 | 133 |
pankso@5 | 134 # |
pankso@5 | 135 # Load requested page |
pankso@5 | 136 # |
pankso@5 | 137 |
pankso@5 | 138 case "${QUERY_STRING}" in |
pankso@16 | 139 pkg=*) |
pankso@16 | 140 pkg=${QUERY_STRING#pkg=} |
pankso@16 | 141 log=$LOGS/$pkg.log |
pankso@16 | 142 echo "<h2>Package: $pkg</h2>" |
pankso@16 | 143 |
pankso@18 | 144 # Package info. |
pankso@18 | 145 echo '<div id="info">' |
pankso@16 | 146 if [ -f "$wok/$pkg/receipt" ]; then |
pankso@16 | 147 echo "<a href='cooker.cgi?receipt=$pkg'>receipt</a>" |
pascal@275 | 148 unset WEB_SITE |
pascal@275 | 149 . $wok/$pkg/receipt |
pascal@301 | 150 [ -n "$WEB_SITE" ] && # busybox wget -s $WEB_SITE && |
pascal@275 | 151 echo "<a href='$WEB_SITE'>home</a>" |
pascal@354 | 152 if [ -f "$wok/$pkg/taz/$PACKAGE-$VERSION/receipt" ]; then |
pascal@355 | 153 echo "<a href='cooker.cgi?files=$pkg'>files</a>" |
pascal@354 | 154 unset EXTRAVERSION |
pascal@354 | 155 . $wok/$pkg/taz/$PACKAGE-$VERSION/receipt |
pascal@354 | 156 if [ -f $PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg ]; then |
pascal@354 | 157 echo "<a href='cooker.cgi?download=$PACKAGE-$VERSION$EXTRAVERSION.tazpkg'>download</a>" |
pascal@354 | 158 fi |
pascal@354 | 159 fi |
pankso@16 | 160 else |
pankso@18 | 161 echo "No package named: $pkg" |
pankso@16 | 162 fi |
pankso@18 | 163 echo '</div>' |
pankso@16 | 164 |
paul@62 | 165 # Check for a log file and display summary if it exists. |
pankso@16 | 166 if [ -f "$log" ]; then |
pankso@87 | 167 if grep -q "cook:$pkg$" $command; then |
pankso@88 | 168 echo "<pre>The Cooker is currently building: $pkg</pre>" |
pankso@87 | 169 fi |
pankso@149 | 170 if fgrep -q "Summary for:" $LOGS/$pkg.log; then |
pankso@87 | 171 echo "<h3>Cook summary</h3>" |
pankso@87 | 172 echo '<pre>' |
pankso@392 | 173 grep -A 9 "^Summary for:" $LOGS/$pkg.log | sed /^$/d | \ |
pankso@87 | 174 syntax_highlighter log |
pankso@87 | 175 echo '</pre>' |
pankso@14 | 176 fi |
pankso@149 | 177 if fgrep -q "Debug information" $LOGS/$pkg.log; then |
pankso@17 | 178 echo "<h3>Cook failed</h3>" |
pankso@17 | 179 echo '<pre>' |
pankso@149 | 180 grep -A 8 "^Debug information" $LOGS/$pkg.log | sed /^$/d | \ |
pankso@17 | 181 syntax_highlighter log |
pankso@17 | 182 echo '</pre>' |
pankso@16 | 183 fi |
pankso@16 | 184 echo "<h3>Cook log</h3>" |
pankso@16 | 185 echo '<pre>' |
pankso@17 | 186 cat $log | syntax_highlighter log |
pankso@16 | 187 echo '</pre>' |
pankso@5 | 188 else |
pankso@16 | 189 echo "<pre>No log: $pkg</pre>" |
pankso@16 | 190 fi ;; |
pankso@65 | 191 file=*) |
paul@89 | 192 # Dont allow all files on the system for security reasons. |
pankso@65 | 193 file=${QUERY_STRING#file=} |
pankso@65 | 194 case "$file" in |
pankso@90 | 195 activity|cooknotes|cooklist) |
pankso@91 | 196 [ "$file" == "cooklist" ] && \ |
pankso@93 | 197 nb="- Packages: $(cat $cooklist | wc -l)" |
pankso@91 | 198 echo "<h2>DB: $file $nb</h2>" |
pankso@18 | 199 echo '<pre>' |
pankso@129 | 200 tac $CACHE/$file | syntax_highlighter activity |
pankso@65 | 201 echo '</pre>' ;; |
pankso@66 | 202 broken) |
pankso@66 | 203 nb=$(cat $broken | wc -l) |
pankso@93 | 204 echo "<h2>DB: broken - Packages: $nb</h2>" |
pankso@66 | 205 echo '<pre>' |
pankso@129 | 206 cat $CACHE/$file | sort | \ |
pankso@66 | 207 sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g |
pankso@66 | 208 echo '</pre>' ;; |
pankso@129 | 209 *.diff) |
pankso@129 | 210 diff=$CACHE/$file |
pankso@129 | 211 echo "<h2>Diff for: ${file%.diff}</h2>" |
pankso@129 | 212 [ "$file" == "installed.diff" ] && echo \ |
pankso@129 | 213 "<p>This is the latest diff between installed packages \ |
pankso@130 | 214 and installed build dependencies to cook.</p>" |
pankso@129 | 215 echo '<pre>' |
pankso@129 | 216 cat $diff | syntax_highlighter diff |
pankso@129 | 217 echo '</pre>' ;; |
pankso@65 | 218 *.log) |
pankso@71 | 219 log=$LOGS/$file |
pankso@71 | 220 name=$(basename $log) |
pankso@65 | 221 echo "<h2>Log for: ${name%.log}</h2>" |
pankso@71 | 222 if [ -f "$log" ]; then |
pankso@71 | 223 if fgrep -q "Summary" $log; then |
pankso@65 | 224 echo '<pre>' |
pankso@73 | 225 grep -A 20 "^Summary" $log | sed /^$/d | \ |
pankso@65 | 226 syntax_highlighter log |
pankso@65 | 227 echo '</pre>' |
pankso@65 | 228 fi |
pankso@65 | 229 echo '<pre>' |
pankso@71 | 230 cat $log | syntax_highlighter log |
pankso@65 | 231 echo '</pre>' |
pankso@65 | 232 else |
pankso@71 | 233 echo "<pre>No log file: $log</pre>" |
pankso@65 | 234 fi ;; |
pankso@65 | 235 esac ;; |
pankso@16 | 236 receipt=*) |
pankso@16 | 237 pkg=${QUERY_STRING#receipt=} |
pankso@17 | 238 echo "<h2>Receipt for: $pkg</h2>" |
pankso@16 | 239 if [ -f "$wok/$pkg/receipt" ]; then |
pankso@16 | 240 echo '<pre>' |
pankso@17 | 241 cat $wok/$pkg/receipt | syntax_highlighter receipt |
pankso@16 | 242 echo '</pre>' |
pankso@16 | 243 else |
pascal@301 | 244 echo "<pre>No receipt for: $pkg</pre>" |
pascal@301 | 245 fi ;; |
pascal@301 | 246 files=*) |
pascal@301 | 247 pkg=${QUERY_STRING#files=} |
pascal@301 | 248 echo "<h2>Installed files by: $pkg</h2>" |
pascal@301 | 249 dir=$(ls -d $WOK/$pkg/taz/$pkg-*) |
pascal@301 | 250 if [ -d "$dir/fs" ]; then |
pascal@301 | 251 echo '<pre>' |
pascal@301 | 252 find $dir/fs -not -type d | xargs ls -ld | \ |
pascal@301 | 253 sed "s|$dir/fs||" | syntax_highlighter log |
pascal@301 | 254 echo '</pre>' |
pascal@301 | 255 else |
pascal@301 | 256 echo "<pre>No files list for: $pkg</pre>" |
pankso@5 | 257 fi ;; |
pankso@5 | 258 *) |
pankso@383 | 259 # We may have a toolchain.cgi script for cross cooker's |
pankso@383 | 260 if [ -f "toolchain.cgi" ]; then |
pankso@383 | 261 toolchain='toolchain.cgi' |
pankso@383 | 262 else |
pankso@383 | 263 toolchain='cooker.cgi?pkg=slitaz-toolchain' |
pankso@383 | 264 fi |
pankso@383 | 265 # Main page with summary. Count only package include in ARCH, |
pankso@383 | 266 # use 'cooker arch' to manually create arch.$ARCH files. |
pankso@383 | 267 # We may have arm only packages, use arch.i486 ? |
pankso@383 | 268 case "$ARCH" in |
pankso@383 | 269 arm) inwok=$(ls $WOK/*/arch.$ARCH | wc -l) ;; |
pankso@383 | 270 *) inwok=$(ls $WOK | wc -l) ;; |
pankso@383 | 271 esac |
pankso@75 | 272 cooked=$(ls $PKGS/*.tazpkg | wc -l) |
pankso@106 | 273 unbuilt=$(($inwok - $cooked)) |
pankso@245 | 274 pct=0 |
pankso@245 | 275 [ $inwok -gt 0 ] && pct=$(( ($cooked * 100) / $inwok )) |
pankso@5 | 276 cat << EOT |
pankso@5 | 277 <div style="float: right;"> |
pankso@5 | 278 <form method="get" action="$SCRIPT_NAME"> |
pankso@16 | 279 Package: |
pankso@16 | 280 <input type="text" name="pkg" /> |
pankso@5 | 281 </form> |
pankso@5 | 282 </div> |
pankso@5 | 283 |
pankso@5 | 284 <h2>Summary</h2> |
pankso@75 | 285 |
pankso@5 | 286 <pre> |
pankso@16 | 287 Running command : $([ -s "$command" ] && cat $command || echo "Not running") |
pascal@301 | 288 Wok revision : <a href="$WOK_URL">$(cat $wokrev)</a> |
pankso@5 | 289 Commits to cook : $(cat $commits | wc -l) |
pankso@65 | 290 Current cooklist : $(cat $cooklist | wc -l) |
pankso@5 | 291 Broken packages : $(cat $broken | wc -l) |
pankso@95 | 292 Blocked packages : $(cat $blocked | wc -l) |
pankso@5 | 293 </pre> |
pankso@5 | 294 |
pankso@383 | 295 <p class="info"> |
pankso@247 | 296 Packages: $inwok in the wok - $cooked cooked - $unbuilt unbuilt - |
pankso@247 | 297 Server date: $(date '+%Y-%m-%d %H:%M') |
pankso@75 | 298 </p> |
pankso@75 | 299 <div class="pctbar"> |
pankso@75 | 300 <div class="pct" style="width: ${pct}%;">${pct}%</div> |
pankso@14 | 301 </div> |
pankso@14 | 302 |
pankso@75 | 303 <p> |
pankso@129 | 304 Latest: |
pankso@129 | 305 <a href="cooker.cgi?file=cookorder.log">cookorder.log</a> |
pankso@129 | 306 <a href="cooker.cgi?file=commits.log">commits.log</a> |
pankso@129 | 307 <a href="cooker.cgi?file=installed.diff">installed.diff</a> |
pankso@188 | 308 - Architecture $ARCH: |
pankso@383 | 309 <a href="$toolchain">toolchain</a> |
pankso@75 | 310 </p> |
pankso@75 | 311 |
pascal@270 | 312 <a name="activity"></a> |
pankso@5 | 313 <h2>Activity</h2> |
pankso@5 | 314 <pre> |
pankso@129 | 315 $(tac $CACHE/activity | head -n 12 | syntax_highlighter activity) |
pankso@5 | 316 </pre> |
pankso@65 | 317 <a class="button" href="cooker.cgi?file=activity">More activity</a> |
pankso@5 | 318 |
pascal@272 | 319 <a name="cooknotes"></a> |
pankso@23 | 320 <h2>Cooknotes</h2> |
pankso@23 | 321 <pre> |
pankso@129 | 322 $(tac $cooknotes | head -n 12 | syntax_highlighter activity) |
pankso@23 | 323 </pre> |
pankso@65 | 324 <a class="button" href="cooker.cgi?file=cooknotes">More notes</a> |
pankso@23 | 325 |
pascal@270 | 326 <a name="commits"></a> |
pankso@5 | 327 <h2>Commits</h2> |
pankso@5 | 328 <pre> |
pankso@5 | 329 $(cat $commits) |
pankso@5 | 330 </pre> |
pankso@5 | 331 |
pascal@270 | 332 <a name="cooklist"></a> |
pankso@18 | 333 <h2>Cooklist</h2> |
pankso@18 | 334 <pre> |
pankso@90 | 335 $(cat $cooklist | head -n 20) |
pankso@18 | 336 </pre> |
pankso@90 | 337 <a class="button" href="cooker.cgi?file=cooklist">Full cooklist</a> |
pankso@18 | 338 |
pascal@270 | 339 <a name="broken"></a> |
pankso@5 | 340 <h2>Broken</h2> |
pankso@5 | 341 <pre> |
pankso@66 | 342 $(cat $broken | head -n 20 | sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g) |
pankso@5 | 343 </pre> |
pankso@66 | 344 <a class="button" href="cooker.cgi?file=broken">All broken packages</a> |
pankso@5 | 345 |
pascal@270 | 346 <a name="blocked"></a> |
pankso@23 | 347 <h2>Blocked</h2> |
pankso@14 | 348 <pre> |
pankso@23 | 349 $(cat $blocked | sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g) |
pankso@14 | 350 </pre> |
pankso@14 | 351 |
pascal@270 | 352 <a name="lastcook"></a> |
pankso@5 | 353 <h2>Latest cook</h2> |
pankso@5 | 354 <pre> |
pankso@20 | 355 $(list_packages | sed s"#^\([^']*\).* : #<span class='log-date'>\0</span>#"g) |
pankso@5 | 356 </pre> |
pankso@5 | 357 EOT |
pankso@5 | 358 ;; |
pankso@5 | 359 esac |
pankso@5 | 360 |
pankso@5 | 361 # Close xHTML page |
pankso@5 | 362 cat << EOT |
pankso@5 | 363 </div> |
pankso@5 | 364 |
pankso@5 | 365 <div id="footer"> |
pankso@116 | 366 <a href="http://www.slitaz.org/">SliTaz Website</a> |
pankso@116 | 367 <a href="cooker.cgi">Cooker</a> |
pankso@116 | 368 <a href="http://hg.slitaz.org/cookutils/raw-file/tip/doc/cookutils.en.html"> |
pankso@116 | 369 Documentation</a> |
pankso@5 | 370 </div> |
pankso@5 | 371 |
pankso@5 | 372 </body> |
pankso@5 | 373 </html> |
pankso@5 | 374 EOT |
pankso@5 | 375 |
pankso@5 | 376 exit 0 |