X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=index.cgi;h=9d9a3e7090f3441b760c321d16407be17cb0e4e0;hb=3e174383701ddbfb7d4dee4c350e30387b1770f4;hp=b52ba72723f7021d10dd66a96dfa20ef137aba63;hpb=88f480fb0141fcbff7ad1097341a0cbf1d48b1d1;p=lobster diff --git a/index.cgi b/index.cgi index b52ba72..9d9a3e7 100755 --- a/index.cgi +++ b/index.cgi @@ -9,6 +9,16 @@ esac; done [ -z "${_EXEC%/}" ] && _EXEC="$(realpath "${0%/*}")" || _EXEC="${_EXEC%/}" [ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}" +# debug() { +# local dbg=/dev/stderr +# if [ "$#" -gt 0 ]; then +# printf '%s\n' "$@" >>"$dbg" +# else +# tee -a "$dbg" +# fi +# } +debug() { [ "$#" -gt 0 ] && : || cat; } + . "$_EXEC/cgilite/cgilite.sh" . "$_EXEC/cgilite/session.sh" @@ -54,8 +64,8 @@ yield_page() { topdir="${_PATH#/}" topdir="/${topdir%%/*}" -if [ -d "${_EXEC}/${topdir}" -a -x "${_EXEC}/${topdir}/index.cgi" ]; then - . "${_EXEC}/${topdir}/index.cgi" +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 @@ -63,6 +73,8 @@ elif [ ! -d "${_EXEC}/${_PATH}" -a -x "${_EXEC}/${_PATH}" ]; then 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