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 }