X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=index.cgi;h=a620cf9a8525b2ed182dafd7dea890965602320c;hb=df692aadca85504ab0333aa5845e58cac730ad20;hp=54841bf4338feab6adce565f87d6c71ad34b28b4;hpb=10597e4506dca6e0f4abe239ff44e742d3de8a8c;p=serve0 diff --git a/index.cgi b/index.cgi index 54841bf..a620cf9 100755 --- a/index.cgi +++ b/index.cgi @@ -1,56 +1,91 @@ #!/bin/sh -[ -z "${_EXEC%/}" ] && _EXEC=. || _EXEC="${_DATA%/}" +for n in "$@"; do case ${n%%=*} in + data) _DATA="${n#data=}";; + exec) _exec="${n#exec=}";; +esac; done + +[ -z "${_EXEC%/}" ] && _EXEC="$(realpath "${0%/*}")" || _EXEC="${_EXEC%/}" [ -z "${_DATA%/}" ] && _DATA=. || _DATA="${_DATA%/}" -. "$_EXEC/cgilite/cgilite.sh" -. "$_EXEC/widgets.sh" +file_pattern='^.*\.(mov|ts|mpg|mpeg|mp4|m4v|avi|mkv|flv|sfv|wmv|ogm|ogv|webm|iso|rmvb)$' -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)" +. "$_EXEC/cgilite/cgilite.sh" -item="$(printf %s "${PATH_INFO#/}" |sed -r ':X /(^|\/)\.\.($|\/)/s;(^|[^/]*/)..(/|$);;; tX;')" +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#/}")" 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)" + 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)" + 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)" ;; esac -if [ -f "$_DATA/$item" ]; then +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) ;; - download) - ;; 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" + fakemp4="$(COOKIE fakemp4)" + FILE "$_DATA/$ITEM" "$([ "$fakemp4" = yes ] && printf 'video/mp4')" ;; esac -elif [ -d "$_DATA/$item" ]; then +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)" ;; - *) printf 'Content-Type: text/html;charset=utf-8\r\n\r\n' - "$_EXEC/cgilite/html-sh.sed" <<-EOF - [!DOCTYPE HTML] - [html [head [title Listing] - ] [body - $(w_search) $(w_prefs) - ] ] - EOF - exit 0 + *) . "$_EXEC/list.sh" ;; esac 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