X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=index.cgi;h=119228e116befd523332bcf4137d719f4beb2f6e;hp=327135f8f21529e9cb029bba29b530e3a22a5ad8;hb=804ecf70ec21f803334b09cc223aedb41d51c610;hpb=2dc9740e1452127d64d027b57432032242f04eff diff --git a/index.cgi b/index.cgi index 327135f..119228e 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 @@ -7,7 +9,7 @@ die() { } debug() { #change to false to disable debugging #true && echo "$*" >>debug - true && [ -n "$*" ] && echo "$*" >>/dev/stderr + true && [ -n "$*" ] && echo -E "$*" >>/dev/stderr true && [ -z "$*" ] && tee /dev/stderr } @@ -15,25 +17,19 @@ 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}; do +for each in "$_DATA"/{vcard,ical,cache,temp,mappings}; do [ ! -e "$each" ] && mkdir "$each" [ -w "$each" ] && [ -d "$each" ] || die "storage $each must be a writable directory" done +touch "$_DATA/mappings/attendance" # create htaccess file [ -f .htaccess ] || cat >.htaccess <