-/* $Id$ */
+/*
+ * $Id$
+ *
+ * Display a list of all users currently logged on to the Citadel server.
+ */
#include <ctype.h>
#include <stdlib.h>
*/
void whobbs(void)
{
- char buf[SIZ], sess, user[SIZ], room[SIZ], host[SIZ],
+ char buf[SIZ], user[SIZ], room[SIZ], host[SIZ],
realroom[SIZ], realhost[SIZ];
+ int sess;
time_t last_activity;
time_t now;
+ int bg = 0;
- output_headers(7);
+ output_headers(1, 1, 2, 0, 1, 0, 0);
- wprintf("<SCRIPT LANGUAGE=\"JavaScript\">\n"
+ wprintf("<script type=\"text/javascript\">\n"
"function ConfirmKill() { \n"
"return confirm('Do you really want to kill this session?');\n"
"}\n"
- "</SCRIPT>\n"
+ "</script>\n"
);
- wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=007700><TR><TD>");
- wprintf("<IMG SRC=\"/static/users-icon.gif\" ALT=\" \" ALIGN=MIDDLE>");
- wprintf("<FONT SIZE=+1 COLOR=\"FFFFFF\"> <B>Users currently on ");
+ wprintf("<div id=\"banner\">\n");
+ wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>");
+ wprintf("<IMG SRC=\"/static/usermanag_48x.gif\" ALT=\" \" ALIGN=MIDDLE>");
+ wprintf("<SPAN CLASS=\"titlebar\"> Users currently on ");
escputs(serv_info.serv_humannode);
- wprintf("</B></FONT></TD><TD>");
+ wprintf("</SPAN></TD><TD ALIGN=RIGHT>");
offer_start_page();
wprintf("</TD></TR></TABLE>\n");
+ wprintf("</div>\n"
+ "<div id=\"content\">\n");
- wprintf("<CENTER><TABLE BORDER=1 WIDTH=100%%>\n<TR>\n");
- wprintf("<TH>Session ID</TH>\n");
+ wprintf("<div id=\"fix_scrollbar_bug\">"
+ "<table border=0 cellspacing=0 width=100%% bgcolor=\"#FFFFFF\">"
+ "<tr>\n");
+ wprintf("<TH COLSPAN=3> </TH>\n");
wprintf("<TH>User Name</TH>\n");
wprintf("<TH>Room</TH>");
wprintf("<TH>From host</TH>\n</TR>\n");
serv_puts("TIME");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '2') {
now = extract_long(&buf[4], 0);
}
}
serv_puts("RWHO");
- 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")) {
sess = extract_int(buf, 0);
- extract(user, buf, 1);
- extract(room, buf, 2);
- extract(host, buf, 3);
- extract(realroom, buf, 9);
- extract(realhost, buf, 10);
+ extract_token(user, buf, 1, '|', sizeof user);
+ extract_token(room, buf, 2, '|', sizeof room);
+ extract_token(host, buf, 3, '|', sizeof host);
+ extract_token(realroom, buf, 9, '|', sizeof realroom);
+ extract_token(realhost, buf, 10, '|', sizeof realhost);
last_activity = extract_long(buf, 5);
- wprintf("<TR>\n\t<TD ALIGN=center>%d", sess);
+ bg = 1 - bg;
+ wprintf("<TR BGCOLOR=\"#%s\">",
+ (bg ? "DDDDDD" : "FFFFFF")
+ );
+
+
+ wprintf("<td>");
if ((WC->is_aide) &&
- (sess != serv_info.serv_pid)) {
+ (sess != WC->ctdl_pid)) {
wprintf(" <A HREF=\"/terminate_session&which_session=%d&session_owner=", sess);
urlescputs(user);
wprintf("\" onClick=\"return ConfirmKill();\" "
- ">(kill)</A>");
+ ">[kill]</A>");
}
- if (sess == serv_info.serv_pid) {
+ if (sess == WC->ctdl_pid) {
wprintf(" <A HREF=\"/edit_me\" "
- ">(edit)</A>");
+ ">[edit]</A>");
}
- wprintf("</TD>\n\t<TD>");
+ wprintf("</TD>");
/* (link to page this user) */
- wprintf("<A HREF=\"/display_page&recp=");
+ wprintf("<TD><A HREF=\"/display_page?recp=");
urlescputs(user);
wprintf("\">"
"<IMG ALIGN=MIDDLE WIDTH=20 HEIGHT=15 "
"SRC=\"/static/page.gif\" "
"ALT=\"(p)\""
" BORDER=0></A> ");
+ wprintf("</TD>");
+
+ /* (idle flag) */
+ wprintf("<TD>");
+ if ((now - last_activity) > 900L) {
+ wprintf(" "
+ "<IMG ALIGN=MIDDLE "
+ "SRC=\"/static/idle.gif\" "
+ "ALT=\"[idle]\" BORDER=0>");
+ }
+ wprintf("</TD>\n\t<TD>");
+
/* username (link to user bio/photo page) */
escputs(user);
wprintf("</A>");
- if ((now - last_activity) > 900L) {
- wprintf(" "
- "<IMG ALIGN=MIDDLE "
- "SRC=\"/static/idle.gif\" "
- "ALT=\"[idle]\" BORDER=0>");
- }
-
/* room */
wprintf("</TD>\n\t<TD>");
escputs(room);
if (strlen(realroom) > 0) {
- wprintf("<BR><I>");
+ wprintf("<br /><I>");
escputs(realroom);
wprintf("</I>");
}
/* hostname */
escputs(host);
if (strlen(realhost) > 0) {
- wprintf("<BR><I>");
+ wprintf("<br /><I>");
escputs(realhost);
wprintf("</I>");
}
wprintf("</TD>\n</TR>");
}
}
- wprintf("</TABLE>\n"
+ wprintf("</TABLE></div>\n"
+ "<div align=center>"
"Click on a name to read user info. Click on "
"<IMG ALIGN=MIDDLE SRC=\"/static/page.gif\" ALT=\"(p)\" "
- "BORDER=0> to send "
- "a page (instant message) to that user.<BR></CENTER>\n");
+ "BORDER=0> to send an instant message to that user.</div>\n");
wDumpContent(1);
}
char buf[SIZ];
serv_printf("TERM %s", bstr("which_session"));
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
whobbs();
}
if (!strcasecmp(bstr("sc"), "Change room name")) {
serv_printf("RCHG %s", bstr("fake_roomname"));
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
http_redirect("/whobbs");
} else if (!strcasecmp(bstr("sc"), "Change host name")) {
serv_printf("HCHG %s", bstr("fake_hostname"));
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
http_redirect("/whobbs");
} else if (!strcasecmp(bstr("sc"), "Change user name")) {
serv_printf("UCHG %s", bstr("fake_username"));
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
http_redirect("/whobbs");
} else if (!strcasecmp(bstr("sc"), "Cancel")) {
http_redirect("/whobbs");
} else {
- output_headers(3);
+ output_headers(1, 1, 0, 0, 0, 0, 0);
- wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=000077><TR><TD>");
- wprintf("<FONT SIZE=+1 COLOR=\"FFFFFF\"><B>");
+ wprintf("<div id=\"banner\">\n");
+ wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>");
+ wprintf("<SPAN CLASS=\"titlebar\">");
wprintf("Edit your session display");
- wprintf("</B></FONT></TD></TR></TABLE>\n");
+ wprintf("</SPAN></TD></TR></TABLE>\n");
+ wprintf("</div>\n<div id=\"content\">\n");
+
wprintf("This screen allows you to change the way your\n");
wprintf("session appears in the 'Who is online' listing.\n");
wprintf("To turn off any 'fake' name you've previously\n");
wprintf("set, simply click the appropriate 'change' button\n");
wprintf("without typing anything in the corresponding box.\n");
- wprintf("<BR>\n");
+ wprintf("<br />\n");
wprintf("<FORM METHOD=\"POST\" ACTION=\"/edit_me\">\n");