X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=cards%2Fupdate_card.sh;h=7bfca2f3ab7d67a54135bc1f0a9683587a3195d5;hb=915db545f387cf9287b95f3ad5f84278bc2860d3;hp=7896beb5011d3cee5892b9d6c099a8693d34caa3;hpb=203fc5d63ba59a30688bac00c98d199cb08a8f30;p=lobster diff --git a/cards/update_card.sh b/cards/update_card.sh index 7896beb..7bfca2f 100755 --- a/cards/update_card.sh +++ b/cards/update_card.sh @@ -1,6 +1,6 @@ -#!/bin/zsh +#!/bin/sh -# Copyright 2014, 2016, 2019, 2020 Paul Hänsch +# Copyright 2014, 2016, 2019, 2020, 2021 Paul Hänsch # # This file is part of Confetti. # @@ -22,7 +22,7 @@ . "$_EXEC/cgilite/storage.sh" unset filter order card action newfield -unset cardfile attfile tempfile +unset cardfile tempfile unset vcf field cnt delete_key filter="$(REF f)" @@ -30,7 +30,6 @@ order="$(REF o)" card="$(POST card |PATH)"; card="${card##*/}" cardfile="$_DATA/vcard/${card}" -attfile="$_DATA/mappings/attendance" action="$(POST action)" newfield="$(POST newfield |grep -m 1 -xE '[A-Z][A-Z0-9-]*')" @@ -50,34 +49,46 @@ elif [ "$(POST tid)" != "$(transid "$tempfile")" ]; then exit 0 fi -vcf_escape(){ - for each in "$@"; do - printf %s\\n "$each" \ - | sed -E ':X;$!{N;bX}; s;\r\n;\n;g; s;([;,\\]);\\\1;g; s;\n;\\n;g;' - done \ - | sed -E ':X;$!{N;bX}; s;\n;\;;g' -} - # [ "${_POST[hi_select]}" = "list" ] || _POST[hi_company]="${_POST[hi_other]}" # [ -n "${_POST[hi_company]}${_POST[hi_number]}${_POST[hi_status]}" ] \ -# && _POST[X-HEALTH-INSURANCE]="$(vcf_escape "${_POST[hi_company]}" "${_POST[hi_number]}" "${_POST[hi_status]}")" +# && _POST[X-HEALTH-INSURANCE]="$(pdi_escape "${_POST[hi_company]}" "${_POST[hi_number]}" "${_POST[hi_status]}")" + +vcf="$(pdi_load "$tempfile")" -vcf="$(pdi_load "$cardfile")" +n1="$(POST 1N)" n2="$(POST 2N)" n3="$(POST 3N)" n4="$(POST 4N)" n5="$(POST 5N)" +# 3N (Middle Names) is not actually used +n3="${n2#${n2%% *}}" -vcf="$(pdi_update_value "$vcf" N 1 "$(vcf_escape "$(POST 1N)" "$(POST 2N)" "$(POST 3N)" "$(POST 4N)" "$(POST 5N)")")" +vcf="$(pdi_update_value "$vcf" N 1 "$(pdi_escape "$n1" "${n2%% *}" "${n3# }" "$n4" "$n5")")" +vcf="$(pdi_update_value "$vcf" FN 1 "$(pdi_escape "$n4 $n2 $n1 $n5" |sed -E 's;(^ +| +$);;g; s; +; ;g;')")" +vcf="$(printf '%s\n' "$vcf" |sed -E "/^CATEGORIES;[^:]*:.*$/d")" for field in $(POST_KEYS |grep -xE '[A-Z][A-Z0-9-]*'); do for cnt in $(seq 1 $(POST_COUNT "$field")); do case "$field" in # (TEL) - # printf '%s;TYPE=%s:%s\r\n' "${field}" "${_POST[phonetype${key#TEL}]}" "$(vcf_escape "$(POST "$field" "$cnt")")" + # printf '%s;TYPE=%s:%s\r\n' "${field}" "${_POST[phonetype${key#TEL}]}" "$(pdi_escape "$(POST "$field" "$cnt")")" # ;; + X-HEALTH-INSURANCE) + hi_select="$(POST "$field" "$cnt")" + if [ "$hi_select" = list ]; then + vcf="$(pdi_update_value "$vcf" "$field" "$cnt" "$(pdi_escape "$(POST "hi_company" "$cnt")" \ + "$(POST "hi_number" "$cnt")" \ + "$(POST "hi_status" "$cnt")" \ + )")" + elif [ "$hi_select" = other ]; then + vcf="$(pdi_update_value "$vcf" "$field" "$cnt" "$(pdi_escape "$(POST "hi_other" "$cnt")" \ + "$(POST "hi_number" "$cnt")" \ + "$(POST "hi_status" "$cnt")" \ + )")" + fi + ;; TEL) vcf="$(pdi_update_attrib "$vcf" TEL $cnt TYPE="$(POST teltype $cnt |grep -Exm1 'HOME|WORK|CELL|FAX')")" - vcf="$(pdi_update_value "$vcf" "$field" "$cnt" "$(vcf_escape "$(POST "$field" "$cnt")")")" + vcf="$(pdi_update_value "$vcf" "$field" "$cnt" "$(pdi_escape "$(POST "$field" "$cnt")")")" ;; *) - vcf="$(pdi_update_value "$vcf" "$field" "$cnt" "$(vcf_escape "$(POST "$field" "$cnt")")")" + vcf="$(pdi_update_value "$vcf" "$field" "$cnt" "$(pdi_escape "$(POST "$field" "$cnt")")")" ;; esac done; done @@ -95,37 +106,21 @@ vcf="$(printf '%s\n' "$vcf" |sed -E "/^[^:]+:delete=${delete_key}\$/d")" if [ "$action" = addfield ]; then vcf="$(pdi_update_value "$vcf" "$newfield" $(( $(pdi_count "$vcf" "$newfield") + 1 )) '')" fi -printf '%s' "$vcf" |grep -vx '' >"$tempfile" +printf '%s' "$vcf" | sed -E '/^$/d; s/^([^:]+);:/\1:/;' >"$tempfile" case "$action" in addfield) - REDIRECT "/cards/?o=${order}&f=${filter}&e=${card}" + REDIRECT "/cards/?o=${order}&f=${filter}&e=${card#/}" ;; update) - if LOCK "$attfile"; then - grep -F " ${card}" "$attfile" |while read course junk; do - touch "$_DATA/courses/${course}" - done - sed -i -r "/^.+ ${card}\$/d" "$attfile" - seq 1 $(POST_COUNT attendance) |while read n; do - printf '%s %s\n' "$(POST attendance $n)" "$card" - done >>"$attfile" - grep -F " ${card}" "$attfile" |while read course junk; do - touch "$_DATA/courses/${course}" - done - RELEASE "$attfile" - else - SET_COOKIE 0 message="COULD NOT UPDATE COURSE MAPPINGS" - fi - cp "$tempfile" "$cardfile" RELEASE_SLOCK "$cardfile" - REDIRECT "/cards/?o=${order}&f=${filter}#${card}" + REDIRECT "/cards/?o=${order}&f=${filter}#${card#/}" ;; cancel) RELEASE_SLOCK "$cardfile" [ -f "$cardfile" ] \ - && REDIRECT "/cards/?o=${order}&f=${filter}#${card}" \ + && REDIRECT "/cards/?o=${order}&f=${filter}#${card#/}" \ || REDIRECT "/cards/?o=${order}&f=${filter}" ;; delete)