X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fwiki.c;h=c1ba90512e81491293a25063ed3daed1c501b48e;hb=dca4414169da8ea7161d5b95fc9ccbefe5d39651;hp=b7b03c1a0363e9885443263456f9d0b89a0be7b2;hpb=1bd684cdaefaae14ad8feb1d6adf2f7e4b6de8e4;p=citadel.git diff --git a/webcit/wiki.c b/webcit/wiki.c index b7b03c1a0..c1ba90512 100644 --- a/webcit/wiki.c +++ b/webcit/wiki.c @@ -1,11 +1,19 @@ /* - * $Id$ - * * Functions pertaining to rooms with a wiki view + * + * Copyright (c) 2009-2012 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. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. */ #include "webcit.h" -#include "groupdav.h" +#include "dav.h" /* * Convert a string to something suitable as a wiki index @@ -46,19 +54,19 @@ void display_wiki_page_backend(const StrBuf *roomname, char *pagename, char *rev if (StrLength(roomname) > 0) { /* If we're not in the correct room, try going there. */ - if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->wc_roomname))) { + if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->CurRoom.name))) { gotoroom(roomname); } /* If we're still not in the correct room, it doesn't exist. */ - if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->wc_roomname))) { + if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->CurRoom.name))) { wc_printf(_("There is no room called '%s'."), ChrPtr(roomname)); return; } } - if (WC->wc_view != VIEW_WIKI) { + if (WC->CurRoom.view != VIEW_WIKI) { wc_printf(_("'%s' is not a Wiki room."), ChrPtr(roomname)); return; } @@ -87,7 +95,7 @@ void display_wiki_page_backend(const StrBuf *roomname, char *pagename, char *rev return; } - wc_printf("

" + wc_printf("

" "
" "" "
" @@ -115,6 +123,7 @@ void display_wiki_page(void) output_headers(1, 1, 1, 0, 0, 0); roomname = sbstr("room"); safestrncpy(pagename, bstr("page"), sizeof pagename); + str_wiki_index(pagename); safestrncpy(rev, bstr("rev"), sizeof rev); do_revert = atoi(bstr("revert")); display_wiki_page_backend(roomname, pagename, rev, do_revert); @@ -139,12 +148,12 @@ void tmplput_display_wiki_history(StrBuf *Target, WCTemplputParams *TP) if (StrLength(roomname) > 0) { /* If we're not in the correct room, try going there. */ - if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->wc_roomname))) { + if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->CurRoom.name))) { gotoroom(roomname); } /* If we're still not in the correct room, it doesn't exist. */ - if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->wc_roomname))) { + if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->CurRoom.name))) { wc_printf(_("There is no room called '%s'."), ChrPtr(roomname)); return; } @@ -162,14 +171,12 @@ void tmplput_display_wiki_history(StrBuf *Target, WCTemplputParams *TP) StrBuf *author = NewStrBuf(); StrBuf *node = NewStrBuf(); - wc_printf("
" - "" - ); + wc_printf("
"); wc_printf("", _("Date")); wc_printf("", _("Author")); - while(StrBuf_ServGetln(Buf), strcmp(ChrPtr(Buf), "000")) { + while((StrBuf_ServGetln(Buf) >= 0) && strcmp(ChrPtr(Buf), "000")) { rev_date = extract_long(ChrPtr(Buf), 1); webcit_fmt_date(rev_date_displayed, sizeof rev_date_displayed, rev_date, DATEFMT_FULL); @@ -205,7 +212,7 @@ void tmplput_display_wiki_history(StrBuf *Target, WCTemplputParams *TP) ChrPtr(rev_uuid), _("(show)") ); - wc_printf("", + wc_printf("", bstr("page"), ChrPtr(rev_uuid), _("(revert)") @@ -244,7 +251,7 @@ void tmplput_display_wiki_history(StrBuf *Target, WCTemplputParams *TP) void display_wiki_history(void) { output_headers(1, 1, 1, 0, 0, 0); - do_template("wiki_history", NULL); + do_template("wiki_history"); wDumpContent(1); } @@ -261,37 +268,42 @@ void tmplput_display_wiki_pagelist(StrBuf *Target, WCTemplputParams *TP) roomname = sbstr("room"); if (StrLength(roomname) > 0) { /* If we're not in the correct room, try going there. */ - if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->wc_roomname))) { + if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->CurRoom.name))) { gotoroom(roomname); } /* If we're still not in the correct room, it doesn't exist. */ - if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->wc_roomname))) { + if (strcasecmp(ChrPtr(roomname), ChrPtr(WC->CurRoom.name))) { wc_printf(_("There is no room called '%s'."), ChrPtr(roomname)); return; } } - serv_printf("MSGS ALL|||4"); + if (!IsEmptyStr(bstr("query"))) { + serv_printf("MSGS SEARCH|%s||4", bstr("query")); /* search-reduced list */ + } + else { + serv_printf("MSGS ALL|||4"); /* full list */ + } + Buf = NewStrBuf(); StrBuf_ServGetln(Buf); if (GetServerStatus(Buf, NULL) == 1) { StrBuf *pagetitle = NewStrBuf(); - wc_printf("
" - "
%s%s%s%s
" /* FIXME make its own class */ - ); - + wc_printf("
"); wc_printf("", _("Page title")); - while(StrBuf_ServGetln(Buf), strcmp(ChrPtr(Buf), "000")) { + while((StrBuf_ServGetln(Buf) >= 0) && strcmp(ChrPtr(Buf), "000")) { StrBufExtract_token(pagetitle, Buf, 1, '|'); if (!bmstrcasestr((char *)ChrPtr(pagetitle), "_HISTORY_")) { /* no history pages */ wc_printf("", ((row%2) ? "#FFFFFF" : "#DDDDDD")); - wc_printf(""); + wc_printf(""); wc_printf("\n"); ++row; } @@ -305,12 +317,12 @@ void tmplput_display_wiki_pagelist(StrBuf *Target, WCTemplputParams *TP) /* - * Display a list of all pages in a Wiki room + * Display a list of all pages in a Wiki room. Search requests in a Wiki room also go here. */ void display_wiki_pagelist(void) { output_headers(1, 1, 1, 0, 0, 0); - do_template("wiki_pagelist", NULL); + do_template("wiki_pagelist"); wDumpContent(1); } @@ -319,17 +331,66 @@ int wiki_Cleanup(void **ViewSpecific) { char pagename[5]; safestrncpy(pagename, "home", sizeof pagename); - display_wiki_page_backend(WC->wc_roomname, pagename, "", 0); + display_wiki_page_backend(WC->CurRoom.name, pagename, "", 0); wDumpContent(1); return 0; } + +int ConditionalHaveWikiPage(StrBuf *Target, WCTemplputParams *TP) +{ + const char *page; + const char *pch; + long len; + + page = BSTR("page"); + GetTemplateTokenString(Target, TP, 2, &pch, &len); + return strcasecmp(page, pch) == 0; +} + + +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; +} + + +int wiki_PrintHeaderPage(SharedMessageStatus *Stat, void **ViewSpecific) +{ + /* this function was intentionaly left empty. */ + return 0; +} + +int wiki_GetParamsGetServerCall(SharedMessageStatus *Stat, + void **ViewSpecific, + long oper, + char *cmd, + long len, + char *filter, + long flen) +{ + if (oper == do_search) + display_wiki_pagelist(); + else + http_redirect("wiki?page=home"); + + return 300; +} + + void InitModule_WIKI (void) { RegisterReadLoopHandlerset( VIEW_WIKI, + wiki_GetParamsGetServerCall, + wiki_PrintHeaderPage, NULL, NULL, NULL, @@ -342,4 +403,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); }
%s
"); - escputs(ChrPtr(pagetitle)); /* FIXME make it linkable */ - wc_printf(""); + escputs(ChrPtr(pagetitle)); + wc_printf("