-/* $Id$ */
-
+/*
+ * $Id$
+ *
+ * Lots of different room-related operations.
+ */
#include <ctype.h>
#include <stdlib.h>
int hasnewmsgs;
int is_mailbox;
int selectable;
+ int view;
};
char *viewdefs[] = {
- "Messages",
- "Summary",
+ "Bulletin Board",
+ "Mail Folder",
"Address Book",
"Calendar",
- "Tasks"
+ "Task List",
+ "Notes List"
};
char floorlist[128][SIZ];
floorlist[a][0] = 0;
serv_puts("LFLR");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '1') {
strcpy(floorlist[0], "Main Floor");
return;
}
- while (serv_gets(buf), strcmp(buf, "000")) {
- extract(floorlist[extract_int(buf, 0)], buf, 1);
+ while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(floorlist[extract_int(buf, 0)], buf, 1, '|', sizeof floorlist[0]);
}
}
urlescputs(rmname);
wprintf("\"");
wprintf(">");
- escputs1(rmname, 1);
+ escputs1(rmname, 1, 1);
if ((f & QR_DIRECTORY) && (f & QR_NETWORK))
wprintf("}");
else if (f & QR_DIRECTORY)
/* Ask the server for a room list */
serv_puts(variety);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '1') {
wprintf(" ");
return;
}
- while (serv_gets(buf), strcmp(buf, "000")) {
+ while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
++num_rooms;
rp = malloc(sizeof(struct roomlisting));
- extract(rp->rlname, buf, 0);
+ 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);
}
-/*
- * list all rooms by floor (only should get called from knrooms() because
- * that's where output_headers() is called from)
- */
-void tabular_room_list(void)
-{
- int a;
- char buf[SIZ];
-
- do_template("beginbox_nt");
- wprintf("<TABLE width=100%% border><TR><TH>Floor</TH>");
- wprintf("<TH>Rooms with new messages</TH>");
- wprintf("<TH>Rooms with no new messages</TH></TR>\n");
-
- for (a = 0; a < 128; ++a)
- if (floorlist[a][0] != 0) {
-
- /* Floor name column */
- wprintf("<TR><TD>");
-
- serv_printf("OIMG _floorpic_|%d", a);
- serv_gets(buf);
- if (buf[0] == '2') {
- serv_puts("CLOS");
- serv_gets(buf);
- wprintf("<IMG SRC=\"/image&name=_floorpic_&parm=%d\" ALT=\"%s\">",
- a, &floorlist[a][0]);
- } else {
- escputs(&floorlist[a][0]);
- }
-
- wprintf("</TD>");
-
- /* Rooms with new messages column */
- wprintf("<TD>");
- sprintf(buf, "LKRN %d", a);
- listrms(buf);
- wprintf("</TD>\n<TD>");
-
- /* Rooms with old messages column */
- sprintf(buf, "LKRO %d", a);
- listrms(buf);
- wprintf("</TD></TR>\n");
- }
- wprintf("</TABLE>\n");
- do_template("endbox");
- wDumpContent(1);
-}
-
-
-
-
-
-
-
-
-
/*
* list all forgotten rooms
*/
void zapped_list(void)
{
- output_headers(3);
+ output_headers(1, 1, 0, 0, 0, 0, 0);
svprintf("BOXTITLE", WCS_STRING, "Zapped (forgotten) rooms");
do_template("beginbox");
listrms("LZRM -1");
- wprintf("<BR><BR>\n");
+ wprintf("<br /><br />\n");
wprintf("Click on any room to un-zap it and goto that room.\n");
do_template("endbox");
wDumpContent(1);
char buf[SIZ];
serv_puts("RINF");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '1') {
- fmout(NULL);
+ fmout(NULL, "CENTER");
}
}
-/* Display room graphic. The server doesn't actually
+/* Display room banner icon. The server doesn't actually
* need the room name, but we supply it in order to
- * keep the browser from using a cached graphic from
+ * keep the browser from using a cached icon from
* another room.
*/
void embed_room_graphic(void) {
char buf[SIZ];
serv_puts("OIMG _roompic_");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '2') {
- wprintf("<TD BGCOLOR=\"#444455\">");
- wprintf("<IMG SRC=\"/image&name=_roompic_&room=");
+ wprintf("<IMG HEIGHT=64 SRC=\"/image&name=_roompic_&room=");
urlescputs(WC->wc_roomname);
- wprintf("\"></TD>");
+ wprintf("\">");
serv_puts("CLOS");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
+ }
+ else if (WC->wc_view == VIEW_ADDRESSBOOK) {
+ wprintf("<img height=48 width=48 src=\""
+ "static/viewcontacts_48x.gif"
+ "\">"
+ );
+ }
+ else if (WC->wc_view == VIEW_CALENDAR) {
+ wprintf("<img height=48 width=48 src=\""
+ "static/calarea_48x.gif"
+ "\">"
+ );
+ }
+ else if (WC->wc_view == VIEW_TASKS) {
+ wprintf("<img height=48 width=48 src=\""
+ "static/taskmanag_48x.gif"
+ "\">"
+ );
+ }
+ else if (WC->wc_view == VIEW_NOTES) {
+ wprintf("<img height=48 width=48 src=\""
+ "static/storenotes_48x.gif"
+ "\">"
+ );
+ }
+ else if (WC->wc_view == VIEW_MAILBOX) {
+ wprintf("<img height=48 width=48 src=\""
+ "static/privatemess_48x.gif"
+ "\">"
+ );
+ }
+ else {
+ wprintf("<img height=48 width=48 src=\""
+ "static/chatrooms_48x.gif"
+ "\">"
+ );
}
}
if ( (WC->new_mail > WC->remember_new_mail) && (WC->new_mail>0) ) {
wprintf(
"<A HREF=\"/dotgoto?room=_MAIL_\">"
- "<IMG SRC=\"/static/mail.gif\" border=0 "
+ "<IMG SRC=\"/static/privatemess_32x.gif\" border=0 "
"ALT=\"You have new mail\">"
- "<BR><SPAN CLASS=\"youhavemail\">"
+ "<br /><SPAN CLASS=\"youhavemail\">"
"%d new mail</SPAN></A>", WC->new_mail);
WC->remember_new_mail = WC->new_mail;
}
int i;
wprintf("<FORM NAME=\"viewomatic\">\n"
+ "<span class=\"room_banner_new_messages\">View as: "
"<SELECT NAME=\"newview\" SIZE=\"1\" "
+ "STYLE=\"font-family: Bitstream Vera Sans,Arial,Helvetica,sans-serif;"
+ " font-size: 7pt; background: #444455; color: #ddddcc;\" "
"OnChange=\"location.href=viewomatic.newview.options"
"[selectedIndex].value\">\n");
wprintf("</OPTION>\n");
}
}
- wprintf("</SELECT></FORM>\n");
+ wprintf("</select></span></form>\n");
}
-void embed_room_banner(char *got) {
+void embed_room_banner(char *got, int navbar_style) {
char fakegot[SIZ];
/* We need to have the information returned by a GOTO server command.
*/
if (got == NULL) {
serv_printf("GOTO %s", WC->wc_roomname);
- serv_gets(fakegot);
+ serv_getln(fakegot, sizeof fakegot);
got = fakegot;
}
svcallback("START", offer_start_page);
do_template("roombanner");
- clear_local_substs();
+ if (navbar_style != navbar_none) {
+
+ wprintf("<div style=\"position:absolute; bottom:0px; left:0px\">\n"
+ "<table width=\"100%%\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\"><tr>\n");
+
+
+ if (navbar_style == navbar_default) wprintf(
+ "<td>"
+ "<a href=\"/ungoto\">"
+ "<img align=\"middle\" src=\"/static/ungoto2_24x.gif\" border=\"0\">"
+ "<span class=\"navbar_link\">Ungoto</span></A>"
+ "</td>\n"
+ );
+
+ if ( (navbar_style == navbar_default) && (WC->wc_view == VIEW_BBS) ) {
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readnew\">"
+ "<img align=\"middle\" src=\"/static/newmess2_24x.gif\" border=\"0\">"
+ "<span class=\"navbar_link\">Read new messages</span></A>"
+ "</td>\n"
+ );
+ }
+
+ if (navbar_style == navbar_default) {
+ switch(WC->wc_view) {
+ case VIEW_ADDRESSBOOK:
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd\">"
+ "<img align=\"middle\" src=\"/static/viewcontacts_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "View contacts"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_CALENDAR:
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd?calview=day\">"
+ "<img align=\"middle\" src=\"/static/taskday2_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "Day view"
+ "</span></a></td>\n"
+ );
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd?calview=month\">"
+ "<img align=\"middle\" src=\"/static/monthview2_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "Month view"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_TASKS:
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd\">"
+ "<img align=\"middle\" src=\"/static/taskmanag_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "View tasks"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_NOTES:
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd\">"
+ "<img align=\"middle\" src=\"/static/viewnotes_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "View notes"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_MAILBOX:
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd\">"
+ "<img align=\"middle\" src=\"/static/readallmess3_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "View message list"
+ "</span></a></td>\n"
+ );
+ break;
+ default:
+ wprintf(
+ "<td>"
+ "<A HREF=\"/readfwd\">"
+ "<img align=\"middle\" src=\"/static/readallmess3_24x.gif\" "
+ "border=\"0\">"
+ "<span class=\"navbar_link\">"
+ "Read all messages"
+ "</span></a></td>\n"
+ );
+ break;
+ }
+ }
+
+ if (navbar_style == navbar_default) {
+ switch(WC->wc_view) {
+ case VIEW_ADDRESSBOOK:
+ wprintf(
+ "<td><A HREF=\"/display_enter\">"
+ "<img align=\"middle\" src=\"/static/addnewcontact_24x.gif\" "
+ "border=\"0\"><span class=\"navbar_link\">"
+ "Add new contact"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_CALENDAR:
+ wprintf(
+ "<td><A HREF=\"/display_enter\">"
+ "<img align=\"middle\" src=\"/static/addevent_24x.gif\" "
+ "border=\"0\"><span class=\"navbar_link\">"
+ "Add new event"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_TASKS:
+ wprintf(
+ "<td><A HREF=\"/display_enter\">"
+ "<img align=\"middle\" src=\"/static/newmess3_24x.gif\" "
+ "border=\"0\"><span class=\"navbar_link\">"
+ "Add new task"
+ "</span></a></td>\n"
+ );
+ break;
+ case VIEW_NOTES:
+ wprintf(
+ "<td><A HREF=\"/display_enter\">"
+ "<img align=\"middle\" src=\"/static/enternewnote_24x.gif\" "
+ "border=\"0\"><span class=\"navbar_link\">"
+ "Add new note"
+ "</span></a></td>\n"
+ );
+ break;
+ default:
+ wprintf(
+ "<td><A HREF=\"/display_enter\">"
+ "<img align=\"middle\" src=\"/static/newmess3_24x.gif\" "
+ "border=\"0\"><span class=\"navbar_link\">"
+ "Enter a message"
+ "</span></a></td>\n"
+ );
+ break;
+ }
+ wprintf("</span></a></td>\n");
+ }
+
+ if (navbar_style == navbar_default) wprintf(
+ "<td>"
+ "<A HREF=\"/skip\" "
+ "TITLE=\"Leave all messages marked as unread, go to next room with unread messages\">"
+ "<img align=\"middle\" src=\"/static/skipthisroom_24x.gif\" border=\"0\">"
+ "<span class=\"navbar_link\">Skip this room</span></a>"
+ "</td>\n"
+ );
+
+ if (navbar_style == navbar_default) wprintf(
+ "<td>"
+ "<A HREF=\"/gotonext\" "
+ "TITLE=\"Mark all messages as read, go to next room with unread messages\">"
+ "<img align=\"middle\" src=\"/static/markngo_24x.gif\" border=\"0\">"
+ "<span class=\"navbar_link\">Goto next room</span></a>"
+ "</td>\n"
+ );
+
+ wprintf("</tr></table></div>\n");
+ }
+
}
/*
- * generic routine to take the session to a new room
+ * back end routine to take the session to a new room
*
- * display_name values: 0 = goto only
- * 1 = goto and display
- * 2 = display only
*/
-void gotoroom(char *gname, int display_name)
+void gotoroom(char *gname)
{
char buf[SIZ];
static long ls = (-1L);
+ /* store ungoto information */
+ strcpy(WC->ugname, WC->wc_roomname);
+ WC->uglsn = ls;
- if (display_name) {
- output_headers(0);
- wprintf("Pragma: no-cache\n");
- wprintf("Cache-Control: no-store\n");
-
- wprintf("<HTML><HEAD>\n"
- "<META HTTP-EQUIV=\"refresh\" CONTENT=\"500363689;\">\n"
- "<META HTTP-EQUIV=\"Pragma\" CONTENT=\"no-cache\">\n"
- "<META HTTP-EQUIV=\"expired\" CONTENT=\"28-May-1971 18:10:00 GMT\">\n"
- "<meta name=\"MSSmartTagsPreventParsing\" content=\"TRUE\">\n"
- "</HEAD>\n");
- do_template("background");
- }
- if (display_name != 2) {
- /* store ungoto information */
- strcpy(WC->ugname, WC->wc_roomname);
- WC->uglsn = ls;
- }
/* move to the new room */
serv_printf("GOTO %s", gname);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
serv_puts("GOTO _BASEROOM_");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
}
if (buf[0] != '2') {
- if (display_name) {
- wprintf("<EM>%s</EM><BR>\n", &buf[4]);
- wDumpContent(1);
- }
return;
}
- extract(WC->wc_roomname, &buf[4], 0);
+ extract_token(WC->wc_roomname, &buf[4], 0, '|', sizeof WC->wc_roomname);
WC->room_flags = extract_int(&buf[4], 4);
/* highest_msg_read = extract_int(&buf[4],6);
maxmsgnum = extract_int(&buf[4],5);
is_mail = (char) extract_int(&buf[4],7); */
ls = extract_long(&buf[4], 6);
+ WC->wc_floor = extract_int(&buf[4], 10);
+ WC->wc_view = extract_int(&buf[4], 11);
+ WC->wc_default_view = extract_int(&buf[4], 12);
if (WC->is_aide)
WC->is_room_aide = WC->is_aide;
remove_march(WC->wc_roomname);
if (!strcasecmp(gname, "_BASEROOM_"))
remove_march(gname);
-
- /* Display the room banner */
- if (display_name) {
- embed_room_banner(buf);
- wDumpContent(1);
- }
- strcpy(WC->wc_roomname, WC->wc_roomname);
- WC->wc_view = extract_int(&buf[4], 11);
- WC->wc_default_view = extract_int(&buf[4], 12);
}
if (WC->march == NULL) {
serv_puts("LKRN");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '1')
- while (serv_gets(buf), strcmp(buf, "000")) {
+ while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
mptr = (struct march *) malloc(sizeof(struct march));
mptr->next = NULL;
- extract(mptr->march_name, buf, 0);
+ extract_token(mptr->march_name, buf, 0, '|', sizeof mptr->march_name);
mptr->march_floor = extract_int(buf, 2);
mptr->march_order = extract_int(buf, 3);
if (WC->march == NULL) {
void smart_goto(char *next_room) {
- gotoroom(next_room, 0);
+ gotoroom(next_room);
readloop("readnew");
}
/* set pointer */
serv_puts("SLRP HIGHEST");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- wprintf("<EM>%s</EM><BR>\n", &buf[4]);
+ wprintf("<EM>%s</EM><br />\n", &buf[4]);
return;
}
}
return;
}
serv_printf("GOTO %s", WC->ugname);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
smart_goto(WC->wc_roomname);
return;
}
if (WC->uglsn >= 0L) {
serv_printf("SLRP %ld", WC->uglsn);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
}
strcpy(buf, WC->ugname);
strcpy(WC->ugname, "");
int flags, floor, order, view, flags2;
serv_puts("GETR");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') return(0);
- extract(name, &buf[4], 0);
- extract(password, &buf[4], 1);
- extract(dirname, &buf[4], 2);
+ extract_token(name, &buf[4], 0, '|', sizeof name);
+ extract_token(password, &buf[4], 1, '|', sizeof password);
+ extract_token(dirname, &buf[4], 2, '|', sizeof dirname);
flags = extract_int(&buf[4], 3);
floor = extract_int(&buf[4], 4);
order = extract_int(&buf[4], 5);
serv_printf("SETR %s|%s|%s|%d|0|%d|%d|%d|%d",
name, password, dirname, flags,
floor, order, view, flags2);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
}
return(newval);
char buf[SIZ];
char cmd[SIZ];
char node[SIZ];
+ char remote_room[SIZ];
char recp[SIZ];
char er_name[20];
char er_password[10];
char *tab;
char *shared_with;
char *not_shared_with;
+ int roompolicy = 0;
+ int roomvalue = 0;
+ int floorpolicy = 0;
+ int floorvalue = 0;
tab = bstr("tab");
if (strlen(tab) == 0) tab = "admin";
+ load_floorlist();
serv_puts("GETR");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_main_menu();
return;
}
- extract(er_name, &buf[4], 0);
- extract(er_password, &buf[4], 1);
- extract(er_dirname, &buf[4], 2);
+ extract_token(er_name, &buf[4], 0, '|', sizeof er_name);
+ extract_token(er_password, &buf[4], 1, '|', sizeof er_password);
+ extract_token(er_dirname, &buf[4], 2, '|', sizeof er_dirname);
er_flags = extract_int(&buf[4], 3);
er_floor = extract_int(&buf[4], 4);
- output_headers(1);
+ output_headers(1, 1, 1, 0, 0, 0, 0);
/* print the tabbed dialog */
- wprintf("<TABLE border=0 cellspacing=0 cellpadding=0 width=100%%>"
+ wprintf("<br />"
+ "<div id=\"fix_scrollbar_bug\">"
+ "<TABLE border=0 cellspacing=0 cellpadding=0 width=100%%>"
"<TR ALIGN=CENTER>"
"<TD> </TD>\n");
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#AAAAAA\"><A HREF=\"/display_editroom&tab=admin\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=admin\">");
}
- wprintf("Room administration");
+ wprintf("Administration");
if (!strcmp(tab, "admin")) {
wprintf("</SPAN></TD>\n");
}
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#AAAAAA\"><A HREF=\"/display_editroom&tab=config\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=config\">");
}
- wprintf("Room configuration");
+ wprintf("Configuration");
if (!strcmp(tab, "config")) {
wprintf("</SPAN></TD>\n");
}
wprintf("<TD> </TD>\n");
+ if (!strcmp(tab, "expire")) {
+ wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
+ }
+ else {
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=expire\">");
+ }
+ wprintf("Message expire policy");
+ if (!strcmp(tab, "expire")) {
+ wprintf("</SPAN></TD>\n");
+ }
+ else {
+ wprintf("</A></TD>\n");
+ }
+
+ wprintf("<TD> </TD>\n");
+
+ if (!strcmp(tab, "access")) {
+ wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
+ }
+ else {
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=access\">");
+ }
+ wprintf("Access controls");
+ if (!strcmp(tab, "access")) {
+ wprintf("</SPAN></TD>\n");
+ }
+ else {
+ wprintf("</A></TD>\n");
+ }
+
+ wprintf("<TD> </TD>\n");
+
if (!strcmp(tab, "sharing")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#AAAAAA\"><A HREF=\"/display_editroom&tab=sharing\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=sharing\">");
}
wprintf("Sharing");
if (!strcmp(tab, "sharing")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#AAAAAA\"><A HREF=\"/display_editroom&tab=listserv\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=listserv\">");
}
wprintf("Mailing list service");
if (!strcmp(tab, "listserv")) {
wprintf("</A></TD>\n");
}
- wprintf("</TR></TABLE>\n");
+ wprintf("<TD> </TD>\n");
+
+ wprintf("</TR></TABLE></div>\n");
/* end tabbed dialog */
/* begin content of whatever tab is open now */
- wprintf("<TABLE border=0 width=100%% bgcolor=\"#FFFFFF\">\n"
+ wprintf("<div id=\"fix_scrollbar_bug\">"
+ "<TABLE border=0 width=100%% bgcolor=\"#FFFFFF\">\n"
"<TR><TD>\n");
if (!strcmp(tab, "admin")) {
wprintf("<UL>"
- "<LI><A HREF=\"/confirm_delete_room\">\n"
+ "<LI><A HREF=\"/delete_room\" "
+ "onClick=\"return confirm('Are you sure you want to delete this room?');\">\n"
"Delete this room</A>\n"
"<LI><A HREF=\"/display_editroompic\">\n"
- "Set or change the graphic for this room's banner</A>\n"
+ "Set or change the icon for this room's banner</A>\n"
"<LI><A HREF=\"/display_editinfo\">\n"
"Edit this room's Info file</A>\n"
"</UL>");
wprintf("<INPUT TYPE=\"text\" NAME=\"er_name\" VALUE=\"%s\" MAXLENGTH=\"19\">\n", er_name);
wprintf("<LI>Resides on floor: ");
- load_floorlist();
wprintf("<SELECT NAME=\"er_floor\" SIZE=\"1\">\n");
for (i = 0; i < 128; ++i)
if (strlen(floorlist[i]) > 0) {
wprintf("CHECKED ");
wprintf("> Public room\n");
- wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"guessname\" ");
+ wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"hidden\" ");
if ((er_flags & QR_PRIVATE) &&
(er_flags & QR_GUESSNAME))
wprintf("CHECKED ");
wprintf("CHECKED ");
wprintf("> Network shared room\n");
+ wprintf("<LI><INPUT TYPE=\"checkbox\" NAME=\"permanent\" VALUE=\"yes\" ");
+ if (er_flags & QR_PERMANENT)
+ wprintf("CHECKED ");
+ wprintf("> Permanent (does not auto-purge)\n");
+
/* start of anon options */
wprintf("<LI>Anonymous messages<UL>\n");
wprintf("<LI>Room aide: \n");
serv_puts("GETA");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
wprintf("<EM>%s</EM>\n", &buf[4]);
} else {
- extract(er_roomaide, &buf[4], 0);
+ extract_token(er_roomaide, &buf[4], 0, '|', sizeof er_roomaide);
wprintf("<INPUT TYPE=\"text\" NAME=\"er_roomaide\" VALUE=\"%s\" MAXLENGTH=\"25\">\n", er_roomaide);
}
wprintf("</UL><CENTER>\n");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
- wprintf("</CENTER>\n");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"config\">\n"
+ "<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">"
+ " "
+ "<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">"
+ "</CENTER>\n"
+ );
}
/* Learn the current configuration */
serv_puts("CONF getsys|application/x-citadel-ignet-config");
- serv_gets(buf);
- if (buf[0]=='1') while (serv_gets(buf), strcmp(buf, "000")) {
- extract(node, buf, 0);
+ serv_getln(buf, sizeof buf);
+ if (buf[0]=='1') while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(node, buf, 0, '|', sizeof node);
not_shared_with = realloc(not_shared_with,
strlen(not_shared_with) + 32);
strcat(not_shared_with, node);
- strcat(not_shared_with, "|");
+ strcat(not_shared_with, "\n");
}
serv_puts("GNET");
- serv_gets(buf);
- if (buf[0]=='1') while (serv_gets(buf), strcmp(buf, "000")) {
- extract(cmd, buf, 0);
- extract(node, buf, 1);
+ serv_getln(buf, sizeof buf);
+ if (buf[0]=='1') while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(cmd, buf, 0, '|', sizeof cmd);
+ extract_token(node, buf, 1, '|', sizeof node);
+ extract_token(remote_room, buf, 2, '|', sizeof remote_room);
if (!strcasecmp(cmd, "ignet_push_share")) {
shared_with = realloc(shared_with,
strlen(shared_with) + 32);
strcat(shared_with, node);
- strcat(shared_with, "|");
+ if (strlen(remote_room) > 0) {
+ strcat(shared_with, "|");
+ strcat(shared_with, remote_room);
+ }
+ strcat(shared_with, "\n");
}
}
- for (i=0; i<num_tokens(shared_with, '|'); ++i) {
- extract(node, shared_with, i);
- for (j=0; j<num_tokens(not_shared_with, '|'); ++j) {
- extract(cmd, not_shared_with, j);
+ for (i=0; i<num_tokens(shared_with, '\n'); ++i) {
+ extract_token(buf, shared_with, i, '\n', sizeof buf);
+ extract_token(node, buf, 0, '|', sizeof node);
+ for (j=0; j<num_tokens(not_shared_with, '\n'); ++j) {
+ extract_token(cmd, not_shared_with, j, '\n', sizeof cmd);
if (!strcasecmp(node, cmd)) {
- remove_token(not_shared_with, j, '|');
+ remove_token(not_shared_with, j, '\n');
}
}
}
/* Display the stuff */
- wprintf("<CENTER><BR>"
+ wprintf("<CENTER><br />"
"<TABLE border=1 cellpadding=5><TR>"
"<TD><B><I>Shared with</I></B></TD>"
"<TD><B><I>Not shared with</I></B></TD></TR>\n"
- "<TR><TD>\n");
-
- for (i=0; i<num_tokens(shared_with, '|'); ++i) {
- extract(node, shared_with, i);
+ "<TR><TD VALIGN=TOP>\n");
+
+ wprintf("<TABLE border=0 cellpadding=5><TR BGCOLOR=\"#CCCCCC\">"
+ "<TD>Remote node name</TD>"
+ "<TD>Remote room name</TD>"
+ "<TD>Actions</TD>"
+ "</TR>\n"
+ );
+
+ for (i=0; i<num_tokens(shared_with, '\n'); ++i) {
+ extract_token(buf, shared_with, i, '\n', sizeof buf);
+ extract_token(node, buf, 0, '|', sizeof node);
+ extract_token(remote_room, buf, 1, '|', sizeof remote_room);
if (strlen(node) > 0) {
- wprintf("%s ", node);
- wprintf("<A HREF=\"/netedit&cmd=remove&line="
- "ignet_push_share|");
+ wprintf("<FORM METHOD=\"POST\" "
+ "ACTION=\"/netedit\">"
+ "<TR><TD>%s</TD>\n", node);
+
+ wprintf("<TD>");
+ if (strlen(remote_room) > 0) {
+ escputs(remote_room);
+ }
+ wprintf("</TD>");
+
+ wprintf("<TD>");
+
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"line\" "
+ "VALUE=\"ignet_push_share|");
urlescputs(node);
- wprintf("&tab=sharing\">(unshare)</A><BR>");
+ if (strlen(remote_room) > 0) {
+ wprintf("|");
+ urlescputs(remote_room);
+ }
+ wprintf("\">");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" "
+ "VALUE=\"sharing\">\n");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"cmd\" "
+ "VALUE=\"remove\">\n");
+ wprintf("<INPUT TYPE=\"submit\" "
+ "NAME=\"sc\" VALUE=\"Unshare\">");
+ wprintf("</TD></TR></FORM>\n");
}
}
- wprintf("</TD><TD>\n");
-
- for (i=0; i<num_tokens(not_shared_with, '|'); ++i) {
- extract(node, not_shared_with, i);
+ wprintf("</TABLE>\n");
+ wprintf("</TD><TD VALIGN=TOP>\n");
+ wprintf("<TABLE border=0 cellpadding=5><TR BGCOLOR=\"#CCCCCC\">"
+ "<TD>Remote node name</TD>"
+ "<TD>Remote room name</TD>"
+ "<TD>Actions</TD>"
+ "</TR>\n"
+ );
+
+ for (i=0; i<num_tokens(not_shared_with, '\n'); ++i) {
+ extract_token(node, not_shared_with, i, '\n', sizeof node);
if (strlen(node) > 0) {
- wprintf("%s ", node);
- wprintf("<A HREF=\"/netedit&cmd=add&line="
- "ignet_push_share|");
+ wprintf("<FORM METHOD=\"POST\" "
+ "ACTION=\"/netedit\">"
+ "<TR><TD>");
+ escputs(node);
+ wprintf("</TD><TD>"
+ "<INPUT TYPE=\"INPUT\" "
+ "NAME=\"suffix\" "
+ "MAXLENGTH=128>"
+ "</TD><TD>");
+ wprintf("<INPUT TYPE=\"hidden\" "
+ "NAME=\"line\" "
+ "VALUE=\"ignet_push_share|");
urlescputs(node);
- wprintf("&tab=sharing\">(share)</A><BR>");
+ wprintf("|\">");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" "
+ "VALUE=\"sharing\">\n");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"cmd\" "
+ "VALUE=\"add\">\n");
+ wprintf("<INPUT TYPE=\"submit\" "
+ "NAME=\"sc\" VALUE=\"Share\">");
+ wprintf("</TD></TR></FORM>\n");
}
}
+ wprintf("</TABLE>\n");
wprintf("</TD></TR>"
- "</TABLE><BR>\n"
- "<I><B>Reminder:</B> When sharing a room, "
+ "</TABLE></CENTER><br />\n"
+ "<I><B>Notes:</B><UL><LI>When sharing a room, "
"it must be shared from both ends. Adding a node to "
"the 'shared' list sends messages out, but in order to"
" receive messages, the other nodes must be configured"
- " to send messages out to your system as well.</I><BR>"
- "</CENTER>\n");
+ " to send messages out to your system as well.\n"
+ "<LI>If the remote room name is blank, it is assumed "
+ "that the room name is identical on the remote node."
+ "<LI>If the remote room name is different, the remote "
+ "node must also configure the name of the room here."
+ "</UL></I><br />\n"
+ );
}
/* Mailing list management */
if (!strcmp(tab, "listserv")) {
- wprintf("<BR><center>"
+ wprintf("<br /><center>"
"<TABLE BORDER=0 WIDTH=100%% CELLPADDING=5>"
"<TR><TD VALIGN=TOP>");
wprintf("<i>The contents of this room are being "
"mailed <b>as individual messages</b> "
"to the following list recipients:"
- "</i><br><br>\n");
+ "</i><br /><br />\n");
serv_puts("GNET");
- serv_gets(buf);
- if (buf[0]=='1') while (serv_gets(buf), strcmp(buf, "000")) {
- extract(cmd, buf, 0);
+ serv_getln(buf, sizeof buf);
+ if (buf[0]=='1') while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(cmd, buf, 0, '|', sizeof cmd);
if (!strcasecmp(cmd, "listrecp")) {
- extract(recp, buf, 1);
+ extract_token(recp, buf, 1, '|', sizeof recp);
escputs(recp);
wprintf(" <A HREF=\"/netedit&cmd=remove&line="
"listrecp|");
urlescputs(recp);
- wprintf("&tab=listserv\">(remove)</A><BR>");
+ wprintf("&tab=listserv\">(remove)</A><br />");
}
}
- wprintf("<BR><FORM METHOD=\"POST\" ACTION=\"/netedit\">\n"
+ wprintf("<br /><FORM METHOD=\"POST\" ACTION=\"/netedit\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"listserv\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"prefix\" VALUE=\"listrecp|\">\n");
wprintf("<INPUT TYPE=\"text\" NAME=\"line\">\n");
wprintf("<i>The contents of this room are being "
"mailed <b>in digest form</b> "
"to the following list recipients:"
- "</i><br><br>\n");
+ "</i><br /><br />\n");
serv_puts("GNET");
- serv_gets(buf);
- if (buf[0]=='1') while (serv_gets(buf), strcmp(buf, "000")) {
- extract(cmd, buf, 0);
+ serv_getln(buf, sizeof buf);
+ if (buf[0]=='1') while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(cmd, buf, 0, '|', sizeof cmd);
if (!strcasecmp(cmd, "digestrecp")) {
- extract(recp, buf, 1);
+ extract_token(recp, buf, 1, '|', sizeof recp);
escputs(recp);
wprintf(" <A HREF=\"/netedit&cmd=remove&line="
"digestrecp|");
urlescputs(recp);
- wprintf("&tab=listserv\">(remove)</A><BR>");
+ wprintf("&tab=listserv\">(remove)</A><br />");
}
}
- wprintf("<BR><FORM METHOD=\"POST\" ACTION=\"/netedit\">\n"
+ wprintf("<br /><FORM METHOD=\"POST\" ACTION=\"/netedit\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"listserv\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"prefix\" VALUE=\"digestrecp|\">\n");
wprintf("<INPUT TYPE=\"text\" NAME=\"line\">\n");
wprintf("<INPUT TYPE=\"submit\" NAME=\"cmd\" VALUE=\"Add\">");
wprintf("</FORM>\n");
- wprintf("</TD></TR></TABLE><HR>\n");
+ wprintf("</TD></TR></TABLE><hr />\n");
if (self_service(999) == 1) {
wprintf("This room is configured to allow "
"self-service subscribe/unsubscribe requests."
" <A HREF=\"/toggle_self_service?newval=0&"
"tab=listserv\">"
- "Click to disable.</A><BR>\n"
+ "Click to disable.</A><br />\n"
"The URL for subscribe/unsubscribe is: "
- "<TT>http://%s/listsub</TT><BR>\n",
+ "<TT>http://%s/listsub</TT><br />\n",
WC->http_host
);
}
"self-service subscribe/unsubscribe requests."
" <A HREF=\"/toggle_self_service?newval=1&"
"tab=listserv\">"
- "Click to enable.</A><BR>\n"
+ "Click to enable.</A><br />\n"
);
}
wprintf("</CENTER>\n");
}
+
+ /* Mailing list management */
+ if (!strcmp(tab, "expire")) {
+
+ serv_puts("GPEX room");
+ serv_getln(buf, sizeof buf);
+ if (buf[0] == '2') {
+ roompolicy = extract_int(&buf[4], 0);
+ roomvalue = extract_int(&buf[4], 1);
+ }
+
+ serv_puts("GPEX floor");
+ serv_getln(buf, sizeof buf);
+ if (buf[0] == '2') {
+ floorpolicy = extract_int(&buf[4], 0);
+ floorvalue = extract_int(&buf[4], 1);
+ }
+
+ wprintf("<br /><FORM METHOD=\"POST\" ACTION=\"/set_room_policy\">\n");
+ wprintf("<TABLE border=0 cellspacing=5>\n");
+ wprintf("<TR><TD>Message expire policy for this room<br />(");
+ escputs(WC->wc_roomname);
+ wprintf(")</TD><TD>");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"roompolicy\" VALUE=\"0\" %s>",
+ ((roompolicy == 0) ? "CHECKED" : "") );
+ wprintf("Use the default policy for this floor<br />\n");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"roompolicy\" VALUE=\"1\" %s>",
+ ((roompolicy == 1) ? "CHECKED" : "") );
+ wprintf("Never automatically expire messages<br />\n");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"roompolicy\" VALUE=\"2\" %s>",
+ ((roompolicy == 2) ? "CHECKED" : "") );
+ wprintf("Expire by message count<br />\n");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"roompolicy\" VALUE=\"3\" %s>",
+ ((roompolicy == 3) ? "CHECKED" : "") );
+ wprintf("Expire by message age<br />");
+ wprintf("Number of messages or days: ");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"roomvalue\" MAXLENGTH=\"5\" VALUE=\"%d\">", roomvalue);
+ wprintf("</TD></TR>\n");
+
+ if (WC->axlevel >= 6) {
+ wprintf("<TR><TD COLSPAN=2><hr /></TD></TR>\n");
+ wprintf("<TR><TD>Message expire policy for this floor<br />(");
+ escputs(floorlist[WC->wc_floor]);
+ wprintf(")</TD><TD>");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"floorpolicy\" VALUE=\"0\" %s>",
+ ((floorpolicy == 0) ? "CHECKED" : "") );
+ wprintf("Use the system default<br />\n");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"floorpolicy\" VALUE=\"1\" %s>",
+ ((floorpolicy == 1) ? "CHECKED" : "") );
+ wprintf("Never automatically expire messages<br />\n");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"floorpolicy\" VALUE=\"2\" %s>",
+ ((floorpolicy == 2) ? "CHECKED" : "") );
+ wprintf("Expire by message count<br />\n");
+ wprintf("<INPUT TYPE=\"radio\" NAME=\"floorpolicy\" VALUE=\"3\" %s>",
+ ((floorpolicy == 3) ? "CHECKED" : "") );
+ wprintf("Expire by message age<br />");
+ wprintf("Number of messages or days: ");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"floorvalue\" MAXLENGTH=\"5\" VALUE=\"%d\">",
+ floorvalue);
+ }
+
+ wprintf("<CENTER>\n");
+ wprintf("<TR><TD COLSPAN=2><hr /><CENTER>\n");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+ wprintf(" ");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
+ wprintf("</CENTER></TD><TR>\n");
+
+ wprintf("</TABLE>\n"
+ "<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"expire\">\n"
+ "</FORM>\n"
+ );
+
+ }
+
+ /* Mailing list management */
+ if (!strcmp(tab, "access")) {
+ display_whok();
+ }
+
/* end content of whatever tab is open now */
- wprintf("</TD></TR></TABLE>\n");
+ wprintf("</TD></TR></TABLE></div>\n");
wDumpContent(1);
}
if (strcmp(bstr("sc"), "OK")) {
- display_error("Cancelled. Changes were not saved.");
+ strcpy(WC->ImportantMessage,
+ "Cancelled. Changes were not saved.");
+ display_editroom();
return;
}
serv_puts("GETR");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_editroom();
return;
}
- extract(er_name, &buf[4], 0);
- extract(er_password, &buf[4], 1);
- extract(er_dirname, &buf[4], 2);
+ extract_token(er_name, &buf[4], 0, '|', sizeof er_name);
+ extract_token(er_password, &buf[4], 1, '|', sizeof er_password);
+ extract_token(er_dirname, &buf[4], 2, '|', sizeof er_dirname);
er_flags = extract_int(&buf[4], 3);
strcpy(er_roomaide, bstr("er_roomaide"));
if (strlen(er_roomaide) == 0) {
serv_puts("GETA");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
strcpy(er_roomaide, "");
} else {
- extract(er_roomaide, &buf[4], 0);
+ extract_token(er_roomaide, &buf[4], 0, '|', sizeof er_roomaide);
}
}
strcpy(buf, bstr("er_name"));
if (!strcmp(buf, "invonly")) {
er_flags |= (QR_PRIVATE);
}
- if (!strcmp(buf, "guessname")) {
+ if (!strcmp(buf, "hidden")) {
er_flags |= (QR_PRIVATE | QR_GUESSNAME);
}
if (!strcmp(buf, "passworded")) {
er_flags &= ~QR_READONLY;
}
+ if (!strcmp(bstr("permanent"), "yes")) {
+ er_flags |= QR_PERMANENT;
+ } else {
+ er_flags &= ~QR_PERMANENT;
+ }
+
if (!strcmp(bstr("network"), "yes")) {
er_flags |= QR_NETWORK;
} else {
sprintf(buf, "SETR %s|%s|%s|%u|%d|%d",
er_name, er_password, er_dirname, er_flags, bump, er_floor);
serv_puts(buf);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_editroom();
return;
}
- gotoroom(er_name, 0);
+ gotoroom(er_name);
if (strlen(er_roomaide) > 0) {
sprintf(buf, "SETA %s", er_roomaide);
serv_puts(buf);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_main_menu();
return;
}
}
- smart_goto(er_name);
+ gotoroom(er_name);
+ strcpy(WC->ImportantMessage, "Your changes have been saved.");
+ display_editroom();
+ return;
}
+
/*
- * Invite, Kick, and show Who Knows a room
+ * Display form for Invite, Kick, and show Who Knows a room
*/
-void display_whok(void)
-{
+void do_invt_kick(void) {
char buf[SIZ], room[SIZ], username[SIZ];
serv_puts("GETR");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
- return;
+ escputs(&buf[4]);
+ return;
}
- extract(room, &buf[4], 0);
+ extract_token(room, &buf[4], 0, '|', sizeof room);
strcpy(username, bstr("username"));
- output_headers(1);
- stresc(buf, WC->wc_roomname, 1);
- svprintf("BOXTITLE", WCS_STRING, "Access control list for %s", buf);
- do_template("beginbox");
-
- if(!strcmp(bstr("sc"), "Kick")) {
+ if (!strcmp(bstr("sc"), "Kick")) {
sprintf(buf, "KICK %s", username);
serv_puts(buf);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
- return;
+ strcpy(WC->ImportantMessage, &buf[4]);
} else {
- wprintf("<B><I>User %s kicked out of room %s.</I></B>\n",
+ sprintf(WC->ImportantMessage,
+ "<B><I>User %s kicked out of room %s.</I></B>\n",
username, room);
}
- } else if(!strcmp(bstr("sc"), "Invite")) {
+ }
+
+ if (!strcmp(bstr("sc"), "Invite")) {
sprintf(buf, "INVT %s", username);
serv_puts(buf);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
- return;
+ strcpy(WC->ImportantMessage, &buf[4]);
} else {
- wprintf("<B><I>User %s invited to room %s.</I></B>\n",
+ sprintf(WC->ImportantMessage,
+ "<B><I>User %s invited to room %s.</I></B>\n",
username, room);
}
}
-
+ display_editroom();
+}
+
+
+
+/*
+ * Display form for Invite, Kick, and show Who Knows a room
+ */
+void display_whok(void)
+{
+ char buf[SIZ], room[SIZ], username[SIZ];
+
+ serv_puts("GETR");
+ serv_getln(buf, sizeof buf);
+
+ if (buf[0] != '2') {
+ escputs(&buf[4]);
+ return;
+ }
+ extract_token(room, &buf[4], 0, '|', sizeof room);
+
wprintf("<TABLE border=0 CELLSPACING=10><TR VALIGN=TOP>"
"<TD>The users listed below have access to this room. "
"To remove a user from the access list, select the user "
- "name from the list and click 'Kick'.<BR><BR>");
+ "name from the list and click 'Kick'.<br /><br />");
- wprintf("<CENTER><FORM METHOD=\"POST\" ACTION=\"/display_whok\">\n");
- wprintf("<SELECT NAME=\"username\" SIZE=10>\n");
+ wprintf("<CENTER><FORM METHOD=\"POST\" ACTION=\"/do_invt_kick\">\n");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"access\">\n");
+ wprintf("<SELECT NAME=\"username\" SIZE=\"10\" style=\"width:100%%\">\n");
serv_puts("WHOK");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '1') {
- while (serv_gets(buf), strcmp(buf, "000")) {
- extract(username, buf, 0);
+ while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(username, buf, 0, '|', sizeof username);
wprintf("<OPTION>");
escputs(username);
wprintf("\n");
}
}
- wprintf("</SELECT><BR>\n");
+ wprintf("</SELECT><br />\n");
wprintf("<input type=submit name=sc value=\"Kick\">");
wprintf("</FORM></CENTER>\n");
wprintf("</TD><TD>"
"To grant another user access to this room, enter the "
- "user name in the box below and click 'Invite'.<BR><BR>");
+ "user name in the box below and click 'Invite'.<br /><br />");
- wprintf("<CENTER><FORM METHOD=\"POST\" ACTION=\"/display_whok\">\n");
+ wprintf("<CENTER><FORM METHOD=\"POST\" ACTION=\"/do_invt_kick\">\n");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"access\">\n");
wprintf("Invite: ");
- wprintf("<input type=text name=username><BR>\n"
- "<input type=hidden name=sc value=\"Invite\">"
- "<input type=submit value=\"Invite\">"
+ wprintf("<input type=\"text\" name=\"username\" style=\"width:100%%\"><br />\n"
+ "<input type=\"hidden\" name=\"sc\" value=\"Invite\">"
+ "<input type=\"submit\" value=\"Invite\">"
"</FORM></CENTER>\n");
wprintf("</TD></TR></TABLE>\n");
- do_template("endbox");
wDumpContent(1);
}
char buf[SIZ];
serv_puts("CRE8 0");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_main_menu();
return;
}
- output_headers(3);
- svprintf("BOXTITLE", WCS_STRING, "Create a new room");
- do_template("beginbox");
- wprintf("<FORM METHOD=\"POST\" ACTION=\"/entroom\">\n");
-
- wprintf("<UL><LI>Name of room: ");
- wprintf("<INPUT TYPE=\"text\" NAME=\"er_name\" MAXLENGTH=\"19\">\n");
-
- wprintf("<LI>Type of room:<UL>\n");
-
- wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"public\" ");
- wprintf("CHECKED > Public room\n");
-
- wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"guessname\" ");
- wprintf("> Private - guess name\n");
+ output_headers(1, 1, 2, 0, 0, 0, 0);
+ wprintf("<div id=\"banner\">\n"
+ "<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>"
+ "<SPAN CLASS=\"titlebar\">Create a new room</SPAN>"
+ "</TD></TR></TABLE>\n"
+ "</div>\n<div id=\"content\">\n"
+ );
- wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"passworded\" ");
- wprintf("> Private - require password:\n");
- wprintf("<INPUT TYPE=\"text\" NAME=\"er_password\" MAXLENGTH=\"9\">\n");
+ wprintf("<div id=\"fix_scrollbar_bug\">"
+ "<table border=0 width=100%% bgcolor=\"#ffffff\"><tr><td>\n");
- wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"invonly\" ");
- wprintf("> Private - invitation only\n");
+ wprintf("<form name=\"create_room_form\" method=\"POST\" action=\"/entroom\">\n");
- wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"personal\" ");
- wprintf("> Personal (mailbox for you only)\n");
- wprintf("</UL>\n");
+ wprintf("<UL><LI>Name of room: ");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"er_name\" MAXLENGTH=\"127\">\n");
wprintf("<LI>Resides on floor: ");
load_floorlist();
escputs(floorlist[i]);
wprintf("</OPTION>\n");
}
- wprintf("</SELECT>\n");
- wprintf("</UL>\n");
+ wprintf("</SELECT>\n");
+
+ /* Our clever little snippet of JavaScript automatically selects
+ * a public room if the view is set to Bulletin Board, and it
+ * selects a mailbox room otherwise. The user can override this,
+ * of course.
+ */
+ wprintf("<LI>Default view for room: ");
+ wprintf("<SELECT NAME=\"er_view\" SIZE=\"1\" OnChange=\""
+ " if (this.form.er_view.value == 0) { "
+ " 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) {
+ wprintf("<OPTION %s VALUE=\"%d\">",
+ ((i == 0) ? "SELECTED" : ""), i );
+ escputs(viewdefs[i]);
+ wprintf("</OPTION>\n");
+ }
+ wprintf("</SELECT>\n");
+
+ wprintf("<LI>Type of room:<UL>\n");
+
+ wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"public\" ");
+ wprintf("CHECKED OnChange=\""
+ " if (this.form.type[0].checked == true) { "
+ " this.form.er_floor.disabled = false; "
+ " } "
+ "\"> Public (automatically appears to everyone)\n");
+
+ wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"hidden\" OnChange=\""
+ " if (this.form.type[1].checked == true) { "
+ " this.form.er_floor.disabled = false; "
+ " } "
+ "\"> Private - hidden (accessible to anyone who knows its name)\n");
+
+ wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"passworded\" OnChange=\""
+ " if (this.form.type[2].checked == true) { "
+ " this.form.er_floor.disabled = false; "
+ " } "
+ "\"> Private - require password:\n");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"er_password\" MAXLENGTH=\"9\">\n");
+ wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"invonly\" OnChange=\""
+ " if (this.form.type[3].checked == true) { "
+ " this.form.er_floor.disabled = false; "
+ " } "
+ "\"> Private - invitation only\n");
+
+ wprintf("<LI><INPUT TYPE=\"radio\" NAME=\"type\" VALUE=\"personal\" "
+ "OnChange=\""
+ " if (this.form.type[4].checked == true) { "
+ " this.form.er_floor.disabled = true; "
+ " } "
+ "\"> Personal (mailbox for you only)\n");
+
+ wprintf("</UL>\n");
wprintf("<CENTER>\n");
wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+ wprintf(" ");
wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
wprintf("</CENTER>\n");
- wprintf("</FORM>\n<HR>");
+ wprintf("</FORM>\n<hr />");
serv_printf("MESG roomaccess");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '1') {
- fmout(NULL);
+ fmout(NULL, "CENTER");
}
- do_template("endbox");
+ wprintf("</td></tr></table></div>\n");
wDumpContent(1);
}
+
+/*
+ * support function for entroom() -- sets the default view
+ */
+void er_set_default_view(int newview) {
+
+ char buf[SIZ];
+
+ char rm_name[SIZ];
+ char rm_pass[SIZ];
+ char rm_dir[SIZ];
+ int rm_bits1;
+ int rm_floor;
+ int rm_listorder;
+ int rm_bits2;
+
+ serv_puts("GETR");
+ serv_getln(buf, sizeof buf);
+ if (buf[0] != '2') return;
+
+ extract_token(rm_name, &buf[4], 0, '|', sizeof rm_name);
+ extract_token(rm_pass, &buf[4], 1, '|', sizeof rm_pass);
+ extract_token(rm_dir, &buf[4], 2, '|', sizeof rm_dir);
+ rm_bits1 = extract_int(&buf[4], 3);
+ rm_floor = extract_int(&buf[4], 4);
+ rm_listorder = extract_int(&buf[4], 5);
+ rm_bits2 = extract_int(&buf[4], 7);
+
+ serv_printf("SETR %s|%s|%s|%d|0|%d|%d|%d|%d",
+ rm_name, rm_pass, rm_dir, rm_bits1, rm_floor,
+ rm_listorder, newview, rm_bits2
+ );
+ serv_getln(buf, sizeof buf);
+}
+
+
+
/*
* enter a new room
*/
void entroom(void)
{
char buf[SIZ];
- char er_name[20];
- char er_type[20];
- char er_password[10];
+ char er_name[SIZ];
+ char er_type[SIZ];
+ char er_password[SIZ];
int er_floor;
int er_num_type;
+ int er_view;
if (strcmp(bstr("sc"), "OK")) {
- display_error("Cancelled. No new room was created.");
+ strcpy(WC->ImportantMessage,
+ "Cancelled. No new room was created.");
+ display_main_menu();
return;
}
strcpy(er_name, bstr("er_name"));
strcpy(er_type, bstr("type"));
strcpy(er_password, bstr("er_password"));
er_floor = atoi(bstr("er_floor"));
+ er_view = atoi(bstr("er_view"));
er_num_type = 0;
- if (!strcmp(er_type, "guessname"))
+ if (!strcmp(er_type, "hidden"))
er_num_type = 1;
if (!strcmp(er_type, "passworded"))
er_num_type = 2;
if (!strcmp(er_type, "personal"))
er_num_type = 4;
- sprintf(buf, "CRE8 1|%s|%d|%s|%d",
- er_name, er_num_type, er_password, er_floor);
+ sprintf(buf, "CRE8 1|%s|%d|%s|%d|%d|%d",
+ er_name, er_num_type, er_password, er_floor, 0, er_view);
serv_puts(buf);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_main_menu();
return;
}
- smart_goto(er_name);
+ gotoroom(er_name);
+ do_change_view(er_view); /* Now go there */
}
*/
void display_private(char *rname, int req_pass)
{
+ output_headers(1, 1, 2, 0, 0, 0, 0);
+ wprintf("<div id=\"banner\">\n"
+ "<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>"
+ "<SPAN CLASS=\"titlebar\">Go to a hidden room</SPAN>"
+ "</TD></TR></TABLE>\n"
+ "</div>\n<div id=\"content\">\n"
+ );
- output_headers(3);
-
- svprintf("BOXTITLE", WCS_STRING, "Go to a hidden room");
- do_template("beginbox");
+ wprintf("<div id=\"fix_scrollbar_bug\">"
+ "<table border=0 width=100%% bgcolor=\"#ffffff\"><tr><td>\n");
wprintf("<CENTER>\n");
- wprintf("If you know the name of a hidden (guess-name) or\n");
+ wprintf("<br />If you know the name of a hidden (guess-name) or\n");
wprintf("passworded room, you can enter that room by typing\n");
wprintf("its name below. Once you gain access to a private\n");
wprintf("room, it will appear in your regular room listings\n");
wprintf("so you don't have to keep returning here.\n");
- wprintf("<BR><BR>");
+ wprintf("<br /><br />");
wprintf("<FORM METHOD=\"GET\" ACTION=\"/goto_private\">\n");
- wprintf("<TABLE border><TR><TD>");
- wprintf("Enter room name:</TD><TD>");
- wprintf("<INPUT TYPE=\"text\" NAME=\"gr_name\" VALUE=\"%s\" MAXLENGTH=\"19\">\n", rname);
+ wprintf("<table border=\"0\" cellspacing=\"5\" "
+ "cellpadding=\"5\" BGCOLOR=\"#EEEEEE\">\n"
+ "<TR><TD>"
+ "Enter room name:</TD><TD>"
+ "<INPUT TYPE=\"text\" NAME=\"gr_name\" "
+ "VALUE=\"%s\" MAXLENGTH=\"19\">\n", rname);
if (req_pass) {
wprintf("</TD></TR><TR><TD>");
wprintf("Enter room password:</TD><TD>");
wprintf("<INPUT TYPE=\"password\" NAME=\"gr_pass\" MAXLENGTH=\"9\">\n");
}
- wprintf("</TD></TR></TABLE><BR>\n");
+ wprintf("</TD></TR></TABLE><br />\n");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">"
+ " "
+ "<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
wprintf("</FORM>\n");
- do_template("endbox");
+ wprintf("</td></tr></table></div>\n");
wDumpContent(1);
}
strcat(buf, "|");
strcat(buf, bstr("gr_pass"));
serv_puts(buf);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '2') {
smart_goto(bstr("gr_name"));
display_private(bstr("gr_name"), 1);
return;
}
- output_headers(1);
+ output_headers(1, 1, 1, 0, 0, 0, 0);
wprintf("%s\n", &buf[4]);
wDumpContent(1);
return;
*/
void display_zap(void)
{
- output_headers(1);
+ output_headers(1, 1, 2, 0, 0, 0, 0);
+ wprintf("<div id=\"banner\">\n");
wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#770000\"><TR><TD>");
- wprintf("<SPAN CLASS=\"titlebar\">Zap (forget) the current room</SPAN>\n");
+ wprintf("<SPAN CLASS=\"titlebar\">Zap (forget/unsubscribe) the current room</SPAN>\n");
wprintf("</TD></TR></TABLE>\n");
+ wprintf("</div>\n<div id=\"content\">\n");
wprintf("If you select this option, <em>%s</em> will ", WC->wc_roomname);
wprintf("disappear from your room list. Is this what you wish ");
- wprintf("to do?<BR>\n");
+ wprintf("to do?<br />\n");
wprintf("<FORM METHOD=\"GET\" ACTION=\"/zap\">\n");
wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+ wprintf(" ");
wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
wprintf("</FORM>\n");
wDumpContent(1);
if (!strcasecmp(bstr("sc"), "OK")) {
serv_printf("GOTO %s", WC->wc_roomname);
- serv_gets(buf);
- if (buf[0] != '2') {
- /* ExpressMessageCat(&buf[4]); */
- } else {
+ serv_getln(buf, sizeof buf);
+ if (buf[0] == '2') {
serv_puts("FORG");
- serv_gets(buf);
- if (buf[0] != '2') {
- /* ExpressMessageCat(&buf[4]); */
- } else {
+ serv_getln(buf, sizeof buf);
+ if (buf[0] == '2') {
strcpy(final_destination, "_BASEROOM_");
}
}
-
-/*
- * Confirm deletion of the current room
- */
-void confirm_delete_room(void)
-{
- char buf[SIZ];
-
- serv_puts("KILL 0");
- serv_gets(buf);
- if (buf[0] != '2') {
- display_error(&buf[4]);
- return;
- }
- output_headers(1);
- wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#770000\"><TR><TD>");
- wprintf("<SPAN CLASS=\"titlebar\">Confirm deletion of room</SPAN>\n");
- wprintf("</TD></TR></TABLE>\n");
-
- wprintf("<CENTER>");
- wprintf("<FORM METHOD=\"GET\" ACTION=\"/delete_room\">\n");
-
- wprintf("Are you sure you want to delete <FONT SIZE=+1>");
- escputs(WC->wc_roomname);
- wprintf("</FONT>?<BR>\n");
-
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Delete\">");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
-
- wprintf("</FORM></CENTER>\n");
- wDumpContent(1);
-}
-
-
/*
* Delete the current room
*/
void delete_room(void)
{
char buf[SIZ];
- char sc[SIZ];
-
- strcpy(sc, bstr("sc"));
- if (strcasecmp(sc, "Delete")) {
- display_error("Cancelled. This room was not deleted.");
- return;
- }
serv_puts("KILL 1");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '2') {
- display_error(&buf[4]);
+ strcpy(WC->ImportantMessage, &buf[4]);
+ display_main_menu();
+ return;
} else {
smart_goto("_BASEROOM_");
}
FILE *fp;
char buf[SIZ];
char line[SIZ];
+ char cmpa0[SIZ];
+ char cmpa1[SIZ];
+ char cmpb0[SIZ];
+ char cmpb1[SIZ];
if (strlen(bstr("line"))==0) {
display_editroom();
}
serv_puts("GNET");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '1') {
fclose(fp);
display_editroom();
}
/* This loop works for add *or* remove. Spiffy, eh? */
- while (serv_gets(buf), strcmp(buf, "000")) {
- if (strcasecmp(buf, line)) {
+ while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(cmpa0, buf, 0, '|', sizeof cmpa0);
+ extract_token(cmpa1, buf, 1, '|', sizeof cmpa1);
+ extract_token(cmpb0, line, 0, '|', sizeof cmpb0);
+ extract_token(cmpb1, line, 1, '|', sizeof cmpb1);
+ if ( (strcasecmp(cmpa0, cmpb0))
+ || (strcasecmp(cmpa1, cmpb1)) ) {
fprintf(fp, "%s\n", buf);
}
}
rewind(fp);
serv_puts("SNET");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '4') {
fclose(fp);
display_editroom();
+/*
+ * Back end for change_view()
+ */
+void do_change_view(int newview) {
+ char buf[SIZ];
+
+ serv_printf("VIEW %d", newview);
+ serv_getln(buf, sizeof buf);
+ WC->wc_view = newview;
+ smart_goto(WC->wc_roomname);
+}
*/
void change_view(void) {
int view;
- char buf[SIZ];
view = atol(bstr("view"));
-
- serv_printf("VIEW %d", view);
- serv_gets(buf);
- smart_goto(WC->wc_roomname);
+ do_change_view(view);
}
*/
void do_folder_view(struct folder *fold, int max_folders, int num_floors) {
char buf[SIZ];
- int levels, oldlevels;
- int i, t;
+ int levels;
+ int i;
+ int has_subfolders = 0;
+ int *parents;
+
+ parents = malloc(max_folders * sizeof(int));
+
+ /* BEGIN TREE MENU */
+ wprintf("<div id=\"roomlist_div\">Loading folder list...</div>\n");
+
+ /* include NanoTree */
+ wprintf("<script type=\"text/javascript\" src=\"static/nanotree.js\"></script>\n");
+
+ /* initialize NanoTree */
+ wprintf("<script type=\"text/javascript\"> \n"
+ " showRootNode = false; \n"
+ " sortNodes = false; \n"
+ " dragable = false; \n"
+ " \n"
+ " function standardClick(treeNode) { \n"
+ " } \n"
+ " \n"
+ " var closedGif = 'static/folder_closed.gif'; \n"
+ " var openGif = 'static/folder_open.gif'; \n"
+ " \n"
+ " rootNode = new TreeNode(1, 'root node - hide'); \n"
+ );
- do_template("beginbox_nt");
levels = 0;
- oldlevels = 0;
for (i=0; i<max_folders; ++i) {
+ has_subfolders = 0;
+ if ((i+1) < max_folders) {
+ if ( (!strncasecmp(fold[i].name, fold[i+1].name, strlen(fold[i].name)))
+ && (fold[i+1].name[strlen(fold[i].name)] == '|') ) {
+ has_subfolders = 1;
+ }
+ }
+
levels = num_tokens(fold[i].name, '|');
- oldlevels = levels;
+ parents[levels] = i;
+
+ wprintf("var node%d = new TreeNode(%d, '", i, i);
- for (t=0; t<levels; ++t) wprintf(" ");
if (fold[i].selectable) {
wprintf("<A HREF=\"/dotgoto?room=");
urlescputs(fold[i].room);
wprintf("\">");
}
+
+ if (levels == 1) {
+ wprintf("<SPAN CLASS=\"roomlist_floor\">");
+ }
+ else if (fold[i].hasnewmsgs) {
+ wprintf("<SPAN CLASS=\"roomlist_new\">");
+ }
else {
- wprintf("<i>");
+ wprintf("<SPAN CLASS=\"roomlist_old\">");
}
- if (fold[i].hasnewmsgs) wprintf("<B>");
- extract(buf, fold[i].name, levels-1);
+ extract_token(buf, fold[i].name, levels-1, '|', sizeof buf);
escputs(buf);
- if (fold[i].hasnewmsgs) wprintf("</B>");
- if (fold[i].selectable) {
- wprintf("</A>");
+ wprintf("</SPAN>");
+
+ wprintf("</a>', ");
+ if (has_subfolders) {
+ wprintf("new Array(closedGif, openGif)");
+ }
+ else if (fold[i].view == VIEW_ADDRESSBOOK) {
+ wprintf("'static/viewcontacts_16x.gif'");
+ }
+ else if (fold[i].view == VIEW_CALENDAR) {
+ wprintf("'static/calarea_16x.gif'");
+ }
+ else if (fold[i].view == VIEW_TASKS) {
+ wprintf("'static/taskmanag_16x.gif'");
+ }
+ else if (fold[i].view == VIEW_NOTES) {
+ wprintf("'static/storenotes_16x.gif'");
+ }
+ else if (fold[i].view == VIEW_MAILBOX) {
+ wprintf("'static/privatemess_16x.gif'");
}
else {
- wprintf("</i>");
+ wprintf("'static/chatrooms_16x.gif'");
}
- if (!strcasecmp(fold[i].name, "My Folders|Mail")) {
- wprintf(" (INBOX)");
+ wprintf(", '");
+ urlescputs(fold[i].name);
+ wprintf("');\n");
+
+ if (levels < 2) {
+ wprintf("rootNode.addChild(node%d);\n", i);
+ }
+ else {
+ wprintf("node%d.addChild(node%d);\n", parents[levels-1], i);
}
- wprintf("<BR>\n");
}
- do_template("endbox");
+
+ wprintf("container = document.getElementById('roomlist_div'); \n"
+ "showTree(''); \n"
+ "</script>\n"
+ );
+
+ free(parents);
+ /* END TREE MENU */
}
/*
static int columns = 3;
int boxes_per_column = 0;
int current_column = 0;
+ int nf;
- boxes_per_column = (num_floors / columns);
+ nf = num_floors;
+ while (nf % columns != 0) ++nf;
+ boxes_per_column = (nf / columns);
if (boxes_per_column < 1) boxes_per_column = 1;
/* Outer table (for columnization) */
- wprintf("<TABLE BORDER=0 WIDTH=100%% CELLPADDING=5>"
- "<TR><TD VALIGN=TOP>");
+ wprintf("<TABLE BORDER=0 WIDTH=96%% CELLPADDING=5>"
+ "<tr><td valign=top>");
levels = 0;
oldlevels = 0;
levels = num_tokens(fold[i].name, '|');
- if ((levels == 1) && (oldlevels == 2)) {
+ if ((levels == 1) && (oldlevels > 1)) {
/* End inner box */
do_template("endbox");
if ((num_boxes % boxes_per_column) == 0) {
++current_column;
if (current_column < columns) {
- wprintf("</TD><TD VALIGN=TOP>\n");
+ wprintf("</td><td valign=top>\n");
}
}
}
if (levels == 1) {
/* Begin inner box */
- extract(buf, fold[i].name, levels-1);
- stresc(boxtitle, buf, 1);
+ extract_token(buf, fold[i].name, levels-1, '|', sizeof buf);
+ stresc(boxtitle, buf, 1, 0);
svprintf("BOXTITLE", WCS_STRING, boxtitle);
do_template("beginbox");
else {
wprintf("<i>");
}
- if (fold[i].hasnewmsgs) wprintf("<B>");
- extract(buf, fold[i].name, levels-1);
+ if (fold[i].hasnewmsgs) {
+ wprintf("<SPAN CLASS=\"roomlist_new\">");
+ }
+ else {
+ wprintf("<SPAN CLASS=\"roomlist_old\">");
+ }
+ extract_token(buf, fold[i].name, levels-1, '|', sizeof buf);
escputs(buf);
- if (fold[i].hasnewmsgs) wprintf("</B>");
+ wprintf("</SPAN>");
if (fold[i].selectable) {
wprintf("</A>");
}
if (!strcasecmp(fold[i].name, "My Folders|Mail")) {
wprintf(" (INBOX)");
}
- wprintf("<BR>\n");
+ wprintf("<br />\n");
}
}
/* End the final inner box */
/* Then add floors */
serv_puts("LFLR");
- serv_gets(buf);
- if (buf[0]=='1') while(serv_gets(buf), strcmp(buf, "000")) {
+ serv_getln(buf, sizeof buf);
+ if (buf[0]=='1') while(serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
if (max_folders >= alloc_folders) {
alloc_folders = max_folders + 100;
fold = realloc(fold,
alloc_folders * sizeof(struct folder));
}
memset(&fold[max_folders], 0, sizeof(struct folder));
- extract(fold[max_folders].name, buf, 1);
+ extract_token(fold[max_folders].name, buf, 1, '|', sizeof fold[max_folders].name);
++max_folders;
++num_floors;
}
/* Now add rooms */
serv_puts("LKRA");
- serv_gets(buf);
- if (buf[0]=='1') while(serv_gets(buf), strcmp(buf, "000")) {
+ serv_getln(buf, sizeof buf);
+ if (buf[0]=='1') while(serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
if (max_folders >= alloc_folders) {
alloc_folders = max_folders + 100;
fold = realloc(fold,
alloc_folders * sizeof(struct folder));
}
memset(&fold[max_folders], 0, sizeof(struct folder));
- extract(fold[max_folders].room, buf, 0);
+ extract_token(fold[max_folders].room, buf, 0, '|', sizeof fold[max_folders].room);
ra_flags = extract_int(buf, 5);
flags = extract_int(buf, 1);
fold[max_folders].floor = extract_int(buf, 2);
if (flags & QR_MAILBOX) {
fold[max_folders].is_mailbox = 1;
}
+ fold[max_folders].view = extract_int(buf, 6);
room_to_folder(fold[max_folders].name,
fold[max_folders].room,
fold[max_folders].floor,
}
}
+/* test only hackish view
+ wprintf("<table><TR><TD>A Table</TD></TR></table>\n");
+ for (i=0; i<max_folders; ++i) {
+ escputs(fold[i].name);
+ wprintf("<br />\n");
+ }
+ */
+
if (!strcasecmp(viewpref, "folders")) {
do_folder_view(fold, max_folders, num_floors);
}
void knrooms() {
char listviewpref[SIZ];
- output_headers(3);
+ output_headers(1, 1, 2, 0, 0, 0, 0);
load_floorlist();
/* Determine whether the user is trying to change views */
if (bstr("view") != NULL) {
if (strlen(bstr("view")) > 0) {
- set_preference("roomlistview", bstr("view"));
+ set_preference("roomlistview", bstr("view"), 1);
}
}
- get_preference("roomlistview", listviewpref);
+ get_preference("roomlistview", listviewpref, sizeof listviewpref);
if ( (strcasecmp(listviewpref, "folders"))
&& (strcasecmp(listviewpref, "table")) ) {
}
/* title bar */
- wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#000077\"><TR><TD>"
+ wprintf("<div id=\"banner\">\n"
+ "<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>"
"<SPAN CLASS=\"titlebar\">"
);
if (!strcasecmp(listviewpref, "rooms")) {
}
wprintf("</SPAN></TD>\n");
-
/* offer the ability to switch views */
- wprintf("<TD><FORM NAME=\"roomlistomatic\">\n"
+ wprintf("<TD ALIGN=RIGHT><FORM NAME=\"roomlistomatic\">\n"
"<SELECT NAME=\"newview\" SIZE=\"1\" "
"OnChange=\"location.href=roomlistomatic.newview.options"
"[selectedIndex].value\">\n");
( !strcasecmp(listviewpref, "folders") ? "SELECTED" : "" )
);
- wprintf("<OPTION %s VALUE=\"/knrooms&view=table\">"
- "Classic table view"
- "</OPTION>\n",
- ( !strcasecmp(listviewpref, "table") ? "SELECTED" : "" )
- );
-
- wprintf("</SELECT></FORM></TD><TD>\n");
+ wprintf("</SELECT><br />");
offer_start_page();
- wprintf("</TD></TR></TABLE>\n");
+ wprintf("</FORM></TD></TR></TABLE>\n");
+ wprintf("</div>\n"
+ "</div>\n"
+ "<div id=\"content\">\n");
/* Display the room list in the user's preferred format */
- if (!strcasecmp(listviewpref, "table")) {
- tabular_room_list();
+ list_all_rooms_by_floor(listviewpref);
+}
+
+
+
+/*
+ * Set the message expire policy for this room and/or floor
+ */
+void set_room_policy(void) {
+ char buf[SIZ];
+
+ if (strcmp(bstr("sc"), "OK")) {
+ strcpy(WC->ImportantMessage,
+ "Cancelled. Changes were not saved.");
+ display_editroom();
+ return;
}
- else {
- list_all_rooms_by_floor(listviewpref);
+
+ serv_printf("SPEX room|%d|%d", atoi(bstr("roompolicy")), atoi(bstr("roomvalue")));
+ serv_getln(buf, sizeof buf);
+ strcpy(WC->ImportantMessage, &buf[4]);
+
+ if (WC->axlevel >= 6) {
+ strcat(WC->ImportantMessage, "<br />\n");
+ serv_printf("SPEX floor|%d|%d", atoi(bstr("floorpolicy")), atoi(bstr("floorvalue")));
+ serv_getln(buf, sizeof buf);
+ strcat(WC->ImportantMessage, &buf[4]);
}
+
+ display_editroom();
}