]> git.plutz.net Git - serve0/blobdiff - index.cgi
css loading, externalize page code to file
[serve0] / index.cgi
deleted file mode 120000 (symlink)
index 410e699d63ab9fc7348d1ad94344a7d904bbd060..0000000000000000000000000000000000000000
--- a/index.cgi
+++ /dev/null
@@ -1 +0,0 @@
-shcgi/index.cgi
\ No newline at end of file
new file mode 100755 (executable)
index 0000000000000000000000000000000000000000..94309f3305a50b3690311c0e6a1cbc433fa755b8
--- /dev/null
+++ b/index.cgi
@@ -0,0 +1,52 @@
+#!/bin/sh
+
+[ -z "${_EXEC%/}" ] && _EXEC=. || _EXEC="${_DATA%/}"
+[ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}"
+
+. "$_EXEC/cgilite/cgilite.sh"
+. "$_EXEC/widgets.sh"
+
+filter="$(GET f)"
+search="$(GET s)"
+order="$(GET o |grep -m1 -xE 'Date|Name|Length' || printf Name)"
+pagesize="$(COOKIE pagesize |grep -m1 -xE '[1-9][0-9]*' || printf 50)"
+
+item="$(printf %s "${PATH_INFO#/}" |sed -r ':X /(^|\/)\.\.($|\/)/s;(^|[^/]*/)..(/|$);;; tX;')"
+
+case $(GET a) in
+  setprefs)
+    printf 'Status: 303 See Other\r\n'
+    SET_COOKIE +$((86400 * 90)) pagesize="$(POST pagesize |grep -m1 -xE '[1-9][0-9]*' || printf 50)"
+    SET_COOKIE +$((86400 * 90))  fakemp4="$(POST  fakemp4 |grep -m1 -xE 'yes' || printf no)"
+    printf 'Location: %s\r\n\r\n' "$(POST ref)"
+    exit 0
+  ;;
+esac
+
+if [ "$item" = "/style.css" ]; then
+  . "$_EXEC/cgilite/file.sh"
+  [ -r "$_DATA/$item" ] && FILE "$_DATA/$item" \
+                        || FILE "$_EXEC/style.css"
+elif [ -f "$_DATA/$item" ]; then
+  case $(GET a) in
+    tag)
+    ;;
+    thumbnail)
+    ;;
+    delete)
+    ;;
+    *) . "$_EXEC/cgilite/file.sh"
+      FILE "$_DATA/$item"
+    ;;
+  esac
+elif [ -d "$_DATA/$item" ]; then
+  case $(GET a) in
+    multitag)
+    ;;
+    *) . "$_EXEC/list.sh"
+    ;;
+  esac
+else
+  printf 'Status: 404 Not Found\r\n\r\n'
+  exit 0
+fi