cookutils annotate web/cooker.cgi @ rev 62
Tiny edits
author | Paul Issott <paul@slitaz.org> |
---|---|
date | Sat May 07 15:22:01 2011 +0100 (2011-05-07) |
parents | 8fc5b2a08f0e |
children | ffb061b0826f |
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@5 | 23 |
pankso@5 | 24 # |
pankso@5 | 25 # Functions |
pankso@5 | 26 # |
pankso@5 | 27 |
pankso@5 | 28 # Put some colors in log and DB files. |
pankso@5 | 29 syntax_highlighter() { |
pankso@17 | 30 case $1 in |
pankso@17 | 31 log) |
pankso@17 | 32 sed -e 's#OK$#<span class="span-ok">OK</span>#g' \ |
pankso@17 | 33 -e 's#yes$#<span class="span-ok">yes</span>#g' \ |
pankso@17 | 34 -e 's#no$#<span class="span-no">no</span>#g' \ |
pankso@17 | 35 -e 's#error$#<span class="span-error">error</span>#g' \ |
pankso@17 | 36 -e 's#ERROR:#<span class="span-error">ERROR:</span>#g' \ |
pankso@17 | 37 -e s"#^Executing:\([^']*\).#<span class='span-sky'>\0</span>#"g \ |
pankso@17 | 38 -e s"#^====\([^']*\).#<span class='span-line'>\0</span>#"g \ |
pankso@29 | 39 -e s"#^[a-zA-Z0-9]\([^']*\) :: #<span class='span-sky'>\0</span>#"g \ |
pankso@17 | 40 -e s"#ftp://\([^']*\).*#<a href='\0'>\0</a>#"g \ |
pankso@17 | 41 -e s"#http://\([^']*\).*#<a href='\0'>\0</a>#"g ;; |
pankso@17 | 42 receipt) |
pankso@17 | 43 sed -e s"#^\#\([^']*\)#<span class='sh-comment'>\0</span>#"g \ |
pankso@17 | 44 -e s"#\"\([^']*\)\"#<span class='sh-val'>\0</span>#"g ;; |
pankso@17 | 45 esac |
pankso@5 | 46 } |
pankso@5 | 47 |
pankso@5 | 48 # Latest build pkgs. |
pankso@5 | 49 list_packages() { |
pankso@5 | 50 cd $PKGS |
pankso@5 | 51 ls -1t *.tazpkg | head -20 | \ |
pankso@5 | 52 while read file |
pankso@5 | 53 do |
pankso@5 | 54 echo -n $(stat -c '%y' $PKGS/$file | cut -d . -f 1 | sed s/:[0-9]*$//) |
pankso@5 | 55 echo " : $file" |
pankso@5 | 56 done |
pankso@5 | 57 } |
pankso@5 | 58 |
pankso@5 | 59 # xHTML header |
pankso@5 | 60 cat << EOT |
pankso@5 | 61 <!DOCTYPE html> |
pankso@5 | 62 <html xmlns="http://www.w3.org/1999/xhtml"> |
pankso@5 | 63 <head> |
pankso@5 | 64 <title>SliTaz Cooker</title> |
pankso@5 | 65 <meta charset="utf-8" /> |
pankso@5 | 66 <link rel="stylesheet" type="text/css" href="style.css" /> |
pankso@5 | 67 </head> |
pankso@5 | 68 <body> |
pankso@5 | 69 |
pankso@5 | 70 <div id="header"> |
pankso@5 | 71 <h1><a href="cooker.cgi">SliTaz Cooker</a></h1> |
pankso@5 | 72 </div> |
pankso@5 | 73 |
pankso@5 | 74 <!-- Content --> |
pankso@5 | 75 <div id="content"> |
pankso@5 | 76 EOT |
pankso@5 | 77 |
pankso@5 | 78 # |
pankso@5 | 79 # Load requested page |
pankso@5 | 80 # |
pankso@5 | 81 |
pankso@5 | 82 case "${QUERY_STRING}" in |
pankso@16 | 83 pkg=*) |
pankso@16 | 84 pkg=${QUERY_STRING#pkg=} |
pankso@16 | 85 log=$LOGS/$pkg.log |
pankso@16 | 86 echo "<h2>Package: $pkg</h2>" |
pankso@16 | 87 |
pankso@18 | 88 # Package info. |
pankso@18 | 89 echo '<div id="info">' |
pankso@16 | 90 if [ -f "$wok/$pkg/receipt" ]; then |
pankso@16 | 91 echo "<a href='cooker.cgi?receipt=$pkg'>receipt</a>" |
pankso@16 | 92 else |
pankso@18 | 93 echo "No package named: $pkg" |
pankso@16 | 94 fi |
pankso@18 | 95 echo '</div>' |
pankso@16 | 96 |
paul@62 | 97 # Check for a log file and display summary if it exists. |
pankso@16 | 98 if [ -f "$log" ]; then |
pankso@15 | 99 if fgrep -q "Summary " $LOGS/$pkg.log; then |
pankso@15 | 100 if fgrep -q "cook:$pkg$" $command; then |
pankso@15 | 101 echo "<pre>The Cooker is currently cooking: $pkg</pre>" |
pankso@16 | 102 else |
pankso@16 | 103 echo "<h3>Cook summary</h3>" |
pankso@16 | 104 echo '<pre>' |
pankso@16 | 105 grep -A 8 "^Summary " $LOGS/$pkg.log | sed /^$/d | \ |
pankso@17 | 106 syntax_highlighter log |
pankso@16 | 107 echo '</pre>' |
pankso@15 | 108 fi |
pankso@14 | 109 fi |
pankso@17 | 110 if fgrep -q "Debug " $LOGS/$pkg.log; then |
pankso@17 | 111 echo "<h3>Cook failed</h3>" |
pankso@17 | 112 echo '<pre>' |
pankso@17 | 113 grep -A 8 "^Debug " $LOGS/$pkg.log | sed /^$/d | \ |
pankso@17 | 114 syntax_highlighter log |
pankso@17 | 115 echo '</pre>' |
pankso@16 | 116 fi |
pankso@16 | 117 echo "<h3>Cook log</h3>" |
pankso@16 | 118 echo '<pre>' |
pankso@17 | 119 cat $log | syntax_highlighter log |
pankso@16 | 120 echo '</pre>' |
pankso@5 | 121 else |
pankso@16 | 122 echo "<pre>No log: $pkg</pre>" |
pankso@16 | 123 fi ;; |
pankso@16 | 124 log=*) |
pankso@16 | 125 log=${QUERY_STRING#log=} |
pankso@16 | 126 file=$LOGS/$log.log |
pankso@16 | 127 echo "<h2>Log for: $log</h2>" |
pankso@16 | 128 if [ -f "$LOGS/$log.log" ]; then |
pankso@18 | 129 if fgrep -q "Summary" $file; then |
pankso@18 | 130 echo '<pre>' |
pankso@18 | 131 grep -A 8 "^Summary" $file | sed /^$/d | \ |
pankso@18 | 132 syntax_highlighter log |
pankso@18 | 133 echo '</pre>' |
pankso@18 | 134 fi |
pankso@16 | 135 echo '<pre>' |
pankso@17 | 136 cat $file | syntax_highlighter log |
pankso@16 | 137 echo '</pre>' |
pankso@16 | 138 else |
pankso@16 | 139 echo "<pre>No log for: $log</pre>" |
pankso@16 | 140 fi ;; |
pankso@16 | 141 receipt=*) |
pankso@16 | 142 pkg=${QUERY_STRING#receipt=} |
pankso@17 | 143 echo "<h2>Receipt for: $pkg</h2>" |
pankso@16 | 144 if [ -f "$wok/$pkg/receipt" ]; then |
pankso@16 | 145 echo '<pre>' |
pankso@17 | 146 cat $wok/$pkg/receipt | syntax_highlighter receipt |
pankso@16 | 147 echo '</pre>' |
pankso@16 | 148 else |
pankso@16 | 149 echo "<pre>No receipt for: $log</pre>" |
pankso@5 | 150 fi ;; |
pankso@5 | 151 *) |
pankso@5 | 152 cat << EOT |
pankso@5 | 153 <div style="float: right;"> |
pankso@5 | 154 <form method="get" action="$SCRIPT_NAME"> |
pankso@16 | 155 Package: |
pankso@16 | 156 <input type="text" name="pkg" /> |
pankso@5 | 157 </form> |
pankso@5 | 158 </div> |
pankso@5 | 159 |
pankso@5 | 160 <h2>Summary</h2> |
pankso@5 | 161 <pre> |
pankso@16 | 162 Running command : $([ -s "$command" ] && cat $command || echo "Not running") |
pankso@5 | 163 Cooked packages : $(ls $PKGS/*.tazpkg | wc -l) |
pankso@5 | 164 Packages in wok : $(ls $WOK | wc -l) |
pankso@5 | 165 Wok revision : <a href="http://hg.slitaz.org/wok">$(cd $WOK && hg head --template '{rev}\n')</a> |
pankso@5 | 166 Commits to cook : $(cat $commits | wc -l) |
pankso@5 | 167 Broken packages : $(cat $broken | wc -l) |
pankso@5 | 168 </pre> |
pankso@5 | 169 |
pankso@18 | 170 <div id="info"> |
pankso@18 | 171 Latest logs: <a href="cooker.cgi?log=cookorder">cookorder</a> |
pankso@18 | 172 <a href="cooker.cgi?log=commits">commits</a> |
pankso@14 | 173 </div> |
pankso@14 | 174 |
pankso@5 | 175 <h2>Activity</h2> |
pankso@5 | 176 <pre> |
pankso@16 | 177 $(tac $CACHE/activity | sed s"#^\([^']* : \)#<span class='log-date'>\0</span>#"g) |
pankso@5 | 178 </pre> |
pankso@5 | 179 |
pankso@23 | 180 <h2>Cooknotes</h2> |
pankso@23 | 181 <pre> |
pankso@23 | 182 $(cat $cooknotes) |
pankso@23 | 183 </pre> |
pankso@23 | 184 |
pankso@5 | 185 <h2>Commits</h2> |
pankso@5 | 186 <pre> |
pankso@5 | 187 $(cat $commits) |
pankso@5 | 188 </pre> |
pankso@5 | 189 |
pankso@18 | 190 <h2>Cooklist</h2> |
pankso@18 | 191 <pre> |
pankso@18 | 192 $(cat $cooklist) |
pankso@18 | 193 </pre> |
pankso@18 | 194 |
pankso@5 | 195 <h2>Broken</h2> |
pankso@5 | 196 <pre> |
pankso@23 | 197 $(cat $broken | sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g) |
pankso@5 | 198 </pre> |
pankso@5 | 199 |
pankso@23 | 200 <h2>Blocked</h2> |
pankso@14 | 201 <pre> |
pankso@23 | 202 $(cat $blocked | sed s"#^[^']*#<a href='cooker.cgi?pkg=\0'>\0</a>#"g) |
pankso@14 | 203 </pre> |
pankso@14 | 204 |
pankso@5 | 205 <h2>Latest cook</h2> |
pankso@5 | 206 <pre> |
pankso@20 | 207 $(list_packages | sed s"#^\([^']*\).* : #<span class='log-date'>\0</span>#"g) |
pankso@5 | 208 </pre> |
pankso@5 | 209 EOT |
pankso@5 | 210 ;; |
pankso@5 | 211 esac |
pankso@5 | 212 |
pankso@5 | 213 # Close xHTML page |
pankso@5 | 214 cat << EOT |
pankso@5 | 215 </div> |
pankso@5 | 216 |
pankso@5 | 217 <div id="footer"> |
pankso@15 | 218 <a href="cooker.cgi">SliTaz Cooker</a> |
pankso@5 | 219 </div> |
pankso@5 | 220 |
pankso@5 | 221 </body> |
pankso@5 | 222 </html> |
pankso@5 | 223 EOT |
pankso@5 | 224 |
pankso@5 | 225 exit 0 |