slitaz-base-files view rootfs/usr/lib/slitaz/httphelper.sh @ rev 209

httphelper.sh: update htmlentities
author Pascal Bellard <pascal.bellard@slitaz.org>
date Thu Dec 20 10:43:49 2012 +0100 (2012-12-20)
parents 524eab3120ae
children b2311939ad7e
line source
1 #!/bin/sh
2 #
3 # SliTaz Helper for SHell CGI scripts - See httphelper function
4 #
5 # This helper is used in TazPanel, Pizza and other SliTaz CGI tools and
6 # services. The goal is to maintain it according to the needs of the
7 # project and Busybox httpd server applet since it is used for URL
8 # [en|de]coding.
9 #
10 # Documentation: man httphelper or /usr/share/doc/slitaz/httpelper.txt
11 #
12 # Copyright (C) SliTaz 2012 - GNU gpl v2
13 #
15 alias urlencode='busybox httpd -e'
16 alias urldecode='busybox httpd -d'
18 # Send headers.
19 header() {
20 local i
21 [ -z "$1" ] && set -- "Content-type: text/html"
22 for i in "$@" ""
23 do
24 echo -e "$i\r"
25 done
26 }
28 http_urlencode() {
29 sed -e "s|%|%25|g;s|!|%21|g;s|\*|%2A|g;s|'|%27|g;s|(|%28|g" \
30 -e "s|)|%29|g;s|;|%3B|g;s|:|%3A|g;s|@|%40|g;s|&|%26|g" \
31 -e "s|=|%3D|g;s|+|%2B|g;s|\$|%24|g;s|,|%2C|g;s|/|%2F|g" \
32 -e "s|\?|%3F|g;s|#|%25|g;s|\[|%5B|g;s|\]|%5D|g;s| |+|g"
33 }
35 htmlentities() {
36 echo $1 | sed -e 's|&|\&amp;|g;s|<|\&lt;|g;s|>|\&gt;|g' \
37 -e 's|"|\&quot;|g;s|'"'"'|\&acute;|g;s|\t|\&#09;|g'
38 }
40 # MD5 crypt a string such as password (httpd -m dont give same result ?)
41 md5crypt() {
42 echo -n "$1" | md5sum | awk '{print $1}'
43 }
45 # MD5 crypt a string. Stronger crypto than MD5
46 sha512crypt() {
47 echo -n "$1" | sha512sum | awk '{print $1}'
48 }
50 _ARRAY()
51 {
52 [ -z "$2" ] && eval echo \$${1}__NAMES ||
53 [ -n "$(eval echo \$${1}__NAMES)" ] && eval echo \$${1}_${2}_${3:-1}
54 }
56 GET() { _ARRAY GET "$1" $2; }
57 POST() { _ARRAY POST "$1" $2; }
58 FILE() { _ARRAY FILE "$1" $2; }
59 COOKIE() { _ARRAY COOKIE "$1" $2; }
61 httpinfo()
62 {
63 local i
64 local j
65 local x
66 for i in SERVER_PROTOCOL SERVER_SOFTWARE SERVER_NAME SERVER_PORT AUTH_TYPE \
67 GATEWAY_INTERFACE REMOTE_HOST REMOTE_ADDR REMOTE_PORT \
68 HTTP_REFERER HTTP_HOST HTTP_USER_AGENT HTTP_ACCEPT \
69 HTTP_ACCEPT_LANGUAGE HTTP_COOKIE AUTH_TYPE REMOTE_USER REMOTE_IDENT \
70 REQUEST_METHOD REQUEST_URI QUERY_STRING CONTENT_LENGTH CONTENT_TYPE \
71 SCRIPT_NAME SCRIPT_FILENAME PATH_INFO PATH_TRANSLATED \
72 USER HOME LOGNAME SHELL PWD ; do
73 eval x=\$$i
74 [ -n "$x" ] && echo "$i='$x'"
75 done
76 for x in GET POST COOKIE ; do
77 for i in $($x) ; do
78 if [ $($x $i count) -gt 1 ]; then
79 for j in $(seq 1 $($x $i count)); do
80 echo "$x($i,$j)='$($x $i $j)'"
81 done
82 else
83 echo "$x($i)='$($x $i)'"
84 fi
85 done
86 done
87 for i in $(FILE) ; do
88 for j in name size type tmpname ; do
89 echo "FILE($i,$j)='$(FILE $i $j)'"
90 done
91 done
92 }
94 read_query_string()
95 {
96 local i
97 local names
98 local cnt
99 names=""
100 IFS="&"
101 for i in $2 ; do
102 var=${i%%[^A-Za-z_0-9]*}
103 case " $names " in
104 *\ $var\ *) eval cnt=\$${1}_${var}_count ;;
105 *) cnt=0
106 names="$names $var" ;;
107 esac
108 eval ${1}_${var}_count=$((++cnt))
109 eval ${1}_${var}_$cnt=\'$(busybox httpd -d "${i#*=}" | sed "s/'/\'\\\\\'\'/g")\'
110 done
111 unset IFS
112 eval ${1}__NAMES=\'${names# }\'
113 }
115 [ -z "$GET__NAMES" ] && read_query_string GET "$QUERY_STRING"
116 [ -z "$COOKIE_NAMES" ] &&
117 read_query_string COOKIE "$(echo "$HTTP_COOKIE" | sed 's/; /\&/g')"
119 ddcut()
120 {
121 page=4096
122 skip=$1
123 count=$(($2 - $1 -2))
124 tmp=$(($skip / $page))
125 [ $tmp -ne 0 ] && dd bs=$page skip=$tmp count=0
126 skip=$(($skip - ($tmp * $page) ))
127 dd bs=1 skip=$skip count=0
128 tmp=$(( ($page - $skip) % $page ))
129 if [ $tmp -ne 0 -a $tmp -le $count ]; then
130 dd bs=1 count=$tmp
131 count=$(($count - $tmp))
132 fi
133 tmp=$(($count / $page))
134 [ $tmp -ne 0 ] && dd bs=$page count=$tmp
135 dd bs=1 count=$(($count - ($tmp * $page) ))
136 }
138 if [ "$REQUEST_METHOD$POST__NAMES" == "POST" ]; then
139 prefix=/tmp/httpd_post
140 mkdir $prefix$$
141 now=$(stat -c %Y $prefix$$)
142 for i in $prefix* ; do
143 [ $(stat -c %Y $i) -lt $(($now - 3600)) ] && rm -rf $i
144 done
145 post=$prefix$$/post
146 n=1
147 cat > ${post}0
148 read args < ${post}0
149 delim="${args%?}"
150 case "$delim" in
151 -*) awk "/$delim/ { o+=index(\$0,\"$delim\")-1; print o }
152 { o+=1+length() }" < ${post}0 | while read offset; do
153 if [ $offset -ne 0 ]; then
154 ddcut $last $offset < ${post}0 > $post$n 2> /dev/null
155 n=$(($n+1))
156 fi
157 last=$offset
158 done
159 rm -f ${post}0
160 CR=`printf '\r'`
161 for i in $post* ; do
162 head -n 2 $i | grep -q filename= || echo '' >> $i
163 filename=
164 while read line; do
165 case "$line" in
166 *Content-Disposition*)
167 name=$(echo $line | sed 's/.* name="\([^"]*\)".*$/\1/')
168 name=${name%%[^A-Za-z_0-9]*}
169 case "$line" in
170 *filename=*) filename=$(echo $line | sed 's/.* filename="\([^"]*\)".*$/\1/') ;;
171 esac ;;
172 *Content-Type*)
173 type=$(echo $line | sed 's/.*-Type: \(.*\).$/\1/') ;;
174 $CR)
175 if [ -n "$filename" ]; then
176 tmp=$(mktemp $prefix$$/uploadXXXXXX)
177 cat > $tmp
178 FILE__NAMES="$FILE__NAMES $name"
179 FILE__NAMES="${FILE__NAMES# }"
180 eval FILE_${name}_tmpname=$tmp
181 eval FILE_${name}_name=$filename
182 eval FILE_${name}_size=$(stat -c %s $tmp)
183 eval FILE_${name}_type=$type
184 elif [ -n "$name" ]; then
185 eval cnt=\$POST_${name}_count
186 cnt=$(($cnt + 1))
187 eval var=\$POST_${name}_$cnt
188 while read line; do
189 [ -n "$var" ] && var="$var
190 "
191 var="$var$line"
192 done
193 eval POST_${name}_$cnt="\$var"
194 eval POST_${name}_count=$cnt
195 case " $POST__NAMES " in
196 *\ $name\ *) ;;
197 *) POST__NAMES="$POST__NAMES $name"
198 POST__NAMES="${POST__NAMES# }" ;;
199 esac
200 fi
201 break ;;
202 *)
203 esac
204 done < $i
205 rm -f $i
206 done
207 rmdir $(dirname $post) ;;
208 *) rm -rf $(dirname $post)
209 read_query_string POST "$args" ;;
210 esac
211 fi