X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=themes%2Fdefault.sh;h=7edd4b9986c60ad8e989f07a2740c7dc327d7c48;hb=7b1d88cf33d962e2ac98e03d0fd21327aee583a6;hp=6fa6ba16566245e9e7c0b92b883a155bf9ad4a19;hpb=ed4cab85e95f1eb70badbc3a22a493b5924d8e7e;p=shellwiki
diff --git a/themes/default.sh b/themes/default.sh
index 6fa6ba1..7edd4b9 100755
--- a/themes/default.sh
+++ b/themes/default.sh
@@ -22,6 +22,14 @@ theme_page(){
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" ""
@@ -33,12 +41,14 @@ theme_page(){
$(theme_header)
-
+ $(acl_write "$page" && printf %s \
+ ''
+ )
- $(wiki "$page" || printf 'Page not found')
+ $(wiki "$page" || printf 'Error while loading page
function "wiki" of index.sh returned with an error.')
$(theme_footer)
@@ -50,6 +60,14 @@ theme_editor(){
local page="$1" title
title="${page%/}"; title="${title##*/}"
+ if [ ! "$(mdfile "$page")" ]; then
+ theme_404
+ return 0
+ elif ! acl_write "$page"; then
+ theme_403
+ return 0
+ fi
+
# Important! Web Server response including newline
printf "%s\r\n" "Content-Type: text/html; charset=utf-8" ""
@@ -75,10 +93,50 @@ 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)
+ Attachments $(HTML "${title}")
+
+ $(theme_header)
+
+
+
+
+
+ $(theme_footer)
+
+ EOF
+ else
+ cat <<-EOF
$(theme_head)
@@ -93,27 +151,42 @@ 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(){
- theme_page '[wiki]/login/'
+ theme_page '/[wiki]/login/'
}
theme_register(){
- theme_page '[wiki]/register/'
+ theme_page '/[wiki]/register/'
+}
+
+theme_403(){
+ printf "%s\r\n" "Status: 403 Forbidden"
+
+ if [ "$(mdfile '/[wiki]/403/')" ]; then
+ theme_page '/[wiki]/403/'
+ else
+ printf "Content-Length: 0\r\n\r\n"
+ fi
}
theme_404(){
printf "%s\r\n" "Status: 404 Not Found"
- theme_page '[wiki]/404/'
+ if [ "$(mdfile '/[wiki]/404/')" ]; then
+ theme_page '/[wiki]/404/'
+ else
+ printf "Content-Length: 0\r\n\r\n"
+ fi
}