X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=index.cgi;h=a7edbb1186378b7584e1e23e6b39a8f0aa906b19;hp=4d050e8700c19407fc2c85a8082109077a958d7a;hb=3badbe5f34b9a481f43f83d07d4cd28a3aa7798b;hpb=9d7c6eae1ee756c1ba53d80e7b134fa1f3a1f0b4 diff --git a/index.cgi b/index.cgi index 4d050e8..a7edbb1 100755 --- a/index.cgi +++ b/index.cgi @@ -6,13 +6,15 @@ die() { exit 1 } debug() { #change to false to disable debugging - true && echo "$*" >>debug + #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 _STOR +# therefore we need to identify the code and data directories _EXEC and _DATA call=$0 real=$call while [ -L "$real" ]; do @@ -20,15 +22,12 @@ while [ -L "$real" ]; do done _EXEC="$(dirname "$real")" #execution directory -_STOR="$(dirname "$call")" #storage directory +_DATA="$(dirname "$call")" #storage directory -debug "Execution dir: $_EXEC" -debug "Storage dir: $_STOR" - -[ -w "$_EXEC" ] && [ -d "$_EXEC" ] || die "storage directory must be writable" +[ -w "$_DATA" ] && [ -d "$_DATA" ] || die "storage directory must be writable" # create directories for object storage -for each in "$_STOR"/{vcard,mappings,courses}; do +for each in "$_DATA"/{vcard,mappings,courses,cache,temp}; do [ ! -e "$each" ] && mkdir "$each" [ -w "$each" ] && [ -d "$each" ] || die "storage $each must be a writable directory" done @@ -44,6 +43,13 @@ EOF . "$_EXEC/cgi.sh" cgi_get -debug "$_GET" -. "$_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