X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=index.cgi;h=5dc55be28dab259b079cb0e6d247249e0f93cdc8;hp=def6da0b4c8f72797bab10e7af5cc7bc03ff5e27;hb=c0302919c54331fc9fe3785f7d2a44e639e1bba0;hpb=c778a3abd05946586813bb0b676e04b616d294a4 diff --git a/index.cgi b/index.cgi index def6da0..5dc55be 100755 --- a/index.cgi +++ b/index.cgi @@ -1,51 +1,81 @@ -#!/bin/zsh +#!/bin/sh -# basic functions -die() { - echo "$*" >/dev/stderr - exit 1 -} -debug() { #change to false to disable debugging - #true && echo "$*" >>debug - true && [ -n "$*" ] && echo -E "$*" >>/dev/stderr - true && [ -z "$*" ] && tee /dev/stderr -} +for n in "$@"; do case ${n%%=*} in + data) _DATA="${n#data=}";; + exec) _EXEC="${n#exec=}";; + noerr) exec 2>&-;; +esac; done -# this program is supposed to be symlinked into a http root directory -# we will use the http root as object storage (data directory) and call sub -# programs from the directory in which the real executable resides -# therefore we need to identify the code and data directories _EXEC and _DATA -call=$0 -real=$call -while [ -L "$real" ]; do - real="$(stat -c %N "$real" |sed -r "s:..*. -> .(.*).$:\1:")" -done +[ -z "${_EXEC%/}" ] && _EXEC="$(realpath "${0%/*}")" || _EXEC="${_EXEC%/}" +[ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}" -_EXEC="$(dirname "$real")" #execution directory -_DATA="$(dirname "$call")" #storage directory +debug() { + local dbg=/dev/stderr + if [ ! "$DEBUG" ]; then + [ "$#" -gt 0 ] && : || cat; + elif [ "$#" -gt 0 ]; then + printf '%s\n' "$@" >>"$dbg" + else + tee -a "$dbg" + fi +} -debug "Execution dir: $_EXEC" -debug "Storage dir: $_DATA" +. "$_EXEC/cgilite/cgilite.sh" +. "$_EXEC/cgilite/session.sh" -[ -w "$_DATA" ] && [ -d "$_DATA" ] || die "storage directory must be writable" +_PATH="$(PATH "/${PATH_INFO}")" +ACTION="$(GET a)" -# create directories for object storage -for each in "$_DATA"/{vcard,mappings,courses,cache}; do - [ ! -e "$each" ] && mkdir "$each" - [ -w "$each" ] && [ -d "$each" ] || die "storage $each must be a writable directory" -done +message="$(COOKIE message)" +[ "$message" ] && SET_COOKIE 0 message='' -# create htaccess file -[ -f .htaccess ] || cat >.htaccess </dev/null +} +selected(){ + if [ "$1" = "$2" ] || [ "$1" -eq "$2" ]; then + printf 'selected="selected"' + fi 2>/dev/null +} -. "$_EXEC/cgi.sh" +yield_page() { + local class="$1" style="$2" + printf 'Content-Type: text/html; charset=utf-8\r\n\r\n' + { printf ' + [html [head + [title Confetti] + [meta name="viewport" content="width=device-width"] + [link rel="stylesheet" type="text/css" href="/style.css"] + ' + [ -n "$style" ] && printf ' + [link rel="stylesheet" type="text/css" href="%s"] + ' "$style" + printf ' + ] [body #top class="%s" + ' "$class" + cat + [ "$message" ] && printf '[p #message\n%s\n]' "$(l10n "$message")" + printf '] ]' + } \ + | "${_EXEC}/cgilite/html-sh.sed" +} -cgi_get -debug "$_GET" +topdir="${_PATH#/}" +topdir="/${topdir%%/*}" -. "$_EXEC/page.sh" +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