cookutils annotate web/cooker.cgi @ rev 256
Tiny edits
author | Paul Issott <paul@slitaz.org> |
---|---|
date | Sun May 29 21:00:54 2011 +0100 (2011-05-29) |
parents | edcda368442c |
children | 4ceceb22dc35 |
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 echo "Content-Type: text/html" |
pankso@5 | 6 echo "" |
pankso@5 | 7 |
pankso@5 | 8 [ -f "/etc/slitaz/cook.conf" ] && . /etc/slitaz/cook.conf |
pankso@5 | 9 [ -f "cook.conf" ] && . ./cook.conf |
pankso@5 | 10 |
pankso@5 | 11 # The same wok as cook. |
pankso@5 | 12 wok="$WOK" |
pankso@5 | 13 |
pankso@5 | 14 # Cooker DB files. |
pankso@5 | 15 activity="$CACHE/activity" |
pankso@5 | 16 commits="$CACHE/commits" |
pankso@5 | 17 cooklist="$CACHE/cooklist" |
pankso@5 | 18 cookorder="$CACHE/cookorder" |
pankso@14 | 19 command="$CACHE/command" |
pankso@5 | 20 blocked="$CACHE/blocked" |
pankso@5 | 21 broken="$CACHE/broken" |
pankso@22 | 22 cooknotes="$CACHE/cooknotes" |
pankso@164 | 23 wokrev="$CACHE/wokrev" |
pankso@5 | 24 |
paul@256 | 25 # We're not logged and want time zone to display correct server date. |
pankso@249 | 26 export TZ=$(cat /etc/TZ) |
pankso@249 | 27 |
pankso@5 | 28 # |
pankso@5 | 29 # Functions |
pankso@5 | 30 # |
pankso@5 | 31 |
pankso@5 | 32 # Put some colors in log and DB files. |
pankso@5 | 33 syntax_highlighter() { |
pankso@17 | 34 case $1 in |
pankso@17 | 35 log) |
pankso@17 | 36 sed -e 's#OK$#<span class="span-ok">OK</span>#g' \ |
pankso@17 | 37 -e 's#yes$#<span class="span-ok">yes</span>#g' \ |
pankso@17 | 38 -e 's#no$#<span class="span-no">no</span>#g' \ |
pankso@129 | 39 -e 's#error$#<span class="span-red">error</span>#g' \ |
pankso@129 | 40 -e 's#ERROR:#<span class="span-red">ERROR:</span>#g' \ |
pankso@129 | 41 -e 's#WARNING:#<span class="span-red">WARNING:</span>#g' \ |
pankso@65 | 42 -e s"#^Executing:\([^']*\).#<span class='sh-val'>\0</span>#"g \ |
pankso@17 | 43 -e s"#^====\([^']*\).#<span class='span-line'>\0</span>#"g \ |
pankso@29 | 44 -e s"#^[a-zA-Z0-9]\([^']*\) :: #<span class='span-sky'>\0</span>#"g \ |
pankso@17 | 45 -e s"#ftp://\([^']*\).*#<a href='\0'>\0</a>#"g \ |
pankso@17 | 46 -e s"#http://\([^']*\).*#<a href='\0'>\0</a>#"g ;; |
pankso@17 | 47 receipt) |
pankso@17 | 48 sed -e s"#^\#\([^']*\)#<span class='sh-comment'>\0</span>#"g \ |
pankso@17 | 49 -e s"#\"\([^']*\)\"#<span class='sh-val'>\0</span>#"g ;; |
pankso@129 | 50 diff) |
pankso@129 | 51 sed -e 's|&|\&|g' -e 's|<|\<|g' -e 's|>|\>|g' \ |
pankso@129 | 52 -e s"#^-\([^']*\).#<span class='span-red'>\0</span>#"g \ |
pankso@129 | 53 -e s"#^+\([^']*\).#<span class='span-ok'>\0</span>#"g \ |
pankso@129 | 54 -e s"#@@\([^']*\)@@#<span class='span-sky'>@@\1@@</span>#"g ;; |
pankso@129 | 55 activity) |
pankso@129 | 56 sed s"#^\([^']* : \)#<span class='log-date'>\0</span>#"g ;; |
pankso@17 | 57 esac |
pankso@5 | 58 } |
pankso@5 | 59 |
pankso@5 | 60 # Latest build pkgs. |
pankso@5 | 61 list_packages() { |
pankso@5 | 62 cd $PKGS |
pankso@5 | 63 ls -1t *.tazpkg | head -20 | \ |
pankso@5 | 64 while read file |
pankso@5 | 65 do |
pankso@5 | 66 echo -n $(stat -c '%y' $PKGS/$file | cut -d . -f 1 | sed s/:[0-9]*$//) |
pankso@5 | 67 echo " : $file" |
pankso@5 | 68 done |
pankso@5 | 69 } |
pankso@5 | 70 |
pankso@253 | 71 # xHTML header. Pages can be customized with a separated html.header file. |
pankso@253 | 72 if [ -f "header.html" ]; then |
pankso@253 | 73 cat header.html |
pankso@253 | 74 else |
pankso@253 | 75 cat << EOT |
pankso@5 | 76 <!DOCTYPE html> |
pankso@5 | 77 <html xmlns="http://www.w3.org/1999/xhtml"> |
pankso@5 | 78 <head> |
pankso@5 | 79 <title>SliTaz Cooker</title> |
pankso@5 | 80 <meta charset="utf-8" /> |
pankso@252 | 81 <link rel="shortcut icon" href="favicon.ico" /> |
pankso@5 | 82 <link rel="stylesheet" type="text/css" href="style.css" /> |
pankso@5 | 83 </head> |
pankso@5 | 84 <body> |
pankso@5 | 85 |
pankso@5 | 86 <div id="header"> |
pankso@253 | 87 <div id="logo"></div> |
pankso@5 | 88 <h1><a href="cooker.cgi">SliTaz Cooker</a></h1> |
pankso@5 | 89 </div> |
pankso@5 | 90 |
pankso@5 | 91 <!-- Content --> |
pankso@5 | 92 <div id="content"> |
pankso@5 | 93 EOT |
pankso@253 | 94 fi |
pankso@5 | 95 |
pankso@5 | 96 # |
pankso@5 | 97 # Load requested page |
pankso@5 | 98 # |
pankso@5 | 99 |
pankso@5 | 100 case "${QUERY_STRING}" in |
pankso@16 | 101 pkg=*) |
pankso@16 | 102 pkg=${QUERY_STRING#pkg=} |
pankso@16 | 103 log=$LOGS/$pkg.log |
pankso@16 | 104 echo "<h2>Package: $pkg</h2>" |
pankso@16 | 105 |
pankso@18 | 106 # Package info. |
pankso@18 | 107 echo '<div id="info">' |
pankso@16 | 108 if [ -f "$wok/$pkg/receipt" ]; then |
pankso@16 | 109 echo "<a href='cooker.cgi?receipt=$pkg'>receipt</a>" |
pankso@16 | 110 else |
pankso@18 | 111 echo "No package named: $pkg" |
pankso@16 | 112 fi |
pankso@18 | 113 echo '</div>' |
pankso@16 | 114 |
paul@62 | 115 # Check for a log file and display summary if it exists. |
pankso@16 | 116 if [ -f "$log" ]; then |
pankso@87 | 117 if grep -q "cook:$pkg$" $command; then |
pankso@88 | 118 echo "<pre>The Cooker is currently building: $pkg</pre>" |
pankso@87 | 119 fi |
pankso@149 | 120 if fgrep -q "Summary for:" $LOGS/$pkg.log; then |
pankso@87 | 121 echo "<h3>Cook summary</h3>" |
pankso@87 | 122 echo '<pre>' |
pankso@149 | 123 grep -A 8 "^Summary for:" $LOGS/$pkg.log | sed /^$/d | \ |
pankso@87 | 124 syntax_highlighter log |
pankso@87 | 125 echo '</pre>' |
pankso@14 | 126 fi |
pankso@149 | 127 if fgrep -q "Debug information" $LOGS/$pkg.log; then |
pankso@17 | 128 echo "<h3>Cook failed</h3>" |
pankso@17 | 129 echo '<pre>' |
pankso@149 | 130 grep -A 8 "^Debug information" $LOGS/$pkg.log | sed /^$/d | \ |
pankso@17 | 131 syntax_highlighter log |
pankso@17 | 132 echo '</pre>' |
pankso@16 | 133 fi |
pankso@16 | 134 echo "<h3>Cook log</h3>" |
pankso@16 | 135 echo '<pre>' |
pankso@17 | 136 cat $log | syntax_highlighter log |
pankso@16 | 137 echo '</pre>' |
pankso@5 | 138 else |
pankso@16 | 139 echo "<pre>No log: $pkg</pre>" |
pankso@16 | 140 fi ;; |
pankso@65 | 141 file=*) |
paul@89 | 142 # Dont allow all files on the system for security reasons. |
pankso@65 | 143 file=${QUERY_STRING#file=} |
pankso@65 | 144 case "$file" in |
pankso@90 | 145 activity|cooknotes|cooklist) |
pankso@91 | 146 [ "$file" == "cooklist" ] && \ |
pankso@93 | 147 nb="- Packages: $(cat $cooklist | wc -l)" |
pankso@91 | 148 echo "<h2>DB: $file $nb</h2>" |
pankso@18 | 149 echo '<pre>' |
pankso@129 | 150 tac $CACHE/$file | syntax_highlighter activity |
pankso@65 | 151 echo '</pre>' ;; |
pankso@66 | 152 broken) |
pankso@66 | 153 nb=$(cat $broken | wc -l) |
pankso@93 | 154 echo "<h2>DB: broken - Packages: $nb</h2>" |
pankso@66 | 155 echo '<pre>' |
pankso@129 | 156 cat $CACHE/$file | sort | \ |
pankso@66 | 157 sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g |
pankso@66 | 158 echo '</pre>' ;; |
pankso@129 | 159 *.diff) |
pankso@129 | 160 diff=$CACHE/$file |
pankso@129 | 161 echo "<h2>Diff for: ${file%.diff}</h2>" |
pankso@129 | 162 [ "$file" == "installed.diff" ] && echo \ |
pankso@129 | 163 "<p>This is the latest diff between installed packages \ |
pankso@130 | 164 and installed build dependencies to cook.</p>" |
pankso@129 | 165 echo '<pre>' |
pankso@129 | 166 cat $diff | syntax_highlighter diff |
pankso@129 | 167 echo '</pre>' ;; |
pankso@65 | 168 *.log) |
pankso@71 | 169 log=$LOGS/$file |
pankso@71 | 170 name=$(basename $log) |
pankso@65 | 171 echo "<h2>Log for: ${name%.log}</h2>" |
pankso@71 | 172 if [ -f "$log" ]; then |
pankso@71 | 173 if fgrep -q "Summary" $log; then |
pankso@65 | 174 echo '<pre>' |
pankso@73 | 175 grep -A 20 "^Summary" $log | sed /^$/d | \ |
pankso@65 | 176 syntax_highlighter log |
pankso@65 | 177 echo '</pre>' |
pankso@65 | 178 fi |
pankso@65 | 179 echo '<pre>' |
pankso@71 | 180 cat $log | syntax_highlighter log |
pankso@65 | 181 echo '</pre>' |
pankso@65 | 182 else |
pankso@71 | 183 echo "<pre>No log file: $log</pre>" |
pankso@65 | 184 fi ;; |
pankso@65 | 185 esac ;; |
pankso@16 | 186 receipt=*) |
pankso@16 | 187 pkg=${QUERY_STRING#receipt=} |
pankso@17 | 188 echo "<h2>Receipt for: $pkg</h2>" |
pankso@16 | 189 if [ -f "$wok/$pkg/receipt" ]; then |
pankso@16 | 190 echo '<pre>' |
pankso@17 | 191 cat $wok/$pkg/receipt | syntax_highlighter receipt |
pankso@16 | 192 echo '</pre>' |
pankso@16 | 193 else |
pankso@16 | 194 echo "<pre>No receipt for: $log</pre>" |
pankso@5 | 195 fi ;; |
pankso@5 | 196 *) |
pankso@75 | 197 # Main page with summary. |
pankso@105 | 198 inwok=$(ls $WOK | wc -l) |
pankso@75 | 199 cooked=$(ls $PKGS/*.tazpkg | wc -l) |
pankso@106 | 200 unbuilt=$(($inwok - $cooked)) |
pankso@245 | 201 pct=0 |
pankso@245 | 202 [ $inwok -gt 0 ] && pct=$(( ($cooked * 100) / $inwok )) |
pankso@5 | 203 cat << EOT |
pankso@5 | 204 <div style="float: right;"> |
pankso@5 | 205 <form method="get" action="$SCRIPT_NAME"> |
pankso@16 | 206 Package: |
pankso@16 | 207 <input type="text" name="pkg" /> |
pankso@5 | 208 </form> |
pankso@5 | 209 </div> |
pankso@5 | 210 |
pankso@5 | 211 <h2>Summary</h2> |
pankso@75 | 212 |
pankso@5 | 213 <pre> |
pankso@16 | 214 Running command : $([ -s "$command" ] && cat $command || echo "Not running") |
pankso@164 | 215 Wok revision : <a href="http://hg.slitaz.org/wok">$(cat $wokrev)</a> |
pankso@5 | 216 Commits to cook : $(cat $commits | wc -l) |
pankso@65 | 217 Current cooklist : $(cat $cooklist | wc -l) |
pankso@5 | 218 Broken packages : $(cat $broken | wc -l) |
pankso@95 | 219 Blocked packages : $(cat $blocked | wc -l) |
pankso@5 | 220 </pre> |
pankso@5 | 221 |
pankso@75 | 222 <p> |
pankso@247 | 223 Packages: $inwok in the wok - $cooked cooked - $unbuilt unbuilt - |
pankso@247 | 224 Server date: $(date '+%Y-%m-%d %H:%M') |
pankso@75 | 225 </p> |
pankso@75 | 226 <div class="pctbar"> |
pankso@75 | 227 <div class="pct" style="width: ${pct}%;">${pct}%</div> |
pankso@14 | 228 </div> |
pankso@14 | 229 |
pankso@75 | 230 <p> |
pankso@129 | 231 Latest: |
pankso@129 | 232 <a href="cooker.cgi?file=cookorder.log">cookorder.log</a> |
pankso@129 | 233 <a href="cooker.cgi?file=commits.log">commits.log</a> |
pankso@129 | 234 <a href="cooker.cgi?file=installed.diff">installed.diff</a> |
pankso@188 | 235 - Architecture $ARCH: |
pankso@186 | 236 <a href="cooker.cgi?pkg=slitaz-toolchain">toolchain.log</a> |
pankso@75 | 237 </p> |
pankso@75 | 238 |
pankso@5 | 239 <h2>Activity</h2> |
pankso@5 | 240 <pre> |
pankso@129 | 241 $(tac $CACHE/activity | head -n 12 | syntax_highlighter activity) |
pankso@5 | 242 </pre> |
pankso@65 | 243 <a class="button" href="cooker.cgi?file=activity">More activity</a> |
pankso@5 | 244 |
pankso@23 | 245 <h2>Cooknotes</h2> |
pankso@23 | 246 <pre> |
pankso@129 | 247 $(tac $cooknotes | head -n 12 | syntax_highlighter activity) |
pankso@23 | 248 </pre> |
pankso@65 | 249 <a class="button" href="cooker.cgi?file=cooknotes">More notes</a> |
pankso@23 | 250 |
pankso@5 | 251 <h2>Commits</h2> |
pankso@5 | 252 <pre> |
pankso@5 | 253 $(cat $commits) |
pankso@5 | 254 </pre> |
pankso@5 | 255 |
pankso@18 | 256 <h2>Cooklist</h2> |
pankso@18 | 257 <pre> |
pankso@90 | 258 $(cat $cooklist | head -n 20) |
pankso@18 | 259 </pre> |
pankso@90 | 260 <a class="button" href="cooker.cgi?file=cooklist">Full cooklist</a> |
pankso@18 | 261 |
pankso@5 | 262 <h2>Broken</h2> |
pankso@5 | 263 <pre> |
pankso@66 | 264 $(cat $broken | head -n 20 | sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g) |
pankso@5 | 265 </pre> |
pankso@66 | 266 <a class="button" href="cooker.cgi?file=broken">All broken packages</a> |
pankso@5 | 267 |
pankso@23 | 268 <h2>Blocked</h2> |
pankso@14 | 269 <pre> |
pankso@23 | 270 $(cat $blocked | sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g) |
pankso@14 | 271 </pre> |
pankso@14 | 272 |
pankso@5 | 273 <h2>Latest cook</h2> |
pankso@5 | 274 <pre> |
pankso@20 | 275 $(list_packages | sed s"#^\([^']*\).* : #<span class='log-date'>\0</span>#"g) |
pankso@5 | 276 </pre> |
pankso@5 | 277 EOT |
pankso@5 | 278 ;; |
pankso@5 | 279 esac |
pankso@5 | 280 |
pankso@5 | 281 # Close xHTML page |
pankso@5 | 282 cat << EOT |
pankso@5 | 283 </div> |
pankso@5 | 284 |
pankso@5 | 285 <div id="footer"> |
pankso@116 | 286 <a href="http://www.slitaz.org/">SliTaz Website</a> |
pankso@116 | 287 <a href="cooker.cgi">Cooker</a> |
pankso@116 | 288 <a href="http://hg.slitaz.org/cookutils/raw-file/tip/doc/cookutils.en.html"> |
pankso@116 | 289 Documentation</a> |
pankso@5 | 290 </div> |
pankso@5 | 291 |
pankso@5 | 292 </body> |
pankso@5 | 293 </html> |
pankso@5 | 294 EOT |
pankso@5 | 295 |
pankso@5 | 296 exit 0 |