]> code.citadel.org Git - citadel.git/blobdiff - webcit/who.c
* vcard_edit.c webcit.c webserver.c who.c : i18n
[citadel.git] / webcit / who.c
index d6fd0512ac6899f574636fca91575acd0bc347fe..0a8cc142039b71b015dc2f363d830b5026a7019e 100644 (file)
@@ -4,25 +4,6 @@
  * Display a list of all users currently logged on to the Citadel server.
  */
 
-#include <ctype.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <stdio.h>
-#include <fcntl.h>
-#include <signal.h>
-#include <sys/types.h>
-#include <sys/wait.h>
-#include <sys/socket.h>
-#include <sys/time.h>
-#include <limits.h>
-#include <netinet/in.h>
-#include <netdb.h>
-#include <string.h>
-#include <pwd.h>
-#include <errno.h>
-#include <stdarg.h>
-#include <pthread.h>
-#include <signal.h>
 #include "webcit.h"
 
 
@@ -38,12 +19,12 @@ void who_inner_div(void) {
        time_t now;
        int bg = 0;
 
-       wprintf("<table border=0 cellspacing=0 width=100%% bgcolor=\"#FFFFFF\">"
+       wprintf("<table border=\"0\" cellspacing=\"0\" width=\"100%%\" bgcolor=\"#FFFFFF\">"
                "<tr>\n");
-       wprintf("<TH COLSPAN=3>&nbsp;</TH>\n");
-       wprintf("<TH>User Name</TH>\n");
-       wprintf("<TH>Room</TH>");
-       wprintf("<TH>From host</TH>\n</TR>\n");
+       wprintf("<th colspan=\"3\"> </th>\n");
+       wprintf("<th>%s</th>\n", _("User name"));
+       wprintf("<th>%s</th>", _("Room"));
+       wprintf("<th>%s</th>\n</tr>\n", _("From host"));
 
        serv_puts("TIME");
        serv_getln(buf, sizeof buf);
@@ -67,7 +48,7 @@ void who_inner_div(void) {
                        last_activity = extract_long(buf, 5);
 
                        bg = 1 - bg;
-                       wprintf("<TR BGCOLOR=\"#%s\">",
+                       wprintf("<tr bgcolor=\"#%s\">",
                                (bg ? "DDDDDD" : "FFFFFF")
                        );
 
@@ -75,96 +56,130 @@ void who_inner_div(void) {
                        wprintf("<td>");
                        if ((WC->is_aide) &&
                            (sess != WC->ctdl_pid)) {
-                               wprintf(" <A HREF=\"/terminate_session&which_session=%d&session_owner=", sess);
-                               urlescputs(user);
-                               wprintf("\" onClick=\"return ConfirmKill();\" "
-                               ">[kill]</A>");
+                               wprintf(" <a href=\"/terminate_session?which_session=%d", sess);
+                               wprintf("\" onClick=\"return ConfirmKill();\">%s</a>", _("(kill)"));
                        }
                        if (sess == WC->ctdl_pid) {
-                               wprintf(" <A HREF=\"/edit_me\" "
-                                       ">[edit]</A>");
+                               wprintf(" <a href=\"/edit_me\">%s</a>", _("(edit)"));
                        }
-                       wprintf("</TD>");
+                       wprintf("</td>");
 
                        /* (link to page this user) */
-                       wprintf("<TD><A HREF=\"/display_page?recp=");
+                       wprintf("<td><a href=\"/display_page?recp=");
                        urlescputs(user);
                        wprintf("\">"
-                               "<IMG ALIGN=MIDDLE "
-                               "SRC=\"/static/citadelchat_24x.gif\" "
-                               "ALT=\"(p)\""
-                               " BORDER=0></A>&nbsp;");
-                       wprintf("</TD>");
+                               "<img align=\"middle\" "
+                               "src=\"/static/citadelchat_24x.gif\" "
+                               "alt=\"(p)\""
+                               " border=\"0\" /></a> ");
+                       wprintf("</td>");
 
                        /* (idle flag) */
-                       wprintf("<TD>");
+                       wprintf("<td>");
                        if ((now - last_activity) > 900L) {
-                               wprintf("&nbsp;"
-                                       "<IMG ALIGN=MIDDLE "
-                                       "SRC=\"/static/inactiveuser_24x.gif\" "
-                                       "ALT=\"[idle]\" BORDER=0>");
+                               wprintf(" "
+                                       "<img align=\"middle\" "
+                                       "src=\"/static/inactiveuser_24x.gif\" "
+                                       "alt=\"(idle)\" border=\"0\" />");
                        }
                        else {
-                               wprintf("&nbsp;"
-                                       "<IMG ALIGN=MIDDLE "
-                                       "SRC=\"/static/activeuser_24x.gif\" "
-                                       "ALT=\"[active]\" BORDER=0>");
+                               wprintf(" "
+                                       "<img align=\"middle\" "
+                                       "src=\"/static/activeuser_24x.gif\" "
+                                       "alt=\"(active)\" border=\"0\" />");
                        }
-                       wprintf("</TD>\n\t<TD>");
+                       wprintf("</td>\n<td>");
 
 
 
                        /* username (link to user bio/photo page) */
-                       wprintf("<A HREF=\"/showuser&who=");
+                       wprintf("<a href=\"/showuser?who=");
                        urlescputs(user);
                        wprintf("\">");
                        escputs(user);
-                       wprintf("</A>");
+                       wprintf("</a>");
 
                        /* room */
-                       wprintf("</TD>\n\t<TD>");
+                       wprintf("</td>\n\t<td>");
                        escputs(room);
                        if (strlen(realroom) > 0) {
-                               wprintf("<br /><I>");
+                               wprintf("<br /><i>");
                                escputs(realroom);
-                               wprintf("</I>");
+                               wprintf("</i>");
                        }
-                       wprintf("</TD>\n\t<TD>");
+                       wprintf("</td>\n\t<td>");
 
                        /* hostname */
                        escputs(host);
                        if (strlen(realhost) > 0) {
-                               wprintf("<br /><I>");
+                               wprintf("<br /><i>");
                                escputs(realhost);
-                               wprintf("</I>");
+                               wprintf("</i>");
                        }
-                       wprintf("</TD>\n</TR>");
+                       wprintf("</td>\n</tr>");
                }
        }
-       wprintf("</TABLE>");
+       wprintf("</table>");
 }
 
 
+/*
+ * XML-encapsulated version of wholist inner html
+ */
+void who_inner_html(void) {
+       output_headers(0, 0, 0, 0, 0, 0, 0);
+
+       wprintf("Content-type: text/xml;charset=UTF-8\r\n"
+               "Server: %s\r\n"
+               "Connection: close\r\n"
+               "Pragma: no-cache\r\n"
+               "Cache-Control: no-store\r\n",
+               SERVER);
+       begin_burst();
+
+       wprintf("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
+               "<ajax-response>\r\n"
+               "<response type=\"element\" id=\"fix_scrollbar_bug\">\r\n"
+       );
+
+       who_inner_div();
+
+       wprintf("</response>\r\n"
+               "</ajax-response>\r\n"
+               "\r\n"
+       );
+
+       wDumpContent(0);
+}
+
 
 /*
  * who is on?
  */
 void who(void)
 {
-       output_headers(1, 1, 2, 0, 1, 0, 0);
+       char title[256];
+
+       output_headers(1, 1, 2, 0, 0, 0, 0);
 
        wprintf("<script type=\"text/javascript\">\n"
                "function ConfirmKill() { \n"
-               "return confirm('Do you really want to kill this session?');\n"
+               "return confirm('%s');\n"
                "}\n"
-               "</script>\n"
+               "</script>\n", _("Do you really want to kill this session?")
        );
 
        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\">&nbsp;Users currently on ");
-       escputs(serv_info.serv_humannode);
+       wprintf("<IMG SRC=\"/static/usermanag_48x.gif\" ALT=\" \" "
+               "ALIGN=MIDDLE "
+               ">");
+               /* "onLoad=\"javascript:bodyOnLoad()\" " */
+       wprintf("<SPAN CLASS=\"titlebar\"> ");
+
+       snprintf(title, sizeof title, _("Users currently on %s"), serv_info.serv_humannode);
+       escputs(title);
+
        wprintf("</SPAN></TD><TD ALIGN=RIGHT>");
        offer_start_page();
        wprintf("</TD></TR></TABLE>\n");
@@ -172,14 +187,32 @@ void who(void)
 
        wprintf("<div id=\"content\">\n");
 
-       wprintf("<div id=\"fix_scrollbar_bug\">");
+       wprintf("<div style=\"display:inline\" id=\"fix_scrollbar_bug\">");
        who_inner_div();        /* Actual data handled by another function */
        wprintf("</div>\n");
 
-       wprintf("<div align=center>"
-               "Click on a name to read user info.  Click on "
-               "<IMG ALIGN=MIDDLE SRC=\"/static/citadelchat_16x.gif\" ALT=\"(p)\" "
-               "BORDER=0> to send an instant message to that user.</div>\n");
+       wprintf("<div id=\"instructions\" align=center>");
+       wprintf(_("Click on a name to read user info.  Click on %s "
+               "to send an instant message to that user."),
+               "<img align=\"middle\" src=\"/static/citadelchat_16x.gif\" alt=\"(p)\" border=\"0\">"
+       );
+       wprintf("</div>\n");
+
+       /* JavaScript to make the ajax refresh happen:
+        * 1. Register the request 'getWholist' which calls the WebCit action 'who_inner_html'
+        * 2. Register the 'fix_scrollbar_bug' div as one we're interested in ajaxifying
+        * 3. setInterval to make the ajax refresh happen every 30 seconds.  The random number
+        *    in the request is there to prevent the eternally moronic Internet Explorer from
+        *    caching the XML even though it's been told not to.
+        */
+       wprintf(
+               "<script type=\"text/javascript\">                                                              \n"
+               "       ajaxEngine.registerRequest('getWholist', 'who_inner_html');                             \n"
+               "       ajaxEngine.registerAjaxElement('fix_scrollbar_bug');                                    \n"
+               "       setInterval(\"ajaxEngine.sendRequest('getWholist', 'junk='+Math.random());\", 30000);   \n"
+               "</script>                                                                                      \n"
+       );
+
        wDumpContent(1);
 }
 
@@ -201,65 +234,73 @@ void edit_me(void)
 {
        char buf[SIZ];
 
-       if (!strcasecmp(bstr("sc"), "Change room name")) {
+       if (strlen(bstr("change_room_name_button")) > 0) {
                serv_printf("RCHG %s", bstr("fake_roomname"));
                serv_getln(buf, sizeof buf);
                http_redirect("/who");
-       } else if (!strcasecmp(bstr("sc"), "Change host name")) {
+       } else if (strlen(bstr("change_host_name_button")) > 0) {
                serv_printf("HCHG %s", bstr("fake_hostname"));
                serv_getln(buf, sizeof buf);
                http_redirect("/who");
-       } else if (!strcasecmp(bstr("sc"), "Change user name")) {
+       } else if (strlen(bstr("change_user_name_button")) > 0) {
                serv_printf("UCHG %s", bstr("fake_username"));
                serv_getln(buf, sizeof buf);
                http_redirect("/who");
-       } else if (!strcasecmp(bstr("sc"), "Cancel")) {
+       } else if (strlen(bstr("cancel_button")) > 0) {
                http_redirect("/who");
        } else {
-
                output_headers(1, 1, 0, 0, 0, 0, 0);
 
                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(_("Edit your session display"));
                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(_("This screen allows you to change the way your "
+                       "session appears in the 'Who is online' listing. "
+                       "To turn off any 'fake' name you've previously "
+                       "set, simply click the appropriate 'change' button "
+                       "without typing anything in the corresponding box. "));
                wprintf("<br />\n");
 
                wprintf("<FORM METHOD=\"POST\" ACTION=\"/edit_me\">\n");
 
                wprintf("<TABLE border=0 width=100%%>\n");
 
-               wprintf("<TR><TD><B>Room name:</B></TD>\n<TD>");
+               wprintf("<TR><TD><B>");
+               wprintf(_("Room name:"));
+               wprintf("</B></TD>\n<TD>");
                wprintf("<INPUT TYPE=\"text\" NAME=\"fake_roomname\" MAXLENGTH=\"64\">\n");
                wprintf("</TD>\n<TD ALIGN=center>");
-               wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Change room name\">");
+               wprintf("<INPUT TYPE=\"submit\" NAME=\"change_room_name_button\" VALUE=\"%s\">",
+                       _("Change room name"));
                wprintf("</TD>\n</TR>\n");
 
-               wprintf("<TR><TD><B>Host name:</B></TD><TD>");
+               wprintf("<TR><TD><B>");
+               wprintf(_("Host name:"));
+               wprintf("</B></TD><TD>");
                wprintf("<INPUT TYPE=\"text\" NAME=\"fake_hostname\" MAXLENGTH=\"64\">\n");
                wprintf("</TD>\n<TD ALIGN=center>");
-               wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Change host name\">");
+               wprintf("<INPUT TYPE=\"submit\" NAME=\"change_host_name_button\" VALUE=\"%s\">",
+                       _("Change host name"));
                wprintf("</TD>\n</TR>\n");
 
                if (WC->is_aide) {
-                       wprintf("<TR><TD><B>User name:</B></TD><TD>");
+                       wprintf("<TR><TD><B>");
+                       wprintf(_("User name:"));
+                       wprintf("</B></TD><TD>");
                        wprintf("<INPUT TYPE=\"text\" NAME=\"fake_username\" MAXLENGTH=\"64\">\n");
                        wprintf("</TD>\n<TD ALIGN=center>");
-                       wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Change user name\">");
+                       wprintf("<INPUT TYPE=\"submit\" NAME=\"change_user_name_button\" VALUE=\"%s\">",
+                               _("Change user name"));
                        wprintf("</TD>\n</TR>\n");
                }
-               wprintf("<TR><TD>&nbsp;</TD><TD>&nbsp;</TD><TD ALIGN=center>");
-               wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
+               wprintf("<TR><TD> </TD><TD> </TD><TD ALIGN=center>");
+               wprintf("<INPUT TYPE=\"submit\" NAME=\"cancel_button\" VALUE=\"%s\">",
+                       _("Cancel"));
                wprintf("</TD></TR></TABLE>\n");
-
                wprintf("</FORM></CENTER>\n");
                wDumpContent(1);
        }