X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=write%2Fintroedit.cgi;h=7d0887e4beafaea8ea4f9a962817bdc9f8e2bf1d;hb=ab208fff56e536585bc0978898a7c3f610c73dce;hp=b02437193e28f860229c780db343e1df6fd44a8b;hpb=470dbac80eb2334fdb04a85e448d6194140d250d;p=busy diff --git a/write/introedit.cgi b/write/introedit.cgi index b024371..7d0887e 100755 --- a/write/introedit.cgi +++ b/write/introedit.cgi @@ -16,16 +16,24 @@ # along with Busy. If not, see . [ "$HTTPS" = "on" ] && proto=https || proto=http -. ../auth/acl.sh +. ../auth/permissions.sh info="$(egrep -o '(^|&)i=([0-9]{10}_[0-9]{3}|intro|news)(&|$)' <<<"${QUERY_STRING}" |sed 's:&::g;s:i=::')" -[ "$info" = "news" ] && $ACL_ADDNEWS && info="$(date +%s)_$(apg -M N -a 1 -n 1 -m 3 -x 3)" -[ "$info" != "intro" ] && $ACL_EDITNEWS && info="${info}.news" -[ "$info" = "intro" ] && ($ACL_EDITINTRO || info='') -[ -n "$info" ] || echo "Location: ${proto}://${HTTP_HOST}/?p=Error&i=noaccess\n\n" +if [ "$info" = "news" ]; then + $ACL_ADDNEWS || info='' +elif [ "$info" = "intro" ]; then + $ACL_EDITINTRO || info='' +elif [ -z "$info" ]; then + $ACL_EDITNEWS || info='' +fi +[ -n "$info" ] || echo -n "Location: ${proto}://${HTTP_HOST}/?p=Error&i=noaccess\n\n" [ -n "$info" ] || exit 0 +[ "$info" = "news" ] && info="$(date +%s)_$(apg -M N -a 1 -n 1 -m 3 -x 3)" +[ "$info" != "intro" ] && info="${info}.news" +[ "$info" = "intro" ] && ($ACL_EDITINTRO || info='') + if [ -n "${CONTENT_LENGTH}" -a "${CONTENT_LENGTH}" -gt 0 ]; then (head -c "${CONTENT_LENGTH}"; echo)|sed 's/&/\n/g' |while read line; do if (echo "${line}" | egrep -xq 'text=.+'); then @@ -37,6 +45,6 @@ if [ -n "${CONTENT_LENGTH}" -a "${CONTENT_LENGTH}" -gt 0 ]; then done fi -[ -z "$cancel" ] && grep -qx "${REMOTE_USER}" ../auth/admin.user && echo -e "${text}" >"../Home/$info" +[ -z "$cancel" ] && echo -e "${text}" >"../Home/$info" echo -n "Location: ${proto}://${HTTP_HOST}/?p=Home\n\n"