final touches on dkim test harness
[citadel.git] / webcit / wiki.c
index 47af67ec4170f276b06deb8cb6c30d14694c1c3b..390bf3cbea7e84203eca49ded48c5186552a05e5 100644 (file)
@@ -1,7 +1,7 @@
 /*
  * Functions pertaining to rooms with a wiki view
  *
- * Copyright (c) 2009-2012 by the citadel.org team
+ * Copyright (c) 2009-2021 by the citadel.org team
  *
  * This program is open source software.  You can redistribute it and/or
  * modify it under the terms of the GNU General Public License, version 3.
 /* 
  * Convert a string to something suitable as a wiki index
  */
-void str_wiki_index(char *s)
+void str_wiki_index(StrBuf *s)
 {
-       int i;
-
-       if (s == NULL) return;
-
-       /* First remove all non-alphanumeric characters */
-       for (i=0; i<strlen(s); ++i) {
-               if (!isalnum(s[i])) {
-                       strcpy(&s[i], &s[i+1]);
-               }
-       }
-
-       /* Then make everything lower case */
-       for (i=0; i<strlen(s); ++i) {
-               s[i] = tolower(s[i]);
-       }
+       StrBufSanitizeAscii(s, '_');
+       StrBufLowerCase(s);
 }
 
 /*
@@ -43,7 +30,7 @@ void str_wiki_index(char *s)
  * "rev" may be set to an empty string to display the current version.
  * "do_revert" may be set to nonzero to perform a reversion to the specified version.
  */
-void display_wiki_page_backend(char *pagename, char *rev, int do_revert)
+void display_wiki_page_backend(StrBuf *pagename, char *rev, int do_revert)
 {
        const StrBuf *Mime;
        long msgnum = (-1L);
@@ -54,15 +41,15 @@ void display_wiki_page_backend(char *pagename, char *rev, int do_revert)
                return;
        }
 
-       if (IsEmptyStr(pagename)) {
-               strcpy(pagename, "home");
+       if (StrLength(pagename) == 0) {
+               StrBufPlain(pagename, HKEY("home"));
        }
 
        str_wiki_index(pagename);       /* convert index name to lowercase and numeric only */
 
        if ((rev != NULL) && (strlen(rev) > 0)) {
                /* read an older revision */
-               serv_printf("WIKI rev|%s|%s|%s", pagename, rev, (do_revert ? "revert" : "fetch") );
+               serv_printf("WIKI rev|%s|%s|%s", ChrPtr(pagename), rev, (do_revert ? "revert" : "fetch") );
                serv_getln(buf, sizeof buf);
                if (buf[0] == '2') {
                        msgnum = extract_long(&buf[4], 0);
@@ -70,26 +57,15 @@ void display_wiki_page_backend(char *pagename, char *rev, int do_revert)
        }
        else {
                /* read the current revision */
-               msgnum = locate_message_by_uid(pagename);
+               msgnum = locate_message_by_uid(ChrPtr(pagename));
        }
 
        if (msgnum >= 0L) {
-               read_message(WC->WBuf, HKEY("view_message"), msgnum, NULL, &Mime);
+               read_message(WC->WBuf, HKEY("view_message"), msgnum, NULL, &Mime, NULL);
                return;
        }
-
-       wc_printf("<br><br>"
-               "<div align=\"center\">"
-               "<table border=\"0\" bgcolor=\"#ffffff\" cellpadding=\"10\">"
-               "<tr><td align=\"center\">"
-       );
-       wc_printf("<br><b>");
-       wc_printf(_("There is no page called '%s' here."), pagename);
-       wc_printf("</b><br><br>");
-       wc_printf(_("Select the 'Edit this page' link in the room banner "
-               "if you would like to create this page."));
-       wc_printf("<br><br>");
-       wc_printf("</td></tr></table></div>\n");
+       putbstr("pagename", pagename);
+       do_template("wiki_empty");
 }
 
 
@@ -98,12 +74,12 @@ void display_wiki_page_backend(char *pagename, char *rev, int do_revert)
  */
 void display_wiki_page(void)
 {
-       char pagename[128];
+       StrBuf *pagename;
        char rev[128];
        int do_revert = 0;
 
        output_headers(1, 1, 1, 0, 0, 0);
-       safestrncpy(pagename, bstr("page"), sizeof pagename);
+       pagename = NewStrBufDup(sbstr("page"));
        str_wiki_index(pagename);
        safestrncpy(rev, bstr("rev"), sizeof rev);
        do_revert = atoi(bstr("revert"));
@@ -117,14 +93,14 @@ void display_wiki_page(void)
  */
 void tmplput_display_wiki_history(StrBuf *Target, WCTemplputParams *TP)
 {
-       char pagename[128];
+       StrBuf *pagename;
        StrBuf *Buf;
        int row = 0;
 
-       safestrncpy(pagename, bstr("page"), sizeof pagename);
+       pagename = NewStrBufDup(sbstr("page"));
        str_wiki_index(pagename);
 
-       serv_printf("WIKI history|%s", pagename);
+       serv_printf("WIKI history|%s", ChrPtr(pagename));
        Buf = NewStrBuf();
        StrBuf_ServGetln(Buf);
        if (GetServerStatus(Buf, NULL) == 1) {
@@ -148,19 +124,11 @@ void tmplput_display_wiki_history(StrBuf *Target, WCTemplputParams *TP)
 
                        wc_printf("<tr bgcolor=\"%s\">", ((row%2) ? "#FFFFFF" : "#DDDDDD"));
                        wc_printf("<td>%s</td><td>", rev_date_displayed);
-                       if (!strcasecmp(ChrPtr(node), (char *)WC->serv_info->serv_nodename)) {
-                               escputs(ChrPtr(author));
-                               wc_printf(" @ ");
-                               escputs(ChrPtr(node));
-                       }
-                       else {
-                               wc_printf("<a href=\"showuser?who=");
-                               urlescputs(ChrPtr(author));
-                               wc_printf("\">");
-                               escputs(ChrPtr(author));
-                               wc_printf("</a>");
-                       }
-                       wc_printf("</td>");
+                       wc_printf("<a href=\"showuser?who=");
+                       urlescputs(ChrPtr(author));
+                       wc_printf("\">");
+                       escputs(ChrPtr(author));
+                       wc_printf("</a></td>");
 
                        if (row == 0) {
                                wc_printf("<td><a href=\"wiki?page=%s", bstr("page"));
@@ -278,8 +246,8 @@ void display_wiki_pagelist(void)
 
 int wiki_Cleanup(void **ViewSpecific)
 {
-       char pagename[5];
-       safestrncpy(pagename, "home", sizeof pagename);
+       StrBuf *pagename;
+       pagename = NewStrBufDup(sbstr("page"));
        display_wiki_page_backend(pagename, "", 0);
        wDumpContent(1);
        return 0;
@@ -300,12 +268,11 @@ int ConditionalHaveWikiPage(StrBuf *Target, WCTemplputParams *TP)
 
 int ConditionalHavewikiType(StrBuf *Target, WCTemplputParams *TP)
 {
-       wcsession *WCC = WC;
        const char *pch;
        long len;
 
        GetTemplateTokenString(Target, TP, 2, &pch, &len);
-       return bmstrcasestr((char *)ChrPtr(WCC->Hdr->HR.ReqLine), pch) != NULL;
+       return bmstrcasestr((char *)ChrPtr(WC->Hdr->HR.ReqLine), pch) != NULL;
 }
 
 
@@ -344,7 +311,8 @@ InitModule_WIKI
                NULL,
                NULL,
                NULL,
-               wiki_Cleanup
+               wiki_Cleanup,
+               NULL
        );
 
        WebcitAddUrlHandler(HKEY("wiki"), "", 0, display_wiki_page, 0);
@@ -352,6 +320,6 @@ InitModule_WIKI
        WebcitAddUrlHandler(HKEY("wiki_pagelist"), "", 0, display_wiki_pagelist, 0);
        RegisterNamespace("WIKI:DISPLAYHISTORY", 0, 0, tmplput_display_wiki_history, NULL, CTX_NONE);
        RegisterNamespace("WIKI:DISPLAYPAGELIST", 0, 0, tmplput_display_wiki_pagelist, NULL, CTX_NONE);
-       RegisterConditional(HKEY("COND:WIKI:PAGE"), 1, ConditionalHaveWikiPage, CTX_NONE);
-       RegisterConditional(HKEY("COND:WIKI:TYPE"), 1, ConditionalHavewikiType, CTX_NONE);
+       RegisterConditional("COND:WIKI:PAGE", 1, ConditionalHaveWikiPage, CTX_NONE);
+       RegisterConditional("COND:WIKI:TYPE", 1, ConditionalHavewikiType, CTX_NONE);
 }