X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=index.cgi;h=cf70a45297a8c8c1afaeb4967ddb25a8d86dcc30;hp=919cf243b963d2829313f90c12632110cdf8f3a2;hb=516b1d6b0427b42924a60bd63ed48d8087a9e4e8;hpb=815886bd4a95d4a44691f1cfd9701b8c3cecb5dc diff --git a/index.cgi b/index.cgi index 919cf24..cf70a45 100755 --- 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#/}")"; ITEM="${ITEM#/}" +ACTION="$(GET a)" -[ -w "$_EXEC" ] && [ -d "$_EXEC" ] || die "storage directory must be writable" - -echo ex: $_EXEC -echo st: $_STOR +if [ -d "${_EXEC}/${ITEM%%/*}" -a -x "${_EXEC}/${ITEM%%/*}/main.cgi" ]; then + . "${_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" ]; then +# . "$_EXEC/cgilite/file.sh" +# FILE "${_EXEC}/$ITEM" +else + printf 'Status: 404 Not Found\r\nContent-Length: 0\r\n\r\n' +fi