]> git.plutz.net Git - confetti/blobdiff - index.cgi
keep filter and order settings when updating a card
[confetti] / index.cgi
index f0127826c0eb8f7210d5b7a9d54a0f19e91ca632..a7edbb1186378b7584e1e23e6b39a8f0aa906b19 100755 (executable)
--- a/index.cgi
+++ b/index.cgi
@@ -7,7 +7,8 @@ die() {
 }
 debug() { #change to false to disable debugging
   #true && echo "$*" >>debug
-  true && echo "$*" >>/dev/stderr
+  true && [ -n "$*" ] && echo -E "$*" >>/dev/stderr
+  true && [ -z "$*" ] && tee /dev/stderr
 }
 
 # this program is supposed to be symlinked into a http root directory
@@ -23,13 +24,10 @@ done
 _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,mappings,courses,cache,temp}; do
   [ ! -e "$each" ] && mkdir "$each"
   [ -w "$each" ] && [ -d "$each" ] || die "storage $each must be a writable directory"
 done
@@ -45,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