Expose wiki pages to the site map
authorArt Cancro <ajc@citadel.org>
Tue, 11 Jan 2011 04:59:15 +0000 (23:59 -0500)
committerWilfried Goesgens <dothebart@citadel.org>
Sun, 4 Sep 2011 13:54:01 +0000 (13:54 +0000)
webcit/sitemap.c

index 6af3b49be2e691271862ed55611ed2ea3610634b..fd94266beb64116bc293b4c641c6a8014fad25e4 100644 (file)
@@ -1,7 +1,7 @@
 /*
  * XML sitemap generator
  *
- * Copyright (c) 2010 by the citadel.org team
+ * Copyright (c) 2010-2011 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 as published by
@@ -23,9 +23,9 @@
 
 
 /*
- * XML sitemap generator -- go through the message list
+ * XML sitemap generator -- go through the message list for a BBS room
  */
-void sitemap_do_messages(void) {
+void sitemap_do_bbs(void) {
        wcsession *WCC = WC;
        int num_msgs = 0;
        int i;
@@ -52,6 +52,47 @@ void sitemap_do_messages(void) {
 }
 
 
+/*
+ * XML sitemap generator -- go through the message list for a wiki room
+ * (this might work for blogs too; we'll see)
+ */
+void sitemap_do_wiki(void) {
+       wcsession *WCC = WC;
+       int num_msgs = 0;
+       int i;
+       SharedMessageStatus Stat;
+       message_summary *Msg = NULL;
+       char buf[256];
+
+       memset(&Stat, 0, sizeof Stat);
+       Stat.maxload = INT_MAX;
+       Stat.lowest_found = (-1);
+       Stat.highest_found = (-1);
+       num_msgs = load_msg_ptrs("MSGS ALL", &Stat, NULL);
+       if (num_msgs < 1) return;
+
+       for (i=0; i<num_msgs; ++i) {
+               Msg = GetMessagePtrAt(i, WCC->summ);
+               if (Msg != NULL) {
+
+                       serv_printf("MSG0 %ld|3", Msg->msgnum);
+                       serv_getln(buf, sizeof buf);
+                       if (buf[0] == '1') while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+                               if (    (!strncasecmp(buf, "exti=", 5))
+                                       && (!bmstrcasestr(buf, "_HISTORY_"))
+                               ) {
+                                       wc_printf("<url><loc>%s/wiki", ChrPtr(site_prefix));
+                                       wc_printf("?go=");
+                                       urlescputs(ChrPtr(WC->CurRoom.name));
+                                       wc_printf("?page=%s", &buf[5]);
+                                       wc_printf("</loc></url>\r\n");
+                               }
+                       }
+               }
+       }
+}
+
+
 /*
  * Entry point for RSS feed generator
  */
@@ -78,11 +119,18 @@ void sitemap(void) {
 
        while (GetNextHashPos(roomlist, it, &HKlen, &HashKey, (void *)&room))
        {
-               /* Output the messages in this room only if it's a message board */
-               if (room->defview == VIEW_BBS)
-               {
+               /* Output the messages in this room only if it's a room type we can make sense of */
+               switch(room->defview) {
+               case VIEW_BBS:
+                       gotoroom(room->name);
+                       sitemap_do_bbs();
+                       break;
+               case VIEW_WIKI:
                        gotoroom(room->name);
-                       sitemap_do_messages();
+                       sitemap_do_wiki();
+                       break;
+               default:
+                       break;
                }
        }