X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=index.cgi;h=119228e116befd523332bcf4137d719f4beb2f6e;hp=919cf243b963d2829313f90c12632110cdf8f3a2;hb=002b2558e02b14bf2dbcd3ba5ec039d22bac2d69;hpb=815886bd4a95d4a44691f1cfd9701b8c3cecb5dc diff --git a/index.cgi b/index.cgi index 919cf24..119228e 100755 --- a/index.cgi +++ b/index.cgi @@ -1,21 +1,54 @@ #!/bin/zsh -call=$0 -real=$call +export LC_ALL=de_DE.UTF-8 +# 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 +} + +# 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="$(readlink -f $call)" +_EXEC="$(dirname "$real")" #execution directory +_DATA="$(dirname "$call")" #storage directory + +[ -w "$_DATA" ] && [ -d "$_DATA" ] || die "storage directory must be writable" -while [ -L "$real" ]; do - real="$(stat -c %N "$real" |sed -r "s:..*. -> .(.*).$:\1:")" +# create directories for object storage +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" -_EXEC="$(dirname "$real")" #execution directory -_STOR="$(dirname "$call")" #storage directory +# create htaccess file +[ -f .htaccess ] || cat >.htaccess <