4 * Display a list of all users currently logged on to the Citadel server.
12 * Display inner div of Wholist
14 void who_inner_div(void) {
15 char buf[SIZ], user[SIZ], room[SIZ], host[SIZ],
16 realroom[SIZ], realhost[SIZ];
22 wprintf("<table border=\"0\" cellspacing=\"0\" width=\"100%%\" bgcolor=\"#FFFFFF\">"
24 wprintf("<th colspan=\"3\"> </th>\n");
25 wprintf("<th>%s</th>\n", _("User name"));
26 wprintf("<th>%s</th>", _("Room"));
27 wprintf("<th>%s</th>\n</tr>\n", _("From host"));
30 serv_getln(buf, sizeof buf);
32 now = extract_long(&buf[4], 0);
39 serv_getln(buf, sizeof buf);
41 while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
42 sess = extract_int(buf, 0);
43 extract_token(user, buf, 1, '|', sizeof user);
44 extract_token(room, buf, 2, '|', sizeof room);
45 extract_token(host, buf, 3, '|', sizeof host);
46 extract_token(realroom, buf, 9, '|', sizeof realroom);
47 extract_token(realhost, buf, 10, '|', sizeof realhost);
48 last_activity = extract_long(buf, 5);
51 wprintf("<tr bgcolor=\"#%s\">",
52 (bg ? "DDDDDD" : "FFFFFF")
58 (sess != WC->ctdl_pid)) {
59 wprintf(" <a href=\"/terminate_session?which_session=%d", sess);
60 wprintf("\" onClick=\"return ConfirmKill();\">%s</a>", _("(kill)"));
62 if (sess == WC->ctdl_pid) {
63 wprintf(" <a href=\"/edit_me\">%s</a>", _("(edit)"));
67 /* (link to page this user) */
68 wprintf("<td><a href=\"/display_page?recp=");
71 "<img align=\"middle\" "
72 "src=\"/static/citadelchat_24x.gif\" "
74 " border=\"0\" /></a> ");
79 if ((now - last_activity) > 900L) {
81 "<img align=\"middle\" "
82 "src=\"/static/inactiveuser_24x.gif\" "
83 "alt=\"(idle)\" border=\"0\" />");
87 "<img align=\"middle\" "
88 "src=\"/static/activeuser_24x.gif\" "
89 "alt=\"(active)\" border=\"0\" />");
91 wprintf("</td>\n<td>");
95 /* username (link to user bio/photo page) */
96 wprintf("<a href=\"/showuser?who=");
103 wprintf("</td>\n\t<td>");
105 if (strlen(realroom) > 0) {
106 wprintf("<br /><i>");
110 wprintf("</td>\n\t<td>");
114 if (strlen(realhost) > 0) {
115 wprintf("<br /><i>");
119 wprintf("</td>\n</tr>");
127 * XML-encapsulated version of wholist inner html
129 void who_inner_html(void) {
130 output_headers(0, 0, 0, 0, 0, 0, 0);
132 wprintf("Content-type: text/xml;charset=UTF-8\r\n"
134 "Connection: close\r\n"
135 "Pragma: no-cache\r\n"
136 "Cache-Control: no-store\r\n",
140 wprintf("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
141 "<ajax-response>\r\n"
142 "<response type=\"element\" id=\"fix_scrollbar_bug\">\r\n"
147 wprintf("</response>\r\n"
148 "</ajax-response>\r\n"
163 output_headers(1, 1, 2, 0, 0, 0, 0);
165 wprintf("<script type=\"text/javascript\">\n"
166 "function ConfirmKill() { \n"
167 "return confirm('%s');\n"
169 "</script>\n", _("Do you really want to kill this session?")
172 wprintf("<div id=\"banner\">\n");
173 wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>");
174 wprintf("<IMG SRC=\"/static/usermanag_48x.gif\" ALT=\" \" "
177 /* "onLoad=\"javascript:bodyOnLoad()\" " */
178 wprintf("<SPAN CLASS=\"titlebar\"> ");
180 snprintf(title, sizeof title, _("Users currently on %s"), serv_info.serv_humannode);
183 wprintf("</SPAN></TD><TD ALIGN=RIGHT>");
185 wprintf("</TD></TR></TABLE>\n");
188 wprintf("<div id=\"content\">\n");
190 wprintf("<div style=\"display:inline\" id=\"fix_scrollbar_bug\">");
191 who_inner_div(); /* Actual data handled by another function */
194 wprintf("<div id=\"instructions\" align=center>");
195 wprintf(_("Click on a name to read user info. Click on %s "
196 "to send an instant message to that user."),
197 "<img align=\"middle\" src=\"/static/citadelchat_16x.gif\" alt=\"(p)\" border=\"0\">"
201 /* JavaScript to make the ajax refresh happen:
202 * 1. Register the request 'getWholist' which calls the WebCit action 'who_inner_html'
203 * 2. Register the 'fix_scrollbar_bug' div as one we're interested in ajaxifying
204 * 3. setInterval to make the ajax refresh happen every 30 seconds. The random number
205 * in the request is there to prevent the eternally moronic Internet Explorer from
206 * caching the XML even though it's been told not to.
209 "<script type=\"text/javascript\"> \n"
210 " ajaxEngine.registerRequest('getWholist', 'who_inner_html'); \n"
211 " ajaxEngine.registerAjaxElement('fix_scrollbar_bug'); \n"
212 " setInterval(\"ajaxEngine.sendRequest('getWholist', 'junk='+Math.random());\", 30000); \n"
220 void terminate_session(void)
224 serv_printf("TERM %s", bstr("which_session"));
225 serv_getln(buf, sizeof buf);
231 * Change your session info (fake roomname and hostname)
237 if (strlen(bstr("change_room_name_button")) > 0) {
238 serv_printf("RCHG %s", bstr("fake_roomname"));
239 serv_getln(buf, sizeof buf);
240 http_redirect("/who");
241 } else if (strlen(bstr("change_host_name_button")) > 0) {
242 serv_printf("HCHG %s", bstr("fake_hostname"));
243 serv_getln(buf, sizeof buf);
244 http_redirect("/who");
245 } else if (strlen(bstr("change_user_name_button")) > 0) {
246 serv_printf("UCHG %s", bstr("fake_username"));
247 serv_getln(buf, sizeof buf);
248 http_redirect("/who");
249 } else if (strlen(bstr("cancel_button")) > 0) {
250 http_redirect("/who");
252 output_headers(1, 1, 0, 0, 0, 0, 0);
254 wprintf("<div id=\"banner\">\n");
255 wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>");
256 wprintf("<SPAN CLASS=\"titlebar\">");
257 wprintf(_("Edit your session display"));
258 wprintf("</SPAN></TD></TR></TABLE>\n");
259 wprintf("</div>\n<div id=\"content\">\n");
261 wprintf(_("This screen allows you to change the way your "
262 "session appears in the 'Who is online' listing. "
263 "To turn off any 'fake' name you've previously "
264 "set, simply click the appropriate 'change' button "
265 "without typing anything in the corresponding box. "));
268 wprintf("<FORM METHOD=\"POST\" ACTION=\"/edit_me\">\n");
270 wprintf("<TABLE border=0 width=100%%>\n");
272 wprintf("<TR><TD><B>");
273 wprintf(_("Room name:"));
274 wprintf("</B></TD>\n<TD>");
275 wprintf("<INPUT TYPE=\"text\" NAME=\"fake_roomname\" MAXLENGTH=\"64\">\n");
276 wprintf("</TD>\n<TD ALIGN=center>");
277 wprintf("<INPUT TYPE=\"submit\" NAME=\"change_room_name_button\" VALUE=\"%s\">",
278 _("Change room name"));
279 wprintf("</TD>\n</TR>\n");
281 wprintf("<TR><TD><B>");
282 wprintf(_("Host name:"));
283 wprintf("</B></TD><TD>");
284 wprintf("<INPUT TYPE=\"text\" NAME=\"fake_hostname\" MAXLENGTH=\"64\">\n");
285 wprintf("</TD>\n<TD ALIGN=center>");
286 wprintf("<INPUT TYPE=\"submit\" NAME=\"change_host_name_button\" VALUE=\"%s\">",
287 _("Change host name"));
288 wprintf("</TD>\n</TR>\n");
291 wprintf("<TR><TD><B>");
292 wprintf(_("User name:"));
293 wprintf("</B></TD><TD>");
294 wprintf("<INPUT TYPE=\"text\" NAME=\"fake_username\" MAXLENGTH=\"64\">\n");
295 wprintf("</TD>\n<TD ALIGN=center>");
296 wprintf("<INPUT TYPE=\"submit\" NAME=\"change_user_name_button\" VALUE=\"%s\">",
297 _("Change user name"));
298 wprintf("</TD>\n</TR>\n");
300 wprintf("<TR><TD> </TD><TD> </TD><TD ALIGN=center>");
301 wprintf("<INPUT TYPE=\"submit\" NAME=\"cancel_button\" VALUE=\"%s\">",
303 wprintf("</TD></TR></TABLE>\n");
304 wprintf("</FORM></CENTER>\n");