X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=cards%2Fupdate_card.sh;h=34db10cfb740bdf23493b1590b221c8167b3581a;hp=1975e4ea2aa66afa8bf5851965d7680ebb402118;hb=de8d4cf5570142a647bfe81f13fa87a73802e4e8;hpb=bab7cadaeae32434eb16872bd8e09449817d4f90 diff --git a/cards/update_card.sh b/cards/update_card.sh index 1975e4e..34db10c 100755 --- a/cards/update_card.sh +++ b/cards/update_card.sh @@ -20,15 +20,24 @@ . "$_EXEC/pdiread.sh" . "$_EXEC/session_lock.sh" +unset filter order card action newfield +unset cardfile attfile tempfile +unset vcf field cnt delete_key + filter="$(REF f)" order="$(REF o)" -card="$(POST card)" -cardfile="$_DATA/vcard/$card" +card="$(POST card |PATH)" +cardfile="$_DATA/vcard/${card##*/}" attfile="$_DATA/mappings/attendance" action="$(POST action)" -newfield="$(POST newfield)" +newfield="$(POST newfield |grep -m 1 -xE '[A-Z][A-Z0-9-]*')" + +if printf '%s\n' "$action" |grep -qxE 'addfield [A-Z][A-Z0-9]*'; then + newfield="${action##* }" + action=addfield +fi if ! tempfile=$(CHECK_SLOCK "$cardfile"); then SET_COOKIE 0 message="NO VALID FILE LOCK" @@ -72,6 +81,16 @@ for field in $(POST_KEYS |grep -xE '[A-Z][A-Z0-9-]*'); do esac done; done +# delete fields, first mark for deletion using delete_key +# this way the field enumeration is preserved during the process +# finally filter marked lines +delete_key="$(randomid)" +for delete in $(POST_KEYS |grep -xE '[A-Z][A-Z0-9-]*_delete_[0-9]+'); do + f="${delete%%_*}"; c="${delete##*_}"; + [ "$(POST "$delete")" = "true" ] && vcf="$(pdi_update_value "$vcf" "$f" "$c" "delete=${delete_key}")" +done +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