/*
* Functions pertaining to rooms with a wiki view
*
- * Copyright (c) 2009-2012 by the citadel.org team
+ * Copyright (c) 2009-2018 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);
}
/*
* "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)
{
+ wcsession *WCC = WC;
const StrBuf *Mime;
long msgnum = (-1L);
char buf[256];
- if (WC->CurRoom.view != VIEW_WIKI) {
- wc_printf(_("'%s' is not a Wiki room."), ChrPtr(WC->CurRoom.name) );
+ if ((WCC->CurRoom.view != VIEW_WIKI) &&
+ (WCC->CurRoom.view != VIEW_WIKIMD)) {
+ wc_printf(_("'%s' is not a Wiki room."), ChrPtr(WCC->CurRoom.name) );
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);
}
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(WCC->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");
}
*/
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"));
*/
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) {
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"));
}
else {
- wc_printf("<td><a href=\"wiki?page=%s?rev=%s\">%s</a></td>",
+ wc_printf("<td><a href=\"wiki?page=%s?rev=%s",
bstr("page"),
- ChrPtr(rev_uuid),
- _("(show)")
+ ChrPtr(rev_uuid)
);
+ wc_printf("?go="); urlescputs(ChrPtr(WC->CurRoom.name));
+ wc_printf("\">%s</a></td>", _("(show)"));
wc_printf("<td><a href=\"javascript:GetLoggedInFirst(encodeURIComponent('wiki?page=%s?rev=%s?revert=1'))\">%s</a></td>",
bstr("page"),
ChrPtr(rev_uuid),
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;
NULL,
NULL,
NULL,
- wiki_Cleanup
+ wiki_Cleanup,
+ NULL
+ );
+
+ RegisterReadLoopHandlerset(
+ VIEW_WIKIMD,
+ wiki_GetParamsGetServerCall,
+ wiki_PrintHeaderPage,
+ NULL,
+ NULL,
+ NULL,
+ NULL,
+ wiki_Cleanup,
+ NULL
);
WebcitAddUrlHandler(HKEY("wiki"), "", 0, display_wiki_page, 0);
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);
}