X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=index.cgi;h=427307118ba657f56ceb7e6bad18087393e6a897;hp=92310fd95cb10b877f25fe2b4a5a56e7588f7449;hb=bd9f9ebbf0add55cbba9d47691aad87504284570;hpb=9917259ba7ae33000a3aeb892f392ed71ad0377d diff --git a/index.cgi b/index.cgi index 92310fd..4273071 100755 --- a/index.cgi +++ b/index.cgi @@ -1,5 +1,7 @@ #!/bin/zsh +export LC_ALL=de_DE.UTF-8 + # basic functions die() { echo "$*" >/dev/stderr @@ -15,22 +17,15 @@ debug() { #change to false to disable debugging # 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 - +call="$0" +real="$(readlink -f $call)" _EXEC="$(dirname "$real")" #execution directory _DATA="$(dirname "$call")" #storage directory -debug "Execution dir: $_EXEC" -debug "Storage dir: $_DATA" - [ -w "$_DATA" ] && [ -d "$_DATA" ] || die "storage directory must be writable" # create directories for object storage -for each in "$_DATA"/{vcard,mappings,courses,cache,temp}; do +for each in "$_DATA"/{vcard,ical,cache,temp}; do [ ! -e "$each" ] && mkdir "$each" [ -w "$each" ] && [ -d "$each" ] || die "storage $each must be a writable directory" done @@ -46,6 +41,13 @@ EOF . "$_EXEC/cgi.sh" cgi_get -debug "$_GET" -[ -n "$_GET[\"action\"]" ] && . "$_EXEC/action.sh" || . "$_EXEC/page.sh" +. "$_EXEC/constants.sh" + +if [ -n "$_GET[\"action\"]" ]; then + . "$_EXEC/action.sh" +elif [ -n "$_GET[\"export\"]" ]; then + . "$_EXEC/export.sh" +else + . "$_EXEC/page.sh" +fi