X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=index.cgi;h=1b84d2f436f149a742e11494b592c27a3e9a7b0b;hb=f46c55f97b1e0bafcd9316ecab8a9f920bedef4c;hp=4dbd1150a063ba93b4b5717f16c2e9cbcf8e401e;hpb=915841ffcd76d15c1a6e503d6b14ec740abeac3e;p=serve0 diff --git a/index.cgi b/index.cgi index 4dbd115..1b84d2f 100755 --- a/index.cgi +++ b/index.cgi @@ -1,5 +1,12 @@ #!/bin/sh +exec 2>/dev/null +for n in "$@"; do case ${n%%=*} in + data) _DATA="${n#data=}";; + exec) _exec="${n#exec=}";; + noerr) exec 2>&-;; +esac; done + [ -z "${_EXEC%/}" ] && _EXEC="$(realpath "${0%/*}")" || _EXEC="${_EXEC%/}" [ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}" @@ -9,15 +16,18 @@ file_pattern='^.*\.(mov|ts|mpg|mpeg|mp4|m4v|avi|mkv|flv|sfv|wmv|ogm|ogv|webm|iso FILTER="$(GET f)" SEARCH="$(GET s)" -ORDER="$(GET o |grep -m1 -axE 'Date|Name|Length' || printf Name)" -LISTSIZE="$(COOKIE pagesize |grep -m1 -axE '[1-9][0-9]*' || printf 50)" -ITEM="$(PATH "${PATH_INFO#/}")" +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)" -case $(GET a) in +case $ACTION in setprefs) - SET_COOKIE +$((86400 * 90)) pagesize="$(POST pagesize |grep -m1 -axE '[1-9][0-9]*' || printf 50)" - 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)) 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) @@ -26,7 +36,7 @@ case $(GET a) in s="$(POST search |STRING)"; f="$(POST filter |STRING)" if LOCK "$bm"; then - grep -m1 -avF " search=$s filter=$f${CR}" "$bm" >"$bm.tmp" + 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" @@ -35,51 +45,76 @@ case $(GET a) in 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 +# case $PATH_INFO in +# /style.css) +# . "$_EXEC/cgilite/file.sh" +# [ -r "$_DATA/$PATH_INFO" ] \ +# && FILE "$_DATA/$PATH_INFO" \ +# || FILE "$_EXEC/style.css" +# return 0 +# ;; +# /stereoview.js) +# . "$_EXEC/cgilite/file.sh" +# FILE "$_EXEC/stereoview.js" +# return 0 +# ;; +# esac + +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) - . "$_EXEC/cgilite/file.sh" - index="$_DATA/${ITEM%/*}/.index" - thumb="$index/${ITEM##*/}"; thumb="${thumb%.*}.jpg" - [ -d "$index" -a \! -f "$thumb" ] \ - && file="$_DATA/$ITEM" . "$_EXEC/thumbnail.sh" - FILE "$thumb" - ;; - delete) - ;; - *) . "$_EXEC/cgilite/file.sh" - FILE "$_DATA/$ITEM" - ;; - esac -elif [ -d "$_DATA/$ITEM" ]; then - case $(GET a) in - advsearch) - . "$_EXEC/advsearch.sh" - ;; - spawnindex) - if [ "$(POST recursive)" = yes ]; then - find "$_DATA/$ITEM" -depth -type d \! -name .index \ - -exec mkdir -p '{}'/.index \; - else - mkdir -p "$_DATA/$ITEM/.index" - fi - REDIRECT "$(POST ref)" - ;; - multitag) - . "$_EXEC/multitag.sh" - REDIRECT "$(POST ref)" - ;; - *) . "$_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\nContent-Length 0:\r\n\r\n' fi