X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=cgi.sh;h=fdc57b409fb8f6ed95dc6752a81eed4c7361bc6a;hb=348367d4594d3fa840a4ebf7fb98fc1969a6b666;hp=a9c59d93f0ed19e3f4bd4de107f12918eaea9c00;hpb=2025d397530ad31a57c4c1df926891b028a712a7;p=cgilite diff --git a/cgi.sh b/cgi.sh index a9c59d9..fdc57b4 100755 --- a/cgi.sh +++ b/cgi.sh @@ -40,14 +40,13 @@ cgi_post() { # parse HTTP POST string key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')" val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\2:')" value="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g;')")" - if [ -n "${_POST[$key]}" ]; then + n='' + if [ -n "${_POST[$key$n]}" ]; then n=0 while [ -n "${_POST[$key$n]}" ]; do n=$(($n + 1)); done - _POST[$key$n]="$value" - else - _POST[$key]="$value" fi - debug "_POST[$key] => $value" + _POST[$key$n]="$value" + debug "_POST[$key$n] => $value" done } @@ -71,18 +70,47 @@ cgi_cookie() { # Parse GET data from referer done } -urlsave(){ +urlsafe(){ printf %s "$*" \ | sed 's;%;%25;g; - s; ;%20;g; - s;!;%21;g; - s;";%22;g; - s;&;%26;g; - s;(;%28;g; - s;);%29;g; - s;:;%3a;g + s;\?;%3f;g; + s;#;%23;g; s;<;%3c;g; s;>;%3e;g; - s;'\'';%27;g; - s;\?;%3f;g;' + s;&;%26;g; + s;";%22;g; + s;'\'';%27;g;' +# s; ;%20;g; +# s;!;%21;g; +# s;(;%28;g; +# s;);%29;g; +# s;:;%3a;g; +} + +htmlsafe(){ + printf %s "$*" \ + | sed 's;<;\<\;;g; + s;>;\>\;;g; + s;&;\&\;;g; + s;";\"\;;g; + s;'\'';&apos\;;g;' +} + +redirect(){ + printf '%s\n\n' "Location: $*" + exit 0 +} + +set_cookie(){ + case "$1" in + session|0) expire='';; + ''|default) expire="$(LANG=C date -d "+ 1 week" +'%a, %d %b %Y %T %Z')";; + *) expire="$(LANG=C date -d "$1" +'%a, %d %b %Y %T %Z' 2>&-)";; + esac + cookie="$2" + + printf 'Set-Cookie: %s' "$cookie" + [ -n "$expire" ] && printf '; Expires=%s' "$expire" + [ $# -ge 3 ] && shift 2 && printf '; %s' "$@" + printf '\n' }