]> git.plutz.net Git - shellwiki/commitdiff
filename function
authorPaul Hänsch <paul@plutz.net>
Thu, 14 Apr 2022 14:22:26 +0000 (16:22 +0200)
committerPaul Hänsch <paul@plutz.net>
Thu, 14 Apr 2022 14:22:26 +0000 (16:22 +0200)
multipart.sh

index 09b17653346116b64ab80dcc513a3ba39c41d6da..70270f68f1c3f91830af52e22847f6887ee27081 100644 (file)
@@ -34,7 +34,7 @@ multipart_cache() {
 }
 
 multipart(){
-  local name="$1"
+  local name="$1" count="${2:-1}"
   local formdata state=begin
 
   while read -r formdata; do case "$formdata" in
@@ -47,7 +47,8 @@ multipart(){
                         || state=header
       ;;
     "Content-Disposition: form-data; name=\"${name}\""*"${CR}")
-      [ $state = header ] && state=dheader
+      [ $state = header -a $count -eq 1 ] && state=dheader
+      [ $state = header -a $count -gt 1 ] && count=$((count - 1))
       [ $state = data ] && printf "%s\n" "$formdata"
       ;;
     "${CR}")
@@ -59,3 +60,32 @@ multipart(){
       ;;
   esac; done <"${multipart_cachefile}"
 }
+
+multipart_filename(){
+  local name="$1" count="${2:-1}"
+  local formdata state=begin
+
+  while read -r formdata; do case "$formdata" in
+    "--${multipart_boundary}--${CR}")
+      return 1
+      ;;
+    "--${multipart_boundary}${CR}")
+      state=header
+      ;;
+    "Content-Disposition: form-data; name=\"${name}\"; filename=\""*"\""*"${CR}")
+      [ $state = header -a $count -eq 1 ] && break
+      [ $state = header -a $count -gt 1 ] && count=$((count - 1))
+      ;;
+    "${CR}")
+      [ $state = header ] && state=junk
+      ;;
+    *):
+      ;;
+  esac; done <"${multipart_cachefile}"
+
+  filename="${formdata#*; filename=\"}"
+  filename="${filename%%\"${CR}}"
+  filename="${filename%%\";*}"
+
+  HEX_DECODE % "$filename"
+}