]> git.plutz.net Git - serve0/blobdiff - index.cgi
Merge commit 'b931bbd0c30907b9cc956d3707b26b449bf41f76'
[serve0] / index.cgi
index 94309f3305a50b3690311c0e6a1cbc433fa755b8..79b9a87efda3acf8ac0e2084d29a0a67927b1378 100755 (executable)
--- a/index.cgi
+++ b/index.cgi
@@ -1,52 +1,96 @@
 #!/bin/sh
 
-[ -z "${_EXEC%/}" ] && _EXEC=. || _EXEC="${_DATA%/}"
-[ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}"
+exec 2>/dev/null
+file_pattern='^.*\.(mov|ts|mpg|mpeg|mp4|m4v|avi|mkv|flv|sfv|wmv|ogm|ogv|webm|iso|rmvb)$'
 
-. "$_EXEC/cgilite/cgilite.sh"
-. "$_EXEC/widgets.sh"
+. "${_EXEC:-${0%/*}}/cgilite/cgilite.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)"
+FILTER="$(GET f)"
+SEARCH="$(GET s)"
+ORDER="$(GET o |grep -m1 -axE 'Date|Name|Length|Group' || printf Name)"
+LISTSIZE="$(COOKIE pagesize |grep -m1 -axE '[1-9][0-9]*' || printf 60)"
+ITEM="${PATH_INFO%/}"
+ACTION="$(GET a)"
 
-item="$(printf %s "${PATH_INFO#/}" |sed -r ':X /(^|\/)\.\.($|\/)/s;(^|[^/]*/)..(/|$);;; tX;')"
-
-case $(GET a) in
+case $ACTION 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
+    SET_COOKIE +$((86400 * 90))  pagesize="$(POST pagesize |grep -m1 -axE '[1-9][0-9]*' || printf 60)"
+    SET_COOKIE +$((86400 * 90))      mode="$(POST     mode |grep -m1 -axE 'browse|index' || printf browse)"
+    SET_COOKIE +$((86400 * 90))   fakemp4="$(POST  fakemp4 |grep -m1 -axE 'yes' || printf no)"
+    SET_COOKIE +$((86400 * 90)) downscale="$(POST  downscale |grep -m1 -axE 'yes' || printf no)"
+    [ "$(POST index)" = "update" ] && touch -cd @0 "${_DATA}/.index/meta.time"
+    REDIRECT "$(POST ref)"
+  ;;
+  bookmark)
+    bm="$_DATA/.index/bookmarks"
+    . "$_EXEC/cgilite/storage.sh"
+
+    s="$(POST search |STRING)"; f="$(POST filter |STRING)"
+    if LOCK "$bm"; then
+      grep -avF "      search=$s       filter=$f${CR}" "$bm" >"$bm.tmp"
+      [ ! "$(POST delete)" ] \
+      && printf '%s    search=%s       filter=%s\r\n' \
+               "$(POST name |STRING)" "$s" "$f" >>"$bm.tmp"
+      mv "$bm.tmp" "$bm"
+      RELEASE "$bm"
+    fi
+    REDIRECT "$(POST ref)"
+  ;;
+  multitag)
+    . "$_EXEC/multitag.sh"
+    REDIRECT "$(POST ref)"
   ;;
+  thumbnail) if [ -f "$_DATA/$PATH_INFO" ]; then
+    . "$_EXEC/cgilite/file.sh"
+    index="$_DATA/${PATH_INFO%/*}/.index"
+    thumb="$index/${PATH_INFO##*/}"; thumb="${thumb%.*}.jpg"
+    if [ -d "$index" -a ! -f "$thumb" ] && { printf %s "$PATH_INFO" |grep -qE -e "${file_pattern}" ;}; then
+      . "$_EXEC/thumbnail.sh"
+      gen_thumb "$_DATA/$PATH_INFO" "$thumb"
+    fi
+    FILE "$thumb"
+    return 0
+  fi;;
+  download) if [ -f "$_DATA/$PATH_INFO" ]; then
+    . "$_EXEC/cgilite/file.sh"
+    fakemp4="$(COOKIE fakemp4)"
+    downscale="$(COOKIE downscale)"
+    downfile="$_DATA/${PATH_INFO%/*}/.transcode/${PATH_INFO%.*}.480p.webm"
+    if [ "$downscale" = yes -a -f "$downfile" ]; then
+      FILE "$downfile" "$([ "$fakemp4" = yes ] && printf 'video/mp4')"
+    else
+      FILE "$_DATA/$PATH_INFO" "$([ "$fakemp4" = yes ] && printf 'video/mp4')"
+    fi
+    return 0
+  fi;;
+  delete) if [ -f "$_DATA/$PATH_INFO" ]; then
+    :
+  fi;;
+  advsearch) if [ -d "$_DATA/$PATH_INFO" ]; then
+    . "$_EXEC/advsearch.sh"
+    return 0
+  fi;;
+  spawnindex) if [ -d "$_DATA/$PATH_INFO" ]; then
+    if [ "$(POST recursive)" = yes ]; then
+      find "$_DATA/$PATH_INFO" -depth -type d \! -name .index \
+                          -exec mkdir -p '{}'/.index \;
+    else
+      mkdir -p "$_DATA/$PATH_INFO/.index"
+    fi
+    REDIRECT "$(POST ref)"
+  fi;;
 esac
 
-if [ "$item" = "/style.css" ]; then
+if [ -f "$_EXEC/$PATH_INFO" ]; 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
+  FILE "$_EXEC/$PATH_INFO"
+  return 0
+elif [ -f "$_DATA/$PATH_INFO" ]; then
+  . "$_EXEC/view.sh"
+  return 0
+elif [ -d "$_DATA/$PATH_INFO" ]; then
+  . "$_EXEC/list.sh"
+  return 0
 else
-  printf 'Status: 404 Not Found\r\n\r\n'
-  exit 0
+  printf 'Status: 404 Not Found\r\nContent-Length 0:\r\n\r\n'
 fi