+++ /dev/null
-/*
- * Lots of different room-related operations.
- */
-
-#include "webcit.h"
-#include "webserver.h"
-
-char *viewdefs[VIEW_MAX];
-
-/*
- * This table defines which views may be selected as the
- * default view for a room at the time of its creation.
- */
-int allowed_default_views[VIEW_MAX] = {
- 1, /* VIEW_BBS Bulletin board */
- 1, /* VIEW_MAILBOX Mailbox summary */
- 1, /* VIEW_ADDRESSBOOK Address book */
- 1, /* VIEW_CALENDAR Calendar */
- 1, /* VIEW_TASKS Tasks */
- 1, /* VIEW_NOTES Notes */
- 1, /* VIEW_WIKI Wiki */
- 0, /* VIEW_CALBRIEF Brief Calendar */
- 0, /* VIEW_JOURNAL Journal */
- 0, /* VIEW_DRAFTS Drafts */
- 1, /* VIEW_BLOG Blog */
- 0 /* VIEW_QUEUE Mail Queue */
-};
-
-/*
- * Given the default view for a room, this table defines
- * which alternate views may be selected by the user.
- */
-ROOM_VIEWS exchangeable_views[VIEW_MAX][VIEW_MAX] = {
- { 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0 }, /* bulletin board */
- { 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0 }, /* mailbox summary */
- { 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, /* address book */
- { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0 }, /* calendar */
- { 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0 }, /* tasks */
- { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 }, /* notes */
- { 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0 }, /* wiki */
- { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0 }, /* brief calendar */
- { 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0 }, /* journal */
- { 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0 }, /* drafts */
- { 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0 }, /* blog */
-};
-
-/*
- * Initialize the viewdefs with localized strings
- */
-void initialize_viewdefs(void) {
- viewdefs[VIEW_BBS] = _("Bulletin Board");
- viewdefs[VIEW_MAILBOX] = _("Mail Folder");
- viewdefs[VIEW_ADDRESSBOOK] = _("Address Book");
- viewdefs[VIEW_CALENDAR] = _("Calendar");
- viewdefs[VIEW_TASKS] = _("Task List");
- viewdefs[VIEW_NOTES] = _("Notes List");
- viewdefs[VIEW_WIKI] = _("Wiki");
- viewdefs[VIEW_CALBRIEF] = _("Calendar List");
- viewdefs[VIEW_JOURNAL] = _("Journal");
- viewdefs[VIEW_DRAFTS] = _("Drafts");
- viewdefs[VIEW_BLOG] = _("Blog");
-}
-
-
-void tmplput_ROOM_COLLECTIONTYPE(StrBuf *Target, WCTemplputParams *TP)
-{
- folder *Folder = (folder *)CTX(CTX_ROOMS);
-
- switch(Folder->view) {
- case VIEW_CALENDAR:
- StrBufAppendBufPlain(Target, HKEY("vevent"), 0);
- break;
- case VIEW_TASKS:
- StrBufAppendBufPlain(Target, HKEY("vtodo"), 0);
- break;
- case VIEW_ADDRESSBOOK:
- StrBufAppendBufPlain(Target, HKEY("vcard"), 0);
- break;
- case VIEW_NOTES:
- StrBufAppendBufPlain(Target, HKEY("vnotes"), 0);
- break;
- case VIEW_JOURNAL:
- StrBufAppendBufPlain(Target, HKEY("vjournal"), 0);
- break;
- case VIEW_WIKI:
- StrBufAppendBufPlain(Target, HKEY("wiki"), 0);
- break;
- }
-}
-
-
-
-int ConditionalRoomHasGroupdavContent(StrBuf *Target, WCTemplputParams *TP)
-{
- folder *Folder = (folder *)CTX(CTX_ROOMS);
-
- syslog(LOG_DEBUG, "-> %s: %d\n", ChrPtr(Folder->name), Folder->view);
-
- return ((Folder->view == VIEW_CALENDAR) ||
- (Folder->view == VIEW_TASKS) ||
- (Folder->view == VIEW_ADDRESSBOOK) ||
- (Folder->view == VIEW_NOTES) ||
- (Folder->view == VIEW_JOURNAL) );
-}
-
-
-
-
-int ConditionalIsRoomtype(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
-
- if ((WCC == NULL) ||
- (TP->Tokens->nParameters < 3))
- {
- return ((WCC->CurRoom.view < VIEW_BBS) ||
- (WCC->CurRoom.view > VIEW_MAX));
- }
-
- return WCC->CurRoom.view == GetTemplateTokenNumber(Target, TP, 2, VIEW_BBS);
-}
-
-
-void tmplput_CurrentRoomViewString(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
- StrBuf *Buf;
-
- if ((WCC == NULL) ||
- (WCC->CurRoom.defview >= VIEW_MAX) ||
- (WCC->CurRoom.defview < VIEW_BBS))
- {
- LogTemplateError(Target, "Token", ERR_PARM2, TP,
- "Roomview [%ld] not valid\n",
- (WCC != NULL)?
- WCC->CurRoom.defview : -1);
- return;
- }
-
- Buf = NewStrBufPlain(_(viewdefs[WCC->CurRoom.defview]), -1);
- StrBufAppendTemplate(Target, TP, Buf, 0);
- FreeStrBuf(&Buf);
-}
-
-void tmplput_RoomViewString(StrBuf *Target, WCTemplputParams *TP)
-{
- long CheckThis;
- StrBuf *Buf;
-
- CheckThis = GetTemplateTokenNumber(Target, TP, 0, 0);
- if ((CheckThis >= VIEW_MAX) || (CheckThis < VIEW_BBS))
- {
- LogTemplateError(Target, "Token", ERR_PARM2, TP,
- "Roomview [%ld] not valid\n",
- CheckThis);
- return;
- }
-
- Buf = NewStrBufPlain(_(viewdefs[CheckThis]), -1);
- StrBufAppendTemplate(Target, TP, Buf, 0);
- FreeStrBuf(&Buf);
-}
-
-
-
-int ConditionalIsAllowedDefaultView(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
- long CheckThis;
-
- if (WCC == NULL)
- return 0;
-
- CheckThis = GetTemplateTokenNumber(Target, TP, 2, 0);
- if ((CheckThis >= VIEW_MAX) || (CheckThis < VIEW_BBS))
- {
- LogTemplateError(Target, "Conditional", ERR_PARM2, TP,
- "Roomview [%ld] not valid\n",
- CheckThis);
- return 0;
- }
-
- return allowed_default_views[CheckThis] != 0;
-}
-
-int ConditionalThisRoomDefView(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
- long CheckThis;
-
- if (WCC == NULL)
- return 0;
-
- CheckThis = GetTemplateTokenNumber(Target, TP, 2, 0);
- return CheckThis == WCC->CurRoom.defview;
-}
-
-int ConditionalThisRoomCurrView(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
- long CheckThis;
-
- if (WCC == NULL)
- return 0;
-
- CheckThis = GetTemplateTokenNumber(Target, TP, 2, 0);
- return CheckThis == WCC->CurRoom.view;
-}
-
-int ConditionalThisRoomHaveView(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
- long CheckThis;
-
- if (WCC == NULL)
- return 0;
-
- CheckThis = GetTemplateTokenNumber(Target, TP, 2, 0);
- if ((CheckThis >= VIEW_MAX) || (CheckThis < VIEW_BBS))
- {
- LogTemplateError(Target, "Conditional", ERR_PARM2, TP,
- "Roomview [%ld] not valid\n",
- CheckThis);
- return 0;
- }
-
- return exchangeable_views [WCC->CurRoom.defview][CheckThis] ;
-}
-
-void tmplput_ROOM_VIEW(StrBuf *Target, WCTemplputParams *TP)
-{
- folder *Folder = (folder *)CTX(CTX_ROOMS);
- StrBufAppendPrintf(Target, "%d", Folder->view);
-}
-void tmplput_ROOM_DEFVIEW(StrBuf *Target, WCTemplputParams *TP)
-{
- folder *Folder = (folder *)CTX(CTX_ROOMS);
- StrBufAppendPrintf(Target, "%d", Folder->defview);
-}
-
-
-void tmplput_CurrentRoomDefView(StrBuf *Target, WCTemplputParams *TP)
-{
- wcsession *WCC = WC;
-
- StrBufAppendPrintf(Target, "%d", WCC->CurRoom.defview);
-}
-
-void
-InitModule_ROOMVIEWS
-(void)
-{
- /* we duplicate this, just to be shure its already done. */
- RegisterCTX(CTX_ROOMS);
- RegisterCTX(CTX_FLOORS);
-
- initialize_viewdefs();
-
- RegisterNamespace("THISROOM:VIEW_STRING", 0, 1, tmplput_CurrentRoomViewString, NULL, CTX_NONE);
- RegisterNamespace("ROOM:VIEW_STRING", 1, 2, tmplput_RoomViewString, NULL, CTX_NONE);
-
- RegisterConditional("COND:ALLOWED_DEFAULT_VIEW", 0, ConditionalIsAllowedDefaultView, CTX_NONE);
- RegisterConditional("COND:THISROOM:DEFAULT_VIEW", 0, ConditionalThisRoomDefView, CTX_NONE);
- RegisterNamespace("THISROOM:DEFAULT_VIEW", 0, 0, tmplput_CurrentRoomDefView, NULL, CTX_NONE);
- RegisterNamespace("ROOM:INFO:DEFVIEW", 0, 1, tmplput_ROOM_DEFVIEW, NULL, CTX_ROOMS);
-
- RegisterConditional("COND:ROOM:TYPE_IS", 0, ConditionalIsRoomtype, CTX_NONE);
-
- RegisterConditional("COND:THISROOM:HAVE_VIEW", 0, ConditionalThisRoomHaveView, CTX_NONE);
- RegisterConditional("COND:ROOM:DAV_CONTENT", 0, ConditionalRoomHasGroupdavContent, CTX_ROOMS);
-
- RegisterConditional("COND:THISROOM:CURR_VIEW", 0, ConditionalThisRoomCurrView, CTX_NONE);
- RegisterNamespace("ROOM:INFO:VIEW", 0, 1, tmplput_ROOM_VIEW, NULL, CTX_ROOMS);
-
- RegisterNamespace("ROOM:INFO:COLLECTIONTYPE", 0, 1, tmplput_ROOM_COLLECTIONTYPE, NULL, CTX_ROOMS);
-
-
-
-}