X-Git-Url: http://git.plutz.net/?p=cgilite;a=blobdiff_plain;f=index.cgi;h=907041ee6395a89e4979b34e71b44bea47c124e5;hp=021c516c38849188473d88581406b3762d7d5be6;hb=1a1d111199b770c092e1b16a7e03568d3d911b79;hpb=b3455673aa27e118f55b91fe69a4b07c42dbe3a7 diff --git a/index.cgi b/index.cgi index 021c516..907041e 100755 --- a/index.cgi +++ b/index.cgi @@ -28,7 +28,10 @@ real="$(readlink -f $call)" export _DATA="$(dirname "$call")" #storage directory export _EXEC="${real%/shcgi/index.cgi}" #execution directory +# put debug options in the local.opts file . "$_EXEC/shcgi/misc.sh" +. "$_EXEC/shcgi/debug.sh" +[ -r "$_DATA/local.opts" ] && . "$_DATA/local.opts" if [ "$1" = '--server' -o "$1" = '--inetd' -o "$1" = '--ncat' ]; then . "$_EXEC/shcgi/server.sh" $@ @@ -36,10 +39,6 @@ else HTTP_format(){ cat } fi -# put debug options in the local.opts file -. "$_EXEC/shcgi/debug.sh" -[ -r "$_DATA/local.opts" ] && . "$_DATA/local.opts" - . "$_EXEC/shcgi/cgi.sh" [ -x "$_EXEC/globals.sh" ] && . "$_EXEC/globals.sh" @@ -48,14 +47,16 @@ fi ACTION=$(validate "${ACTION:-${_GET[action]}}" '[a-zA-Z0-9_-]+' '') STATIC=$(invalidate "${STATIC:-${_GET[static]}}" '(^|.*/)\.\./.*' '') -if [ -n "$STATIC" -a -e "${_EXEC}/static/${STATIC}" ]; then +if [ -n "$STATIC" ] && [ -e "${_EXEC}/static/${STATIC}" ]; then . "$_EXEC/shcgi/static.sh" "$_EXEC/static/$STATIC" -elif [ -n "$ACTION" -a -x "${_EXEC}/actions/${ACTION}.sh" ]; then +elif [ -n "$ACTION" ] && [ -x "${_EXEC}/actions/${ACTION}.sh" ]; then . "${_EXEC}/actions/${ACTION}.sh" -elif [ -n "$PAGE" -a -x "${_EXEC}/pages/${PAGE}.sh" ]; then +elif [ -n "$PAGE" ] && [ -x "${_EXEC}/pages/${PAGE}.sh" ]; then . "$_EXEC/shcgi/page.sh" else - printf 'HTTP/1.1 404 Not Found\r\n' + printf 'Status: 404 Not Found\r\n' PAGE=error - . "$_EXEC/shcgi/page.sh" + [ -x "${_EXEC}/pages/${PAGE}.sh" ] \ + && . "$_EXEC/shcgi/page.sh" \ + || printf '\r\n' fi |HTTP_format $@