X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Froomtokens.c;h=57d21443ef342c3071900b984cf666ee4fa23056;hb=5d38a76f8f06640e3a3f097d584ac52336110f7c;hp=80561a457f60c9a45e1c88686af4e459acdbdeed;hpb=89b8bb84814b774301e9b33512cf23d53b17bc9a;p=citadel.git diff --git a/webcit/roomtokens.c b/webcit/roomtokens.c index 80561a457..57d21443e 100644 --- a/webcit/roomtokens.c +++ b/webcit/roomtokens.c @@ -1,24 +1,35 @@ /* * Lots of different room-related operations. + * + * Copyright (c) 1996-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 "webserver.h" +CtxType CTX_ROOMS = CTX_NONE; +CtxType CTX_FLOORS = CTX_NONE; /* * Embed the room banner * * got The information returned from a GOTO server command * navbar_style Determines which navigation buttons to display - * */ void tmplput_roombanner(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; - /* refresh current room states... */ - /* dosen't work??? gotoroom(NULL); */ + /* Refresh current room states. Doesn't work? gotoroom(NULL); */ + wc_printf("
\n"); /* The browser needs some information for its own use */ @@ -26,7 +37,7 @@ void tmplput_roombanner(StrBuf *Target, WCTemplputParams *TP) " room_is_trash = %d; \n" "\n", ((WC->CurRoom.RAFlags & UA_ISTRASH) != 0) - ); + ); /* * If the user happens to select the "make this my start page" link, @@ -36,38 +47,38 @@ void tmplput_roombanner(StrBuf *Target, WCTemplputParams *TP) if (WCC->Hdr->this_page == NULL) { WCC->Hdr->this_page = NewStrBuf(); } - StrBufPrintf(WCC->Hdr->this_page, - "dotskip?room=%s", - ChrPtr(WC->CurRoom.name) - ); + StrBufPrintf(WCC->Hdr->this_page, "dotskip?room=%s", ChrPtr(WC->CurRoom.name)); - do_template("roombanner", NULL); - /* roombanner contains this for mobile */ - if (WC->is_mobile) - return; + do_template("roombanner"); - do_template("navbar", NULL); + do_template("navbar"); wc_printf("
\n"); } /******************************************************************************* ********************** FLOOR Tokens ******************************************* - ******************************************************************************/ + *******************************************************************************/ + + void tmplput_FLOOR_ID(StrBuf *Target, WCTemplputParams *TP) { - Floor *myFloor = (Floor *)CTX; + Floor *myFloor = (Floor *)CTX(CTX_FLOORS); StrBufAppendPrintf(Target, "%d", myFloor->ID); } + + void tmplput_ROOM_FLOORID(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); StrBufAppendPrintf(Target, "%d", Folder->floorid); } + + void tmplput_ROOM_FLOOR_ID(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); const Floor *pFloor = Folder->Floor; if (pFloor == NULL) @@ -76,9 +87,10 @@ void tmplput_ROOM_FLOOR_ID(StrBuf *Target, WCTemplputParams *TP) StrBufAppendPrintf(Target, "%d", pFloor->ID); } + void tmplput_ROOM_FLOOR_NAME(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); const Floor *pFloor = Folder->Floor; if (pFloor == NULL) @@ -86,6 +98,8 @@ void tmplput_ROOM_FLOOR_NAME(StrBuf *Target, WCTemplputParams *TP) StrBufAppendTemplate(Target, TP, pFloor->Name, 0); } + + void tmplput_ThisRoomFloorName(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -101,31 +115,38 @@ void tmplput_ThisRoomFloorName(StrBuf *Target, WCTemplputParams *TP) StrBufAppendTemplate(Target, TP, pFloor->Name, 0); } + + void tmplput_FLOOR_NAME(StrBuf *Target, WCTemplputParams *TP) { - Floor *myFloor = (Floor *)CTX; + Floor *myFloor = (Floor *)CTX(CTX_FLOORS); StrBufAppendTemplate(Target, TP, myFloor->Name, 0); } + void tmplput_FLOOR_NROOMS(StrBuf *Target, WCTemplputParams *TP) { - Floor *myFloor = (Floor *)CTX; + Floor *myFloor = (Floor *)CTX(CTX_FLOORS); StrBufAppendPrintf(Target, "%d", myFloor->NRooms); } + + void tmplput_ROOM_FLOOR_NROOMS(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); const Floor *pFloor = Folder->Floor; if (pFloor == NULL) return; StrBufAppendPrintf(Target, "%d", pFloor->NRooms); } + + int ConditionalFloorHaveNRooms(StrBuf *Target, WCTemplputParams *TP) { - Floor *MyFloor = (Floor *)CTX; + Floor *MyFloor = (Floor *)CTX(CTX_FLOORS); int HaveN; HaveN = GetTemplateTokenNumber(Target, TP, 0, 0); @@ -133,20 +154,23 @@ int ConditionalFloorHaveNRooms(StrBuf *Target, WCTemplputParams *TP) return HaveN == MyFloor->NRooms; } + int ConditionalFloorIsRESTSubFloor(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; - Floor *MyFloor = (Floor *)CTX; + Floor *MyFloor = (Floor *)CTX(CTX_FLOORS); /** if we have dav_depth the client just wants the subfloors */ if ((WCC->Hdr->HR.dav_depth == 1) && (GetCount(WCC->Directory) == 0)) return 1; return WCC->CurrentFloor == MyFloor; } + + int ConditionalFloorIsSUBROOM(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; - Floor *MyFloor = (Floor *)CTX; + Floor *MyFloor = (Floor *)CTX(CTX_FLOORS); return WCC->CurRoom.floorid == MyFloor->ID; } @@ -154,47 +178,41 @@ int ConditionalFloorIsSUBROOM(StrBuf *Target, WCTemplputParams *TP) int ConditionalFloorIsVirtual(StrBuf *Target, WCTemplputParams *TP) { - Floor *MyFloor = (Floor *)CTX; + Floor *MyFloor = (Floor *)CTX(CTX_FLOORS); return MyFloor->ID == VIRTUAL_MY_FLOOR; } - /******************************************************************************* ********************** ROOM Tokens ******************************************** - ******************************************************************************/ + *******************************************************************************/ /**** Name ******/ -void tmplput_RoomName(StrBuf *Target, WCTemplputParams *TP) -{ - StrBufAppendTemplate(Target, TP, WC->CurRoom.name, 0); -} -void tmplput_current_room(StrBuf *Target, WCTemplputParams *TP) + +void tmplput_ThisRoom(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; - if (WCC != NULL) + if (WCC != NULL) { StrBufAppendTemplate(Target, TP, - WCC->CurRoom.name, - 0); + WCC->CurRoom.name, + 0 + ); + } } + + void tmplput_ROOM_NAME(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); - if (Folder == NULL) - { - wcsession *WCC = WC; - - if (WCC == NULL) - return; - Folder = &WCC->CurRoom; - } StrBufAppendTemplate(Target, TP, Folder->name, 0); } + + void tmplput_ROOM_BASENAME(StrBuf *Target, WCTemplputParams *TP) { - folder *room = (folder *)CTX; + folder *room = (folder *)CTX(CTX_ROOMS); if (room->nRoomNameParts > 1) StrBufAppendTemplate(Target, TP, @@ -202,9 +220,11 @@ void tmplput_ROOM_BASENAME(StrBuf *Target, WCTemplputParams *TP) else StrBufAppendTemplate(Target, TP, room->name, 0); } + + void tmplput_ROOM_LEVEL_N_TIMES(StrBuf *Target, WCTemplputParams *TP) { - folder *room = (folder *)CTX; + folder *room = (folder *)CTX(CTX_ROOMS); int i; const char *AppendMe; long AppendMeLen; @@ -217,13 +237,25 @@ void tmplput_ROOM_LEVEL_N_TIMES(StrBuf *Target, WCTemplputParams *TP) StrBufAppendBufPlain(Target, AppendMe, AppendMeLen, 0); } } + + int ConditionalRoomIsInbox(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); return Folder->is_inbox; } + /****** Properties ******/ +int ConditionalRoom_MayEdit(StrBuf *Target, WCTemplputParams *TP) +{ + wcsession *WCC = WC; + + LoadRoomXA (); + + return WCC->CurRoom.XALoaded == 1; +} + int ConditionalThisRoomHas_QRFlag(StrBuf *Target, WCTemplputParams *TP) { long QR_CheckFlag; @@ -243,6 +275,8 @@ int ConditionalThisRoomHas_QRFlag(StrBuf *Target, WCTemplputParams *TP) else return (WCC->CurRoom.QRFlags & QR_CheckFlag) == QR_CheckFlag; } + + int ConditionalRoomHas_QRFlag(StrBuf *Target, WCTemplputParams *TP) { long QR_CheckFlag; @@ -259,9 +293,11 @@ int ConditionalRoomHas_QRFlag(StrBuf *Target, WCTemplputParams *TP) else return (Folder->QRFlags & QR_CheckFlag) == QR_CheckFlag; } + + void tmplput_ROOM_QRFLAGS(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); StrBufAppendPrintf(Target, "%d", Folder->QRFlags); } @@ -286,6 +322,8 @@ int ConditionalThisRoomHas_QRFlag2(StrBuf *Target, WCTemplputParams *TP) else return (WCC->CurRoom.QRFlags2 & QR2_CheckFlag) == QR2_CheckFlag; } + + int ConditionalRoomHas_QRFlag2(StrBuf *Target, WCTemplputParams *TP) { long QR2_CheckFlag; @@ -298,6 +336,7 @@ int ConditionalRoomHas_QRFlag2(StrBuf *Target, WCTemplputParams *TP) return ((Folder->QRFlags2 & QR2_CheckFlag) != 0); } + int ConditionalRoomHas_UAFlag(StrBuf *Target, WCTemplputParams *TP) { folder *Folder = (folder *)(TP->Context); @@ -312,18 +351,14 @@ int ConditionalRoomHas_UAFlag(StrBuf *Target, WCTemplputParams *TP) } - - - void tmplput_ROOM_ACL(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); StrBufAppendPrintf(Target, "%ld", Folder->RAFlags, 0); } - void tmplput_ROOM_RAFLAGS(StrBuf *Target, WCTemplputParams *TP) { folder *Folder = (folder *)(TP->Context); @@ -339,6 +374,8 @@ void tmplput_ThisRoomAide(StrBuf *Target, WCTemplputParams *TP) StrBufAppendTemplate(Target, TP, WCC->CurRoom.RoomAide, 0); } + + int ConditionalRoomAide(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -346,6 +383,7 @@ int ConditionalRoomAide(StrBuf *Target, WCTemplputParams *TP) ((WCC->CurRoom.RAFlags & UA_ADMINALLOWED) != 0) : 0; } + int ConditionalRoomAcessDelete(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -356,30 +394,30 @@ int ConditionalRoomAcessDelete(StrBuf *Target, WCTemplputParams *TP) } - int ConditionalHaveRoomeditRights(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; - return ( (WCC!= NULL) && - ((WCC->axlevel >= 6) || - ((WCC->CurRoom.RAFlags & UA_ADMINALLOWED) != 0) || - (WCC->CurRoom.is_inbox) )); + return ( (WCC != NULL) + && (WCC->logged_in) + && ( + (WCC->axlevel >= 6) + || ((WCC->CurRoom.RAFlags & UA_ADMINALLOWED) != 0) + || (WCC->CurRoom.is_inbox) + ) + ); } + + void tmplput_ThisRoomPass(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; LoadRoomXA(); - StrBufAppendTemplate(Target, TP, WCC->CurRoom.XAPass, 0); } - - - - void tmplput_ThisRoom_nNewMessages(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -387,6 +425,7 @@ void tmplput_ThisRoom_nNewMessages(StrBuf *Target, WCTemplputParams *TP) StrBufAppendPrintf(Target, "%d", WCC->CurRoom.nNewMessages); } + void tmplput_ThisRoom_nTotalMessages(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -395,10 +434,6 @@ void tmplput_ThisRoom_nTotalMessages(StrBuf *Target, WCTemplputParams *TP) } - - - - void tmplput_ThisRoomOrder(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -408,6 +443,7 @@ void tmplput_ThisRoomOrder(StrBuf *Target, WCTemplputParams *TP) StrBufAppendPrintf(Target, "%d", WCC->CurRoom.Order); } + int ConditionalThisRoomOrder(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -422,16 +458,14 @@ int ConditionalThisRoomOrder(StrBuf *Target, WCTemplputParams *TP) return CheckThis == WCC->CurRoom.Order; } + void tmplput_ROOM_LISTORDER(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); StrBufAppendPrintf(Target, "%d", Folder->Order); } - - - int ConditionalThisRoomXHavePic(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -454,6 +488,8 @@ int ConditionalThisRoomXHaveInfoText(StrBuf *Target, WCTemplputParams *TP) LoadXRoomInfoText(); return (StrLength(WCC->CurRoom.XInfoText)>0); } + + void tmplput_ThisRoomInfoText(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -468,32 +504,25 @@ void tmplput_ThisRoomInfoText(StrBuf *Target, WCTemplputParams *TP) } else { /* only a certain number of characters */ - StrBuf *SubBuf = NewStrBuf(); - StrBufSub(SubBuf, WCC->CurRoom.XInfoText, 0, nchars); - StrBufAppendBufPlain(SubBuf, HKEY("..."), 0); + StrBuf *SubBuf; + SubBuf = NewStrBufDup(WCC->CurRoom.XInfoText); + if (StrLength(SubBuf) > nchars) { + StrBuf_Utf8StrCut(SubBuf, nchars); + StrBufAppendBufPlain(SubBuf, HKEY("..."), 0); + } StrBufAppendTemplate(Target, TP, SubBuf, 1); FreeStrBuf(&SubBuf); } } - - - - void tmplput_ROOM_LASTCHANGE(StrBuf *Target, WCTemplputParams *TP) { - folder *Folder = (folder *)CTX; + folder *Folder = (folder *)CTX(CTX_ROOMS); StrBufAppendPrintf(Target, "%d", Folder->lastchange); } - - - - - - void tmplput_ThisRoomDirectory(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -502,6 +531,8 @@ void tmplput_ThisRoomDirectory(StrBuf *Target, WCTemplputParams *TP) StrBufAppendTemplate(Target, TP, WCC->CurRoom.Directory, 0); } + + void tmplput_ThisRoomXNFiles(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -511,6 +542,7 @@ void tmplput_ThisRoomXNFiles(StrBuf *Target, WCTemplputParams *TP) StrBufAppendPrintf(Target, "%d", WCC->CurRoom.XDownloadCount); } + void tmplput_ThisRoomX_FileString(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; @@ -524,10 +556,26 @@ void tmplput_ThisRoomX_FileString(StrBuf *Target, WCTemplputParams *TP) } +int ConditionalIsThisThatRoom(StrBuf *Target, WCTemplputParams *TP) +{ + folder *Folder = (folder *)CTX(CTX_ROOMS); + wcsession *WCC = WC; + + if (WCC == NULL) + return 0; + + return Folder == WCC->ThisRoom; +} + + void InitModule_ROOMTOKENS (void) { + /* we duplicate this, just to be shure its already done. */ + RegisterCTX(CTX_ROOMS); + RegisterCTX(CTX_FLOORS); + RegisterNamespace("ROOMBANNER", 0, 1, tmplput_roombanner, NULL, CTX_NONE); RegisterNamespace("FLOOR:ID", 0, 0, tmplput_FLOOR_ID, NULL, CTX_FLOORS); @@ -548,10 +596,9 @@ InitModule_ROOMTOKENS /**** Room... ******/ /**** Name ******/ - RegisterNamespace("ROOMNAME", 0, 1, tmplput_RoomName, NULL, CTX_NONE); - RegisterNamespace("CURRENT_ROOM", 0, 1, tmplput_current_room, NULL, CTX_NONE); + RegisterNamespace("THISROOM:NAME", 0, 1, tmplput_ThisRoom, NULL, CTX_NONE); + RegisterNamespace("ROOM:INFO:NAME", 0, 1, tmplput_ROOM_NAME, NULL, CTX_ROOMS); - RegisterNamespace("ROOM:INFO:PRINT_NAME", 0, 1, tmplput_ROOM_NAME, NULL, CTX_NONE); RegisterNamespace("ROOM:INFO:BASENAME", 0, 1, tmplput_ROOM_BASENAME, NULL, CTX_ROOMS); RegisterNamespace("ROOM:INFO:LEVELNTIMES", 1, 2, tmplput_ROOM_LEVEL_N_TIMES, NULL, CTX_ROOMS); RegisterConditional(HKEY("COND:ROOM:INFO:IS_INBOX"), 0, ConditionalRoomIsInbox, CTX_ROOMS); @@ -559,6 +606,7 @@ InitModule_ROOMTOKENS /****** Properties ******/ RegisterNamespace("ROOM:INFO:QRFLAGS", 0, 1, tmplput_ROOM_QRFLAGS, NULL, CTX_ROOMS); RegisterConditional(HKEY("COND:THISROOM:FLAG:QR"), 0, ConditionalThisRoomHas_QRFlag, CTX_NONE); + RegisterConditional(HKEY("COND:THISROOM:EDIT"), 0, ConditionalRoom_MayEdit, CTX_NONE); RegisterConditional(HKEY("COND:ROOM:FLAG:QR"), 0, ConditionalRoomHas_QRFlag, CTX_ROOMS); RegisterConditional(HKEY("COND:THISROOM:FLAG:QR2"), 0, ConditionalThisRoomHas_QRFlag2, CTX_NONE); @@ -592,10 +640,6 @@ InitModule_ROOMTOKENS RegisterNamespace("THISROOM:FILES:STR", 0, 1, tmplput_ThisRoomX_FileString, NULL, CTX_NONE); RegisterNamespace("THISROOM:DIRECTORY", 0, 1, tmplput_ThisRoomDirectory, NULL, CTX_NONE); - - - - - RegisterNamespace("ROOM:INFO:ACL", 0, 1, tmplput_ROOM_ACL, NULL, CTX_ROOMS); + RegisterConditional(HKEY("COND:THIS:THAT:ROOM"), 0, ConditionalIsThisThatRoom, CTX_ROOMS); }