]> git.plutz.net Git - confetti/blobdiff - index.cgi
changed project layout
[confetti] / index.cgi
index 919cf243b963d2829313f90c12632110cdf8f3a2..e0bf125ec5c1ad6f4d7501d76cb5c3aaa09ae0f2 100755 (executable)
--- a/index.cgi
+++ b/index.cgi
@@ -1,21 +1,31 @@
-#!/bin/zsh
+#!/bin/sh
 
-call=$0
-real=$call
+for n in "$@"; do case ${n%%=*} in
+  data) _DATA="${n#data=}";;
+  exec) _exec="${n#exec=}";;
+  noerr) exec 2>&-;;
+esac; done
 
-die() {
-  echo "$*" >/dev/stderr
-  exit 1
-}
+[ -z "${_EXEC%/}" ] && _EXEC="$(realpath "${0%/*}")" || _EXEC="${_EXEC%/}"
+[ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}"
 
-while [ -L "$real" ]; do
-  real="$(stat -c %N "$real" |sed -r "s:..*. -> .(.*).$:\1:")"
-done
+. "$_EXEC/cgilite/cgilite.sh"
 
-_EXEC="$(dirname "$real")"  #execution directory
-_STOR="$(dirname "$call")"  #storage directory
+FILTER="$(GET filter)"
+ORDER="$(GET o |grep -m1 -axE 'firstname|lastname|bdate' || printf firstname)"
+# LISTSIZE="$(COOKIE pagesize |grep -m1 -axE '[1-9][0-9]*' || printf 50)"
+ITEM="$(PATH "${PATH_INFO#/}")"
+ACTION="$(GET a)"
 
-[ -w "$_EXEC" ] && [ -d "$_EXEC" ] || die "storage directory must be writable"
-
-echo ex: $_EXEC
-echo st: $_STOR
+if [ -d "${_EXEC}/${ITEM%%/*}/main.cgi" ]
+  . "${_EXEC}/${ITEM%%/*}/main.cgi"
+elif [ "$ITEM" = "/style.css" ]; then
+  . "$_EXEC/cgilite/file.sh"
+  [ -r "$_DATA/$ITEM" ] && FILE "$_DATA/$ITEM" \
+                        || FILE "$_EXEC/style.css"
+elif [ -d "${_EXEC}/${ITEM%%/*}" -a ! -x "${_EXEC}/$ITEM" ]
+  . "$_EXEC/cgilite/file.sh"
+  FILE "${_EXEC}/$ITEM"
+else
+  printf 'Status: 404 Not Found\r\nContent-Length: 0\r\n\r\n'
+fi