]> git.plutz.net Git - shcgi/commitdiff
introduced cookie array, extended urlsave function, IMPORTANT: removed " from array...
authorpaul <paul@plutz.net>
Fri, 31 Jul 2015 10:32:16 +0000 (10:32 +0000)
committerpaul <paul@plutz.net>
Fri, 31 Jul 2015 10:32:16 +0000 (10:32 +0000)
svn path=/trunk/; revision=8

action.sh
cgi.sh
index.cgi
page.sh

index f8faf1f6a8001fdabf9a414ed7e5190b86197f4f..caf214c410310da54f6befbe5f95cd6cfa711cf1 100755 (executable)
--- a/action.sh
+++ b/action.sh
@@ -17,7 +17,7 @@
 # You should have received a copy of the GNU Affero General Public License
 # along with Serve0.  If not, see <http://www.gnu.org/licenses/>. 
 
-ACTION="$(printf %s "$_GET[\"action\"]" |egrep '^[a-zA-Z0-9_-]+$')"
+ACTION="$(printf %s "${_GET[action]}" |egrep '^[a-zA-Z0-9_-]+$')"
 ACTION="${_EXEC}/actions/${ACTION}.sh"
 
 if [ -x "$ACTION" ]; then
diff --git a/cgi.sh b/cgi.sh
index 99942195cc4787bd551b1653c71c494a0146eb3d..3ad0e8b3a9f7c5301122f577bf9e0fc413b55074 100755 (executable)
--- a/cgi.sh
+++ b/cgi.sh
 declare -A _GET
 declare -A _POST
 declare -A _REF
+declare -A _COOKIE
 
 [ -z "$HTTP_REFERER" ] && HTTP_REFERER="./"
 
 cgi_get() {  # parse HTTP GET string
   debug "== CGI DATA: GET =="
   printf '%s\n' "$QUERY_STRING" |tr '&' '\n' |while read query; do
-    key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]*)=(.*)$:\1:')"
-    val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]*)=(.*)$:\2:')"
-    _GET["$key"]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
+    key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')"
+    val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\2:')"
+    _GET[$key]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
     debug "_GET[$key] => $val"
   done
 }
@@ -36,15 +37,15 @@ cgi_get() {  # parse HTTP GET string
 cgi_post() {  # parse HTTP POST string
   debug "== CGI DATA: POST =="
   sed -u 1q |tr '&' '\n' |while read query; do
-    key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]*)=(.*)$:\1:')"
-    val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]*)=(.*)$:\2:')"
+    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
+    if [ -n "${_POST[$key]}" ]; then
       n=0
-      while [ -n "$_POST[\"$key$n\"]" ]; do n=$(($n + 1)); done
-      _POST["$key$n"]="$value"
+      while [ -n "${_POST[$key$n]}" ]; do n=$(($n + 1)); done
+      _POST[$key$n]="$value"
     else
-      _POST["$key"]="$value"
+      _POST[$key]="$value"
     fi
     debug "_POST[$key] => $value"
   done
@@ -53,13 +54,35 @@ cgi_post() {  # parse HTTP POST string
 cgi_refdata() { # Parse GET data from referer
   debug "== CGI DATA: REFERER =="
   printf '%s\n' "$HTTP_REFERER" |cut -d'?' -f2- |tr '&' '\n' |while read query; do
-    key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]*)=(.*)$:\1:')"
-    val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]*)=(.*)$:\2:')"
-    _REF["$key"]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
+    key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')"
+    val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\2:')"
+    _REF[$key]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
     debug "_REF[$key] => $val"
   done
 }
 
+cgi_cookie() { # Parse GET data from referer
+  debug "== CGI DATA: COOKIE =="
+  printf '%s\n' "$HTTP_COOKIE" |tr ';' '\n' |while read query; do
+    key="$(printf %s "$query" |sed -r 's:^ *([a-zA-Z0-9_-]+)=(.*)$:\1:')"
+    val="$(printf %s "$query" |sed -r 's:^ *([a-zA-Z0-9_-]+)=(.*)$:\2:')"
+    _COOKIE[$key]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
+    debug "_COOKIE[$key] => $val"
+  done
+}
+
 urlsave(){
-  printf %s "$*" |sed 's:%:\%25:g;s:\?:\%3F:g;s:&:\%26:g;s:'\'':\%27:g;s: :\%20:g;s:!:\%21:g;s:(:\%28:g;s:):\%29:g;s:":\%22:g;'
+  printf %s "$*" \
+  | sed 's; ;%20;g;
+         s;!;%21;g;
+         s;";%22;g;
+         s;%;%25;g;
+         s;&;%26;g;
+         s;(;%28;g;
+         s;);%29;g;
+         s;:;%3a;g
+         s;<;%3c;g;
+         s;>;%3e;g;
+         s;'\'';%27;g;
+         s;\?;%3f;g;'
 }
index af99fe150b67db0149b81858603d69e9a2b1c17d..b407fc17ea0dcf6d556dba7b5ad5df5eb91189b2 100755 (executable)
--- a/index.cgi
+++ b/index.cgi
@@ -74,7 +74,7 @@ cgi_get
 
 [ -x "$_EXEC/constants.sh" ] && . "$_EXEC/constants.sh"
 
-if [ -n "$_GET[\"action\"]" ]; then
+if [ -n "${_GET[action]}" ]; then
   . "$_EXEC/shcgi/action.sh"
 else
   . "$_EXEC/shcgi/page.sh"
diff --git a/page.sh b/page.sh
index d4e38cec88e2d79c3354feedde3bc74934ecd5cb..ef9df2e3def9271c49ec455cf3d251df17ed4e68 100755 (executable)
--- a/page.sh
+++ b/page.sh
@@ -19,7 +19,7 @@
 
 printf "Content-Type: text/html;charset=utf-8\n\n"
 
-PAGE="$(printf %s "$_GET[\"p\"]" |egrep '^[a-zA-Z0-9_-]+$')"
+PAGE="$(printf %s "${_GET[p]}" |egrep '^[a-zA-Z0-9_-]+$')"
 PAGE="${_EXEC}/pages/${PAGE}.sh"
 [ -x "$PAGE" ] || PAGE="${_EXEC}/pages/error.sh"