X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=index.cgi;h=fa342bb3908d46b9e770c938bf6729e07e6fffc3;hb=0bca0bee961be0c55bddba41b28501d014aef4a6;hp=1b305e4ce66f227edc56fde2331eb0b416706f72;hpb=ed3fecb0e3063d2812a082ea46afc33bb4b58820;p=serve0 diff --git a/index.cgi b/index.cgi index 1b305e4..fa342bb 100755 --- a/index.cgi +++ b/index.cgi @@ -1,5 +1,11 @@ #!/bin/sh +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%/}" @@ -20,6 +26,21 @@ case $(GET a) in 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 [ "$ITEM" = "/style.css" ]; then @@ -41,7 +62,8 @@ elif [ -f "$_DATA/$ITEM" ]; then delete) ;; *) . "$_EXEC/cgilite/file.sh" - FILE "$_DATA/$ITEM" + fakemp4="$(COOKIE fakemp4)" + FILE "$_DATA/$ITEM" "$([ "$fakemp4" = yes ] && printf 'video/mp4')" ;; esac elif [ -d "$_DATA/$ITEM" ]; then