};
/* the brief calendar view is disabled: VIEW_CALBRIEF */
+ROOM_VIEWS allowed_default_views[VIEW_MAX] = {
+ 1, /* VIEW_BBS Bulletin board view */
+ 1, /* VIEW_MAILBOX Mailbox summary */
+ 1, /* VIEW_ADDRESSBOOK Address book view */
+ 1, /* VIEW_CALENDAR Calendar view */
+ 1, /* VIEW_TASKS Tasks view */
+ 1, /* VIEW_NOTES Notes view */
+ 1, /* VIEW_WIKI Wiki view */
+ 0, /* VIEW_CALBRIEF Brief Calendar view */
+ 0, /* VIEW_JOURNAL Journal view */
+ 0 /* VIEW_BLOG Blog view (not yet implemented) */
+};
+
+
/*
* Initialize the viewdefs with localized strings
*/
viewdefs[VIEW_BLOG] = _("Blog");
}
-/*
- * Determine which views are allowed as the default for creating a new room.
- */
-int is_view_allowed_as_default(int which_view)
-{
- switch(which_view) {
- case VIEW_BBS: return(1);
- case VIEW_MAILBOX: return(1);
- case VIEW_ADDRESSBOOK: return(1);
- case VIEW_CALENDAR: return(1);
- case VIEW_TASKS: return(1);
- case VIEW_NOTES: return(1);
- case VIEW_WIKI: return(1);
- case VIEW_CALBRIEF: return(0);
- case VIEW_JOURNAL: return(0);
- default: return(0); /* should never get here */
- }
-}
/*
* load the list of floors
- */
+ * /
void load_floorlist(StrBuf *Buf)
{
int a;
extract_token(floorlist[StrBufExtract_int(Buf, 0, '|')], ChrPtr(Buf), 1, '|', sizeof floorlist[0]);
}
}
-
-
-
-
-/*
- * display rooms in tree structure
- */
-void room_tree_list(struct roomlisting *rp)
-{
- char rmname[64];
- int f;
-
- if (rp == NULL) {
- return;
- }
-
- room_tree_list(rp->lnext);
-
- strcpy(rmname, rp->rlname);
- f = rp->rlflags;
-
- wc_printf("<a href=\"dotgoto?room=");
- urlescputs(rmname);
- wc_printf("\"");
- wc_printf(">");
- escputs1(rmname, 1, 1);
- if ((f & QR_DIRECTORY) && (f & QR_NETWORK))
- wc_printf("}");
- else if (f & QR_DIRECTORY)
- wc_printf("]");
- else if (f & QR_NETWORK)
- wc_printf(")");
- else
- wc_printf(">");
- wc_printf("</a><tt> </tt>\n");
-
- room_tree_list(rp->rnext);
- free(rp);
-}
-
-
-/*
- * Room ordering stuff (compare first by floor, then by order)
- */
-int rordercmp(struct roomlisting *r1, struct roomlisting *r2)
-{
- if ((r1 == NULL) && (r2 == NULL))
- return (0);
- if (r1 == NULL)
- return (-1);
- if (r2 == NULL)
- return (1);
- if (r1->rlfloor < r2->rlfloor)
- return (-1);
- if (r1->rlfloor > r2->rlfloor)
- return (1);
- if (r1->rlorder < r2->rlorder)
- return (-1);
- if (r1->rlorder > r2->rlorder)
- return (1);
- return (0);
-}
-
-
-/*
- * Common code for all room listings
- */
-void listrms(char *variety)
-{
- char buf[SIZ];
- int num_rooms = 0;
-
- struct roomlisting *rl = NULL;
- struct roomlisting *rp;
- struct roomlisting *rs;
-
- /* Ask the server for a room list */
- serv_puts(variety);
- serv_getln(buf, sizeof buf);
- if (buf[0] != '1') {
- wc_printf(" ");
- return;
- }
-
- while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
- ++num_rooms;
- rp = malloc(sizeof(struct roomlisting));
- extract_token(rp->rlname, buf, 0, '|', sizeof rp->rlname);
- rp->rlflags = extract_int(buf, 1);
- rp->rlfloor = extract_int(buf, 2);
- rp->rlorder = extract_int(buf, 3);
- rp->lnext = NULL;
- rp->rnext = NULL;
-
- rs = rl;
- if (rl == NULL) {
- rl = rp;
- } else
- while (rp != NULL) {
- if (rordercmp(rp, rs) < 0) {
- if (rs->lnext == NULL) {
- rs->lnext = rp;
- rp = NULL;
- } else {
- rs = rs->lnext;
- }
- } else {
- if (rs->rnext == NULL) {
- rs->rnext = rp;
- rp = NULL;
- } else {
- rs = rs->rnext;
- }
- }
- }
- }
-
- room_tree_list(rl);
-
- /*
- * If no rooms were listed, print an nbsp to make the cell
- * borders show up anyway.
- */
- if (num_rooms == 0) wc_printf(" ");
-}
-
-
-/*
- * list all forgotten rooms
- */
-void zapped_list(void)
-{
- WCTemplputParams SubTP;
- StrBuf *Buf;
-
- output_headers(1, 1, 1, 0, 0, 0);
- memset(&SubTP, 0, sizeof(WCTemplputParams));
- Buf = NewStrBufPlain(_("Zapped (forgotten) rooms"), -1);
- SubTP.Filter.ContextType = CTX_STRBUF;
- SubTP.Context = Buf;
- DoTemplate(HKEY("beginbox"), NULL, &SubTP);
-
- FreeStrBuf(&Buf);
-
- listrms("LZRM -1");
-
- wc_printf("<br /><br />\n");
- wc_printf(_("Click on any room to un-zap it and goto that room.\n"));
- do_template("endbox", NULL);
- wDumpContent(1);
-}
-
-
+*/
/*
*
*/
-void embed_room_banner(char *got, int navbar_style) {
+void embed_room_banner(void)
+{
wcsession *WCC = WC;
char buf[256];
- char buf2[1024];
- char with_files[256];
- int file_count=0;
-
- /*
- * We need to have the information returned by a GOTO server command.
- * If it isn't supplied, we fake it by issuing our own GOTO.
- */
- if (got == NULL) {
- memset(buf, '0', 20);
- buf[20] = '\0';
- serv_printf("GOTO %s", ChrPtr(WC->CurRoom.name));
- serv_getln(buf, sizeof buf);
- got = buf;
- }
+
+ /* refresh current room states... */
+ /* dosen't work??? gotoroom(NULL); */
/* The browser needs some information for its own use */
wc_printf("<script type=\"text/javascript\"> \n"
" room_is_trash = %d; \n"
"</script>\n",
((WC->CurRoom.RAFlags & UA_ISTRASH) != 0)
- );
+ );
/*
* If the user happens to select the "make this my start page" link,
StrBufPrintf(WCC->Hdr->this_page,
"dotskip?room=%s",
ChrPtr(WC->CurRoom.name)
- );
-
- /* Check for new mail. */
- WC->new_mail = extract_int(&got[4], 9);
- WC->CurRoom.view = extract_int(&got[4], 11);
+ );
do_template("roombanner", NULL);
/* roombanner contains this for mobile */
- if (navbar_style != navbar_none && (WC->is_mobile < 1)) {
+ if (WC->is_mobile)
+ return;
+
- wc_printf("<div id=\"navbar\"><ul>");
+ wc_printf("<div id=\"navbar\"><ul>");
- if (navbar_style == navbar_default) wc_printf(
- "<li class=\"ungoto\">"
- "<a href=\"ungoto\">"
- "<img src=\"static/ungoto2_24x.gif\" alt=\"\" width=\"24\" height=\"24\">"
+ wc_printf(
+ "<li class=\"ungoto\">"
+ "<a href=\"ungoto\">"
+ "<img src=\"static/ungoto2_24x.gif\" alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">%s</span></A>"
+ "</li>\n", _("Ungoto")
+ );
+
+ if (WC->CurRoom.view == VIEW_BBS) {
+ wc_printf(
+ "<li class=\"newmess\">"
+ "<a href=\"readnew\">"
+ "<img src=\"static/newmess2_24x.gif\" alt=\"\" width=\"24\" height=\"24\">"
"<span class=\"navbar_link\">%s</span></A>"
- "</li>\n", _("Ungoto")
+ "</li>\n", _("Read new messages")
);
+ }
- if ( (navbar_style == navbar_default) && (WC->CurRoom.view == VIEW_BBS) ) {
+ switch(WC->CurRoom.view) {
+ case VIEW_ADDRESSBOOK:
+ wc_printf(
+ "<li class=\"viewcontacts\">"
+ "<a href=\"readfwd\">"
+ "<img src=\"static/viewcontacts_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("View contacts")
+ );
+ wc_printf(
+ "<li class=\"addnewcontact\">"
+ "<a href=\"display_enter\">"
+ "<img src=\"static/addnewcontact_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Add new contact")
+ );
+ break;
+ case VIEW_CALENDAR:
+ wc_printf(
+ "<li class=\"staskday\">"
+ "<a href=\"readfwd?calview=day\">"
+ "<img src=\"static/taskday2_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Day view")
+ );
+ wc_printf(
+ "<li class=\"monthview\">"
+ "<a href=\"readfwd?calview=month\">"
+ "<img src=\"static/monthview2_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Month view")
+ );
+ wc_printf("<li class=\"addevent\"><a href=\"display_enter");
+ if (havebstr("year" )) wc_printf("?year=%s", bstr("year"));
+ if (havebstr("month")) wc_printf("?month=%s", bstr("month"));
+ if (havebstr("day" )) wc_printf("?day=%s", bstr("day"));
+ wc_printf("\">"
+ "<img src=\"static/addevent_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Add new event")
+ );
+ break;
+ case VIEW_CALBRIEF:
+ wc_printf(
+ "<li class=\"monthview\">"
+ "<a href=\"readfwd?calview=month\">"
+ "<img src=\"static/monthview2_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Calendar list")
+ );
+ break;
+ case VIEW_TASKS:
+ wc_printf(
+ "<li class=\"taskmanag\">"
+ "<a href=\"readfwd\">"
+ "<img src=\"static/taskmanag_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("View tasks")
+ );
+ wc_printf(
+ "<li class=\"newmess\">"
+ "<a href=\"display_enter\">"
+ "<img src=\"static/newmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Add new task")
+ );
+ break;
+ case VIEW_NOTES:
+ wc_printf(
+ "<li class=\"viewnotes\">"
+ "<a href=\"readfwd\">"
+ "<img src=\"static/viewnotes_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("View notes")
+ );
+ wc_printf(
+ "<li class=\"enternewnote\">"
+ "<a href=\"add_new_note\">"
+ "<img src=\"static/enternewnote_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Add new note")
+ );
+ break;
+ case VIEW_MAILBOX:
+ wc_printf(
+ "<li class=\"readallmess\">"
+ "<a id=\"m_refresh\" href=\"readfwd\">"
+ "<img src=\"static/readallmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Refresh message list")
+ );
+ wc_printf(
+ "<li class=\"readallmess\">"
+ "<a href=\"readfwd\">"
+ "<img src=\"static/readallmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Read all messages")
+ );
+ wc_printf(
+ "<li class=\"newmess\">"
+ "<a href=\"display_enter\">"
+ "<img src=\"static/newmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Write mail")
+ );
+ break;
+ case VIEW_WIKI:
+ wc_printf(
+ "<li class=\"readallmess\">"
+ "<a href=\"wiki?page=home\">"
+ "<img src=\"static/readallmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Wiki home")
+ );
+ safestrncpy(buf, bstr("page"), sizeof buf);
+ if (IsEmptyStr(buf)) {
+ safestrncpy(buf, "home", sizeof buf);
+ }
+ str_wiki_index(buf);
+ wc_printf(
+ "<li class=\"newmess\">"
+ "<a href=\"display_enter?page=%s\">"
+ "<img src=\"static/newmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", buf, _("Edit this page")
+ );
+
+ if (bmstrcasestr((char *)ChrPtr(WCC->Hdr->HR.ReqLine), "wiki_history")) {
+ /* already viewing history; display a link to the current page */
wc_printf(
"<li class=\"newmess\">"
- "<a href=\"readnew\">"
- "<img src=\"static/newmess2_24x.gif\" alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">%s</span></A>"
- "</li>\n", _("Read new messages")
+ "<a href=\"wiki?page=%s\">"
+ "<img src=\"static/newmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", buf, _("Current version")
);
}
-
- if (navbar_style == navbar_default) {
- switch(WC->CurRoom.view) {
- case VIEW_ADDRESSBOOK:
- wc_printf(
- "<li class=\"viewcontacts\">"
- "<a href=\"readfwd\">"
- "<img src=\"static/viewcontacts_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("View contacts")
- );
- break;
- case VIEW_CALENDAR:
- wc_printf(
- "<li class=\"staskday\">"
- "<a href=\"readfwd?calview=day\">"
- "<img src=\"static/taskday2_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Day view")
- );
- wc_printf(
- "<li class=\"monthview\">"
- "<a href=\"readfwd?calview=month\">"
- "<img src=\"static/monthview2_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Month view")
- );
- break;
- case VIEW_CALBRIEF:
- wc_printf(
- "<li class=\"monthview\">"
- "<a href=\"readfwd?calview=month\">"
- "<img src=\"static/monthview2_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Calendar list")
- );
- break;
- case VIEW_TASKS:
- wc_printf(
- "<li class=\"taskmanag\">"
- "<a href=\"readfwd\">"
- "<img src=\"static/taskmanag_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("View tasks")
- );
- break;
- case VIEW_NOTES:
- wc_printf(
- "<li class=\"viewnotes\">"
- "<a href=\"readfwd\">"
- "<img src=\"static/viewnotes_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("View notes")
- );
- break;
- case VIEW_MAILBOX:
- wc_printf(
- "<li class=\"readallmess\">"
- "<a id=\"m_refresh\" href=\"readfwd\">"
- "<img src=\"static/readallmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Refresh message list")
- );
- break;
- case VIEW_WIKI:
- wc_printf(
- "<li class=\"readallmess\">"
- "<a href=\"wiki?page=home\">"
- "<img src=\"static/readallmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Wiki home")
- );
- break;
- default:
- wc_printf(
- "<li class=\"readallmess\">"
- "<a href=\"readfwd\">"
- "<img src=\"static/readallmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Read all messages")
- );
- break;
- }
- }
-
- if (navbar_style == navbar_default) {
- switch(WC->CurRoom.view) {
- case VIEW_ADDRESSBOOK:
- wc_printf(
- "<li class=\"addnewcontact\">"
- "<a href=\"display_enter\">"
- "<img src=\"static/addnewcontact_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Add new contact")
- );
- break;
- case VIEW_CALENDAR:
- case VIEW_CALBRIEF:
- wc_printf("<li class=\"addevent\"><a href=\"display_enter");
- if (havebstr("year" )) wc_printf("?year=%s", bstr("year"));
- if (havebstr("month")) wc_printf("?month=%s", bstr("month"));
- if (havebstr("day" )) wc_printf("?day=%s", bstr("day"));
- wc_printf("\">"
- "<img src=\"static/addevent_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Add new event")
- );
- break;
- case VIEW_TASKS:
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"display_enter\">"
- "<img src=\"static/newmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Add new task")
- );
- break;
- case VIEW_NOTES:
- wc_printf(
- "<li class=\"enternewnote\">"
- "<a href=\"add_new_note\">"
- "<img src=\"static/enternewnote_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Add new note")
- );
- break;
- case VIEW_WIKI:
- safestrncpy(buf, bstr("page"), sizeof buf);
- if (IsEmptyStr(buf)) {
- safestrncpy(buf, "home", sizeof buf);
- }
- str_wiki_index(buf);
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"display_enter?page=%s\">"
- "<img src=\"static/newmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", buf, _("Edit this page")
- );
-
- if (bmstrcasestr((char *)ChrPtr(WCC->Hdr->HR.ReqLine), "wiki_history")) {
- /* already viewing history; display a link to the current page */
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"wiki?page=%s\">"
- "<img src=\"static/newmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", buf, _("Current version")
- );
- }
- else {
- /* display a link to the history */
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"wiki_history?page=%s\">"
- "<img src=\"static/newmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", buf, _("History")
- );
- }
- break;
- case VIEW_MAILBOX:
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"display_enter\">"
- "<img src=\"static/newmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Write mail")
- );
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"javascript:deleteAllSelectedMessages();\">"
- "<img src=\"static/delete.gif\" "
- "alt=\"\" width=\"24\" height=\"24\"><span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Delete")
- );
- break;
- default:
- wc_printf(
- "<li class=\"newmess\">"
- "<a href=\"display_enter\">"
- "<img src=\"static/newmess3_24x.gif\" "
- "alt=\"\" width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">"
- "%s"
- "</span></a></li>\n", _("Enter a message")
- );
- break;
- }
+ else {
+ /* display a link to the history */
+ wc_printf(
+ "<li class=\"newmess\">"
+ "<a href=\"wiki_history?page=%s\">"
+ "<img src=\"static/newmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", buf, _("History")
+ );
}
-
- if (navbar_style == navbar_default) wc_printf(
- "<li class=\"skipthisroom\">"
- "<a href=\"skip\" "
- "title=\"%s\">"
- "<img src=\"static/skipthisroom_24x.gif\" alt=\"\" "
- "width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">%s</span></a>"
- "</li>\n",
- _("Leave all messages marked as unread, go to next room with unread messages"),
- _("Skip this room")
+ break;
+ break;
+ default:
+ wc_printf(
+ "<li class=\"readallmess\">"
+ "<a href=\"readfwd\">"
+ "<img src=\"static/readallmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Read all messages")
);
-
- if (navbar_style == navbar_default) wc_printf(
- "<li class=\"markngo\">"
- "<a href=\"gotonext\" "
- "title=\"%s\">"
- "<img src=\"static/markngo_24x.gif\" alt=\"\" "
- "width=\"24\" height=\"24\">"
- "<span class=\"navbar_link\">%s</span></a>"
- "</li>\n",
- _("Mark all messages as read, go to next room with unread messages"),
- _("Goto next room")
+ wc_printf(
+ "<li class=\"newmess\">"
+ "<a href=\"display_enter\">"
+ "<img src=\"static/newmess3_24x.gif\" "
+ "alt=\"\" width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">"
+ "%s"
+ "</span></a></li>\n", _("Enter a message")
);
-
- wc_printf("</ul></div>\n");
+ break;
}
-
+
+ wc_printf(
+ "<li class=\"skipthisroom\">"
+ "<a href=\"skip\" "
+ "title=\"%s\">"
+ "<img src=\"static/skipthisroom_24x.gif\" alt=\"\" "
+ "width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">%s</span></a>"
+ "</li>\n",
+ _("Leave all messages marked as unread, go to next room with unread messages"),
+ _("Skip this room")
+ );
+
+ wc_printf(
+ "<li class=\"markngo\">"
+ "<a href=\"gotonext\" "
+ "title=\"%s\">"
+ "<img src=\"static/markngo_24x.gif\" alt=\"\" "
+ "width=\"24\" height=\"24\">"
+ "<span class=\"navbar_link\">%s</span></a>"
+ "</li>\n",
+ _("Mark all messages as read, go to next room with unread messages"),
+ _("Goto next room")
+ );
+
+ wc_printf("</ul></div>\n");
}
long err = 0;
/* store ungoto information */
- strcpy(WCC->ugname, ChrPtr(WCC->CurRoom.name));
+ if (StrLength(gname) > 0)
+ strcpy(WCC->ugname, ChrPtr(WCC->CurRoom.name));
WCC->uglsn = ls;
Buf = NewStrBuf();
/* move to the new room */
- serv_printf("GOTO %s", ChrPtr(gname));
+ if (StrLength(gname) > 0)
+ serv_printf("GOTO %s", ChrPtr(gname));
+ else /* or just refresh the current state... */
+ serv_printf("GOTO 00000000000000000000");
StrBuf_ServGetln(Buf);
if (GetServerStatus(Buf, &err) != 2) {
serv_puts("GOTO _BASEROOM_");
return err;
}
}
+ FlushFolder(&WCC->CurRoom);
ParseGoto(&WCC->CurRoom, Buf);
- remove_march(WCC->CurRoom.name);
- if (!strcasecmp(ChrPtr(gname), "_BASEROOM_"))
- remove_march(gname);
+ if (StrLength(gname) > 0)
+ {
+ remove_march(WCC->CurRoom.name);
+ if (!strcasecmp(ChrPtr(gname), "_BASEROOM_"))
+ remove_march(gname);
+ }
FreeStrBuf(&Buf);
return err;
}
+void DBG_QR(long QR)
+{
+ const char *QRFlagList[15] = {
+ strof(QR_PERMANENT),
+ strof(QR_INUSE),
+ strof(QR_PRIVATE),
+ strof(QR_PASSWORDED),
+ strof(QR_GUESSNAME),
+ strof(QR_DIRECTORY),
+ strof(QR_UPLOAD),
+ strof(QR_DOWNLOAD),
+ strof(QR_VISDIR),
+ strof(QR_ANONONLY),
+ strof(QR_ANONOPT),
+ strof(QR_NETWORK),
+ strof(QR_PREFONLY),
+ strof(QR_READONLY),
+ strof(QR_MAILBOX)
+ };
+ int i = 1;
+ int j=0;
+ StrBuf *QRVec;
+
+ QRVec = NewStrBufPlain(NULL, 256);
+ while (i != 0)
+ {
+ if ((QR & i) != 0) {
+ if (StrLength(QRVec) > 0)
+ StrBufAppendBufPlain(QRVec, HKEY(" | "), 0);
+ StrBufAppendBufPlain(QRVec, QRFlagList[j], -1, 0);
+ }
+ i = i << 1;
+ j++;
+ }
+ lprintf(9, "DBG: QR-Vec [%ld] [%s]\n", QR, ChrPtr(QRVec));
+ FreeStrBuf(&QRVec);
+}
+
+
+
+void DBG_QR2(long QR2)
+{
+ const char *QR2FlagList[15] = {
+ strof(QR2_SYSTEM),
+ strof(QR2_SELFLIST),
+ strof(QR2_COLLABDEL),
+ strof(QR2_SUBJECTREQ),
+ strof(QR2_SMTP_PUBLIC),
+ strof(QR2_MODERATED),
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ ""
+ };
+ int i = 1;
+ int j=0;
+ StrBuf *QR2Vec;
+
+ QR2Vec = NewStrBufPlain(NULL, 256);
+ while (i != 0)
+ {
+ if ((QR2 & i) != 0) {
+ if (StrLength(QR2Vec) > 0)
+ StrBufAppendBufPlain(QR2Vec, HKEY(" | "), 0);
+ StrBufAppendBufPlain(QR2Vec, QR2FlagList[j], -1, 0);
+ }
+ i = i << 1;
+ j++;
+ }
+ lprintf(9, "DBG: QR2-Vec [%ld] [%s]\n", QR2, ChrPtr(QR2Vec));
+ FreeStrBuf(&QR2Vec);
+}
+
+
void ParseGoto(folder *room, StrBuf *Line)
{
room->QRFlags = StrBufExtractNext_long(Line, &Pos, '|'); //CurRoom->QRFlags
+ DBG_QR(room->QRFlags);
+
room->HighestRead = StrBufExtractNext_long(Line, &Pos, '|');
room->LastMessageRead = StrBufExtractNext_long(Line, &Pos, '|');
room->RAFlags |= UA_ISTRASH; // wc_is_trash
room->QRFlags2 = StrBufExtractNext_long(Line, &Pos, '|'); // CurRoom->QRFlags2
+ DBG_QR2(room->QRFlags2);
/* find out, whether we are in a sub-room */
room->nRoomNameParts = StrBufNum_tokens(room->name, '\\');
WCC->CurRoom.XALoaded = 1;
Buf = NewStrBuf();
- serv_puts("GETA");
+ serv_puts("GETR");
StrBuf_ServGetln(Buf);
if (GetServerStatus(Buf, NULL) != 2) {
FlushStrBuf(WCC->CurRoom.XAPass);
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;
}
+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;
+}
+
/*
* goto next room
*/
serv_getln(buf, sizeof buf);
}
+ FlushRoomlist ();
return(newval);
}
RoomOps->view,
RoomOps->flags2);
serv_getln(buf, sizeof buf);
+ FlushRoomlist ();
+
return (1);
}
*/
void display_editroom(void)
{
- StrBuf *Buf;
char buf[SIZ];
char cmd[1024];
char node[256];
tab = bstr("tab");
if (IsEmptyStr(tab)) tab = "admin";
- Buf = NewStrBuf();
- load_floorlist(Buf);
- FreeStrBuf(&Buf);
+// Buf = NewStrBuf();
+// load_floorlist(Buf);
+// FreeStrBuf(&Buf);
output_headers(1, 1, 1, 0, 0, 0);
wc_printf("<div class=\"fix_scrollbar_bug\">");
set_roomflags (&RoomFlags);
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
}
if (!havebstr("ok_button")) {
strcpy(WC->ImportantMessage,
_("Cancelled. Changes were not saved."));
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
return;
}
serv_puts("GETR");
if (GetServerStatus(Buf, NULL) != 2) {
StrBufCutLeft(Buf, 4);
strcpy(WC->ImportantMessage, ChrPtr(Buf));
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
FreeStrBuf(&Buf);
return;
}
+ FlushRoomlist ();
+
er_name = NewStrBuf();
er_password = NewStrBuf();
er_dirname = NewStrBuf();
StrBuf_ServGetln(Buf);
if (GetServerStatus(Buf, NULL) != 2) {
strcpy(WC->ImportantMessage, &ChrPtr(Buf)[4]);
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
FreeStrBuf(&Buf);
FreeStrBuf(&er_name);
FreeStrBuf(&er_password);
}
gotoroom(er_name);
strcpy(WC->ImportantMessage, _("Your changes have been saved."));
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
FreeStrBuf(&Buf);
FreeStrBuf(&er_name);
FreeStrBuf(&er_password);
}
}
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
}
wDumpContent(1);
}
-
-
-/*
- * display the form for entering a new room
- */
-void display_entroom(void)
-{
- StrBuf *Buf;
- int i;
- char buf[SIZ];
-
- Buf = NewStrBuf();
- serv_puts("CRE8 0");
- serv_getln(buf, sizeof buf);
-
- if (buf[0] != '2') {
- strcpy(WC->ImportantMessage, &buf[4]);
- display_main_menu();
- FreeStrBuf(&Buf);
- return;
- }
-
- output_headers(1, 1, 1, 0, 0, 0);
-
- svprintf(HKEY("BOXTITLE"), WCS_STRING, _("Create a new room"));
- do_template("beginbox", NULL);
-
- wc_printf("<form name=\"create_room_form\" method=\"POST\" action=\"entroom\">\n");
- wc_printf("<input type=\"hidden\" name=\"nonce\" value=\"%d\">\n", WC->nonce);
-
- wc_printf("<table class=\"altern\"> ");
-
- wc_printf("<tr class=\"even\"><td>");
- wc_printf(_("Name of room: "));
- wc_printf("</td><td>");
- wc_printf("<input type=\"text\" NAME=\"er_name\" MAXLENGTH=\"127\">\n");
- wc_printf("</td></tr>");
-
- wc_printf("<tr class=\"odd\"><td>");
- wc_printf(_("Resides on floor: "));
- wc_printf("</td><td>");
- load_floorlist(Buf);
- wc_printf("<select name=\"er_floor\" size=\"1\">\n");
- for (i = 0; i < 128; ++i)
- if (!IsEmptyStr(floorlist[i])) {
- wc_printf("<option ");
- wc_printf("value=\"%d\">", i);
- escputs(floorlist[i]);
- wc_printf("</option>\n");
- }
- wc_printf("</select>\n");
- wc_printf("</td></tr>");
-
- /*
- * Our clever little snippet of JavaScript automatically selects
- * a public room if the view is set to Bulletin Board or wiki, and
- * it selects a mailbox room otherwise. The user can override this,
- * of course. We also disable the floor selector for mailboxes.
- */
- wc_printf("<tr class=\"even\"><td>");
- wc_printf(_("Default view for room: "));
- wc_printf("</td><td>");
- wc_printf("<select name=\"er_view\" size=\"1\" OnChange=\""
- " if ( (this.form.er_view.value == 0) "
- " || (this.form.er_view.value == 6) ) { "
- " this.form.type[0].checked=true; "
- " this.form.er_floor.disabled = false; "
- " } "
- " else { "
- " this.form.type[4].checked=true; "
- " this.form.er_floor.disabled = true; "
- " } "
- "\">\n");
- for (i=0; i<(sizeof viewdefs / sizeof (char *)); ++i) {
- if (is_view_allowed_as_default(i)) {
- wc_printf("<option %s value=\"%d\">",
- ((i == 0) ? "selected" : ""), i );
- escputs(viewdefs[i]);
- wc_printf("</option>\n");
- }
- }
- wc_printf("</select>\n");
- wc_printf("</td></tr>");
-
- wc_printf("<tr class=\"even\"><td>");
- wc_printf(_("Type of room:"));
- wc_printf("</td><td>");
- wc_printf("<ul class=\"adminlist\">\n");
-
- wc_printf("<li><input type=\"radio\" NAME=\"type\" VALUE=\"public\" ");
- wc_printf("CHECKED OnChange=\""
- " if (this.form.type[0].checked == true) { "
- " this.form.er_floor.disabled = false; "
- " } "
- "\"> ");
- wc_printf(_("Public (automatically appears to everyone)"));
- wc_printf("</li>");
-
- wc_printf("\n<li><input type=\"radio\" NAME=\"type\" VALUE=\"hidden\" OnChange=\""
- " if (this.form.type[1].checked == true) { "
- " this.form.er_floor.disabled = false; "
- " } "
- "\"> ");
- wc_printf(_("Private - hidden (accessible to anyone who knows its name)"));
- wc_printf("</li>");
-
- wc_printf("\n<li><input type=\"radio\" NAME=\"type\" VALUE=\"passworded\" OnChange=\""
- " if (this.form.type[2].checked == true) { "
- " this.form.er_floor.disabled = false; "
- " } "
- "\"> ");
- wc_printf(_("Private - require password: "));
- wc_printf("<input type=\"text\" NAME=\"er_password\" MAXLENGTH=\"9\">\n");
- wc_printf("</li>");
-
- wc_printf("<li><input type=\"radio\" NAME=\"type\" VALUE=\"invonly\" OnChange=\""
- " if (this.form.type[3].checked == true) { "
- " this.form.er_floor.disabled = false; "
- " } "
- "\"> ");
- wc_printf(_("Private - invitation only"));
- wc_printf("</li>");
-
- wc_printf("\n<li><input type=\"radio\" NAME=\"type\" VALUE=\"personal\" "
- "OnChange=\""
- " if (this.form.type[4].checked == true) { "
- " this.form.er_floor.disabled = true; "
- " } "
- "\"> ");
- wc_printf(_("Personal (mailbox for you only)"));
- wc_printf("</li>");
-
- wc_printf("\n</ul>\n");
- wc_printf("</td></tr></table>\n");
-
- wc_printf("<div class=\"buttons\">\n");
- wc_printf("<input type=\"submit\" name=\"ok_button\" value=\"%s\">", _("Create new room"));
- wc_printf(" ");
- wc_printf("<input type=\"submit\" name=\"cancel_button\" value=\"%s\">", _("Cancel"));
- wc_printf("</div>\n");
- wc_printf("</form>\n<hr />");
- serv_printf("MESG roomaccess");
- serv_getln(buf, sizeof buf);
- if (buf[0] == '1') {
- fmout("LEFT");
- }
-
- do_template("endbox", NULL);
-
- wDumpContent(1);
- FreeStrBuf(&Buf);
-}
-
-
-
-
/*
* support function for entroom() -- sets the default view
*/
}
/** TODO: Room created, now update the left hand icon bar for this user */
burn_folder_cache(0); /* burn the old folder cache */
-
+
gotoroom(er_name);
serv_printf("VIEW %d", er_view);
WCC->CurRoom.view = er_view;
if ( (WCC != NULL) && ( (WCC->CurRoom.RAFlags & UA_ADMINALLOWED) != 0) ) {
- display_editroom ();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
} else {
do_change_view(er_view); /* Now go there */
}
}
-/**
- * \brief display the screen to enter a private room
- */
-void display_private(char *rname, int req_pass)
-{
- WCTemplputParams SubTP;
- StrBuf *Buf;
- output_headers(1, 1, 1, 0, 0, 0);
-
- Buf = NewStrBufPlain(_("Go to a hidden room"), -1);
- memset(&SubTP, 0, sizeof(WCTemplputParams));
- SubTP.Filter.ContextType = CTX_STRBUF;
- SubTP.Context = Buf;
- DoTemplate(HKEY("beginbox"), NULL, &SubTP);
-
- FreeStrBuf(&Buf);
-
- wc_printf("<p>");
- wc_printf(_("If you know the name of a hidden (guess-name) or "
- "passworded room, you can enter that room by typing "
- "its name below. Once you gain access to a private "
- "room, it will appear in your regular room listings "
- "so you don't have to keep returning here."));
- wc_printf("</p>");
-
- wc_printf("<form method=\"post\" action=\"goto_private\">\n");
- wc_printf("<input type=\"hidden\" name=\"nonce\" value=\"%d\">\n", WC->nonce);
-
- wc_printf("<table class=\"altern\"> "
- "<tr class=\"even\"><td>");
- wc_printf(_("Enter room name:"));
- wc_printf("</td><td>"
- "<input type=\"text\" name=\"gr_name\" "
- "value=\"%s\" maxlength=\"128\">\n", rname);
-
- if (req_pass) {
- wc_printf("</td></tr><tr class=\"odd\"><td>");
- wc_printf(_("Enter room password:"));
- wc_printf("</td><td>");
- wc_printf("<input type=\"password\" name=\"gr_pass\" maxlength=\"9\">\n");
- }
- wc_printf("</td></tr></table>\n");
-
- wc_printf("<div class=\"buttons\">\n");
- wc_printf("<input type=\"submit\" name=\"ok_button\" value=\"%s\">"
- " "
- "<input type=\"submit\" name=\"cancel_button\" value=\"%s\">",
- _("Go there"),
- _("Cancel")
- );
- wc_printf("</div></form>\n");
-
- do_template("endbox", NULL);
-
- wDumpContent(1);
-}
-
/**
* \brief goto a private room
*/
display_main_menu();
return;
}
+ FlushRoomlist();
strcpy(hold_rm, ChrPtr(WC->CurRoom.name));
serv_printf("GOTO %s|%s",
bstr("gr_name"),
return;
}
if (!strncmp(buf, "540", 3)) {
- display_private(bstr("gr_name"), 1);
+ DoTemplate(HKEY("room_display_private"), NULL, &NoCtx);
return;
}
output_headers(1, 1, 1, 0, 0, 0);
}
-/**
- * \brief display the screen to zap a room
- */
-void display_zap(void)
-{
- output_headers(1, 1, 2, 0, 0, 0);
-
- wc_printf("<div id=\"banner\">\n");
- wc_printf("<h1>");
- wc_printf(_("Zap (forget/unsubscribe) the current room"));
- wc_printf("</h1>\n");
- wc_printf("</div>\n");
-
- wc_printf("<div id=\"content\" class=\"service\">\n");
-
- wc_printf(_("If you select this option, <em>%s</em> will "
- "disappear from your room list. Is this what you wish "
- "to do?<br />\n"), ChrPtr(WC->CurRoom.name));
-
- wc_printf("<form method=\"POST\" action=\"zap\">\n");
- wc_printf("<input type=\"hidden\" name=\"nonce\" value=\"%d\">\n", WC->nonce);
- wc_printf("<input type=\"submit\" NAME=\"ok_button\" VALUE=\"%s\">", _("Zap this room"));
- wc_printf(" ");
- wc_printf("<input type=\"submit\" NAME=\"cancel_button\" VALUE=\"%s\">", _("Cancel"));
- wc_printf("</form>\n");
- wDumpContent(1);
-}
-
/**
* \brief zap a room
StrBufAppendBufPlain(final_destination, HKEY("_BASEROOM_"), 0);
}
}
+ FlushRoomlist ();
}
smart_goto(final_destination);
FreeStrBuf(&final_destination);
serv_puts("KILL 1");
serv_getln(buf, sizeof buf);
burn_folder_cache(0); /* Burn the cahce of known rooms to update the icon bar */
+ FlushRoomlist ();
if (buf[0] != '2') {
strcpy(WC->ImportantMessage, &buf[4]);
display_main_menu();
strcat(line, bstr("suffix"));
}
else {
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
return;
}
fp = tmpfile();
if (fp == NULL) {
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
return;
}
serv_getln(buf, sizeof buf);
if (buf[0] != '1') {
fclose(fp);
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
return;
}
serv_getln(buf, sizeof buf);
if (buf[0] != '4') {
fclose(fp);
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
return;
}
serv_puts("000");
fclose(fp);
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
}
if (!havebstr("ok_button")) {
strcpy(WC->ImportantMessage,
_("Cancelled. Changes were not saved."));
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
return;
}
strcat(WC->ImportantMessage, &buf[4]);
}
- display_editroom();
+ http_transmit_thing(ChrPtr(do_template("room_edit", NULL)), 0);
}
void tmplput_RoomName(StrBuf *Target, WCTemplputParams *TP)
StrBufAppendTemplate(Target, TP, WC->CurRoom.name, 0);
}
-
-void _display_private(void) {
- display_private("", 0);
-}
-
void dotgoto(void) {
if (!havebstr("room")) {
readloop(readnew, eUseDefault);
void tmplput_roombanner(StrBuf *Target, WCTemplputParams *TP)
{
wc_printf("<div id=\"banner\">\n");
- embed_room_banner(NULL, navbar_default);
+ embed_room_banner();
wc_printf("</div>\n");
}
if (QR_CheckFlag == 0)
LogTemplateError(Target, "Conditional", ERR_PARM1, TP,
"requires one of the #\"QR*\"- defines or an integer flag 0 is invalid!");
+
+ if (WCC == NULL)
+ return 0;
- return ((WCC!=NULL) &&
- ((WCC->CurRoom.QRFlags & QR_CheckFlag) != 0));
+ if ((TP->Tokens->Params[2]->MaskBy == eOR) ||
+ (TP->Tokens->Params[2]->MaskBy == eNO))
+ return (WCC->CurRoom.QRFlags & QR_CheckFlag) != 0;
+ else
+ return (WCC->CurRoom.QRFlags & QR_CheckFlag) == QR_CheckFlag;
}
int ConditionalRoomHas_QRFlag(StrBuf *Target, WCTemplputParams *TP)
if (QR_CheckFlag == 0)
LogTemplateError(Target, "Conditional", ERR_PARM1, TP,
"requires one of the #\"QR*\"- defines or an integer flag 0 is invalid!");
- return ((Folder->QRFlags & QR_CheckFlag) != 0);
+
+ if ((TP->Tokens->Params[2]->MaskBy == eOR) ||
+ (TP->Tokens->Params[2]->MaskBy == eNO))
+ return (Folder->QRFlags & QR_CheckFlag) != 0;
+ else
+ return (Folder->QRFlags & QR_CheckFlag) == QR_CheckFlag;
}
LogTemplateError(Target, "Conditional", ERR_PARM1, TP,
"requires one of the #\"QR2*\"- defines or an integer flag 0 is invalid!");
- return ((WCC!=NULL) &&
- ((WCC->CurRoom.QRFlags2 & QR2_CheckFlag) != 0));
+
+ if (WCC == NULL)
+ return 0;
+
+ if ((TP->Tokens->Params[2]->MaskBy == eOR) ||
+ (TP->Tokens->Params[2]->MaskBy == eNO))
+ return (WCC->CurRoom.QRFlags2 & QR2_CheckFlag) != 0;
+ else
+ return (WCC->CurRoom.QRFlags2 & QR2_CheckFlag) == QR2_CheckFlag;
}
int ConditionalRoomHas_QRFlag2(StrBuf *Target, WCTemplputParams *TP)
serv_puts("WHOK");
Line = NewStrBuf();
- Token = NewStrBuf();
StrBuf_ServGetln(Line);
if (GetServerStatus(Line, &State) == 1)
{
_("Higher access is required to access this function."), -1, 0);
+ FreeStrBuf(&Line);
return Whok;
}
+void _FlushRoomList(wcsession *WCC)
+{
+ free_march_list(WCC);
+ DeleteHash(&WCC->Floors);
+ DeleteHash(&WCC->Rooms);
+ DeleteHash(&WCC->FloorsByName);
+}
+
+void FlushRoomlist(void)
+{
+ wcsession *WCC = WC;
+ _FlushRoomList(WCC);
+}
+
+
void
InitModule_ROOMOPS
(void)
WebcitAddUrlHandler(HKEY("knrooms"), "", 0, knrooms, 0);
WebcitAddUrlHandler(HKEY("dotgoto"), "", 0, dotgoto, NEED_URL);
WebcitAddUrlHandler(HKEY("dotskip"), "", 0, dotskip, NEED_URL);
- WebcitAddUrlHandler(HKEY("display_private"), "", 0, _display_private, 0);
+
WebcitAddUrlHandler(HKEY("goto_private"), "", 0, goto_private, NEED_URL);
- WebcitAddUrlHandler(HKEY("zapped_list"), "", 0, zapped_list, 0);
- WebcitAddUrlHandler(HKEY("display_zap"), "", 0, display_zap, 0);
WebcitAddUrlHandler(HKEY("zap"), "", 0, zap, 0);
- WebcitAddUrlHandler(HKEY("display_entroom"), "", 0, display_entroom, 0);
WebcitAddUrlHandler(HKEY("entroom"), "", 0, entroom, 0);
- WebcitAddUrlHandler(HKEY("display_whok"), "", 0, display_whok, 0);
WebcitAddUrlHandler(HKEY("do_invt_kick"), "", 0, do_invt_kick, 0);
WebcitAddUrlHandler(HKEY("display_editroom"), "", 0, display_editroom, 0);
WebcitAddUrlHandler(HKEY("netedit"), "", 0, netedit, 0);
RegisterNamespace("THISROOM:ORDER", 0, 0, tmplput_CurrentRoomOrder, NULL, CTX_NONE);
RegisterNamespace("THISROOM:DEFAULT_VIEW", 0, 0, tmplput_CurrentRoomDefView, NULL, CTX_NONE);
RegisterConditional(HKEY("COND:THISROOM:HAVE_VIEW"), 0, ConditionalThisRoomHaveView, CTX_NONE);
+ RegisterConditional(HKEY("COND:ALLOWED_DEFAULT_VIEW"), 0, ConditionalIsAllowedDefaultView, CTX_NONE);
+
RegisterNamespace("THISROOM:VIEW_STRING", 0, 1, tmplput_CurrentRoomViewString, NULL, CTX_NONE);
RegisterNamespace("ROOM:VIEW_STRING", 1, 2, tmplput_RoomViewString, NULL, CTX_NONE);
RegisterNamespace("THISROOM:INFOTEXT", 1, 2, tmplput_CurrentRoomInfoText, NULL, CTX_NONE);
RegisterConditional(HKEY("COND:THISROOM:ORDER"), 0, ConditionalThisRoomOrder, CTX_NONE);
RegisterConditional(HKEY("COND:THISROOM:DEFAULT_VIEW"), 0, ConditionalThisRoomDefView, CTX_NONE);
+ RegisterConditional(HKEY("COND:THISROOM:CURR_VIEW"), 0, ConditionalThisRoomCurrView, CTX_NONE);
RegisterConditional(HKEY("COND:THISROOM:HAVE_PIC"), 0, ConditionalThisRoomXHavePic, CTX_NONE);
RegisterConditional(HKEY("COND:THISROOM:HAVE_INFOTEXT"), 0, ConditionalThisRoomXHaveInfoText, CTX_NONE);
RegisterNamespace("THISROOM:FILES:N", 0, 1, tmplput_CurrentRoomXNFiles, NULL, CTX_NONE);
free(sess->cache_fold);
}
- free_march_list(sess);
- DeleteHash(&sess->Floors);
- DeleteHash(&sess->Rooms);
- DeleteHash(&sess->FloorsByName);
+ _FlushRoomList (sess);
}