X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=themes%2Fdefault.sh;h=36710dbd44e8194f6fd6fad0dba0dfc60e4ef4f9;hb=4d35c26aaac2a8738a8831118671d7a70dca827c;hp=022a29ab4985bbad8dd05a8624fdbae6dc6084d9;hpb=f9cfcde441afed9d6db96e201935b6208903046d;p=shellwiki
diff --git a/themes/default.sh b/themes/default.sh
index 022a29a..36710db 100755
--- a/themes/default.sh
+++ b/themes/default.sh
@@ -93,10 +93,19 @@ theme_attachments(){
local page="$1" title
title="${page%/}"; title="${title##*/}"
+ if [ ! "$(mdfile "$page")" ]; then
+ theme_404
+ return 0
+ elif ! acl_read "$page"; then
+ theme_403
+ return 0
+ fi
+
# Important! Web Server response including newline
printf "%s\r\n" "Content-Type: text/html; charset=utf-8" ""
- cat <<-EOF
+ if acl_write "$page"; then
+ cat <<-EOF
$(theme_head)
@@ -105,10 +114,38 @@ theme_attachments(){
$(theme_header)
+
+
+ $(theme_footer)
+
+ EOF
+ else
+ cat <<-EOF
+
+
+ $(theme_head)
+ Attachments $(HTML "${title}")
+
+ $(theme_header)
+
$(for file in "$_EXEC/pages/$page/#attachments"/* "$_DATA/pages/$page/#attachments"/*; do
[ "$file" = "$_EXEC/pages/$page/#attachments/${file##*/}" \
@@ -116,15 +153,16 @@ theme_attachments(){
stat="$(stat -c '%s %Y' -- "$file" 2>&-)" || continue
size="${stat% *}" date="${stat#* }"
- printf '- %s
+ printf '
- %s
%s%s
' \
- "$(HTML "${file##*/}")" "$(size_human "$size")" "$(date -d @"$date" +"%F %T")"
+ "$(HTML "${file##*/}")" "$(HTML "${file##*/}")" "$(size_human "$size")" "$(date -d @"$date" +"%F %T")"
done)
$(theme_footer)
EOF
+ fi
}
theme_login(){
@@ -154,3 +192,23 @@ theme_404(){
printf "Content-Length: 0\r\n\r\n"
fi
}
+
+theme_409(){
+ printf "%s\r\n" "Status: 409 Conflict"
+
+ if [ "$(mdfile '/[wiki]/409/')" ]; then
+ theme_page '/[wiki]/409/'
+ else
+ printf "Content-Length: 0\r\n\r\n"
+ fi
+}
+
+theme_500(){
+ printf "%s\r\n" "Status: 500 Internal Server Error"
+
+ if [ "$(mdfile '/[wiki]/500/')" ]; then
+ theme_page '/[wiki]/500/'
+ else
+ printf "Content-Length: 0\r\n\r\n"
+ fi
+}