]> git.plutz.net Git - confetti/blobdiff - index.cgi
touch course file (invalidate cache) when updating attendance in vcard
[confetti] / index.cgi
index 170645f4c3d1d733f1b5173d710e1c5eedcd3ac5..5dc55be28dab259b079cb0e6d247249e0f93cdc8 100755 (executable)
--- a/index.cgi
+++ b/index.cgi
@@ -2,13 +2,24 @@
 
 for n in "$@"; do case ${n%%=*} in
   data) _DATA="${n#data=}";;
-  exec) _exec="${n#exec=}";;
+  exec) _EXEC="${n#exec=}";;
   noerr) exec 2>&-;;
 esac; done
 
 [ -z "${_EXEC%/}" ] && _EXEC="$(realpath "${0%/*}")" || _EXEC="${_EXEC%/}"
 [ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}"
 
+debug() {
+  local dbg=/dev/stderr
+  if [ ! "$DEBUG" ]; then
+    [ "$#" -gt 0 ] && : || cat;
+  elif [ "$#" -gt 0 ]; then
+    printf '%s\n' "$@" >>"$dbg"
+  else
+    tee -a "$dbg"
+  fi
+}
+
 . "$_EXEC/cgilite/cgilite.sh"
 . "$_EXEC/cgilite/session.sh"
 
@@ -18,6 +29,17 @@ ACTION="$(GET a)"
 message="$(COOKIE message)"
 [ "$message" ] && SET_COOKIE 0 message=''
 
+checked(){
+  if [ "$1" = "$2" ] || [ "$1" -eq "$2" ]; then
+    printf 'checked="checked"'
+  fi 2>/dev/null
+}
+selected(){
+  if [ "$1" = "$2" ] || [ "$1" -eq "$2" ]; then
+    printf 'selected="selected"'
+  fi 2>/dev/null
+}
+
 yield_page() {
   local class="$1" style="$2"
   printf 'Content-Type: text/html; charset=utf-8\r\n\r\n'
@@ -31,22 +53,29 @@ yield_page() {
          [link rel="stylesheet" type="text/css" href="%s"]
     ' "$style"
     printf '
-       ] [body class="%s"
+       ] [body #top class="%s"
     ' "$class"
     cat
-    [ "$message" ] && printf '[p #message\n%s\n]' $(l10n "$message")
+    [ "$message" ] && printf '[p #message\n%s\n]' "$(l10n "$message")"
     printf '] ]'
   } \
   | "${_EXEC}/cgilite/html-sh.sed"
 }
 
-if   [   -d "${_EXEC}/${_PATH}" -a -x "${_EXEC}/${_PATH}/main.cgi" ]; then
-  . "${_EXEC}/${_PATH}/main.cgi"
+topdir="${_PATH#/}"
+topdir="/${topdir%%/*}"
+
+if [ "${_PATH}" = / ]; then
+  REDIRECT /cards/
+elif   [   -d "${_EXEC}/${_PATH}" -a -x "${_EXEC}/${_PATH}/index.cgi" ]; then
+  . "${_EXEC}/${_PATH}/index.cgi"
 elif [ ! -d "${_EXEC}/${_PATH}" -a -x "${_EXEC}/${_PATH}" ]; then
   . "${_EXEC}/${_PATH}"
 elif [ ! -x "${_EXEC}/${_PATH}" -a -r "${_EXEC}/${_PATH}" ]; then
   . "$_EXEC/cgilite/file.sh"
   FILE "${_EXEC}/${_PATH}"
+elif   [   -d "${_EXEC}/${topdir}" -a -x "${_EXEC}/${topdir}/index.cgi" ]; then
+  . "${_EXEC}/${topdir}/index.cgi"
 else
   printf 'Status: 404 Not Found\r\nContent-Length: 0\r\n\r\n'
 fi