-#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"
-
-
+/*
+ * $Id$
+ */
+/**
+ * \defgroup AccDisplay Display a list of all accounts on a Citadel system.
+ * \ingroup CitadelConfig
+ */
+/*@{*/
+#include "webcit.h"
+/**
+ * \brief structure to keep namelists in
+ */
struct namelist {
- struct namelist *next;
- char name[32];
+ struct namelist *next; /**< next item of the linked list */
+ char name[32]; /**< name of the userentry */
};
-/*
- * display the userlist
+/**
+ * \brief display the userlist
*/
void userlist(void)
{
- char buf[SIZ];
- char fl[SIZ];
- struct tm *tmbuf;
- long lc;
+ char buf[256];
+ char fl[256];
+ char title[256];
+ struct tm tmbuf;
+ time_t lc;
struct namelist *bio = NULL;
struct namelist *bptr;
int has_bio;
+ int bg = 0;
serv_puts("LBIO");
- 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")) {
bptr = (struct namelist *) malloc(sizeof(struct namelist));
bptr->next = bio;
strcpy(bptr->name, buf);
bio = bptr;
}
- output_headers(3);
+ output_headers(1, 1, 2, 0, 0, 0);
+ wprintf("<div id=\"banner\">\n");
+ wprintf("<h1>");
+ snprintf(title, sizeof title, _("User list for %s"), serv_info.serv_humannode);
+ escputs(title);
+ wprintf("</h1>");
+ wprintf("</div>");
+
+ wprintf("<div id=\"content\" class=\"service\">\n");
serv_puts("LIST");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] != '1') {
- wprintf("<EM>%s</EM><BR>\n", &buf[4]);
+ wprintf("<em>%s</em><br />\n", &buf[4]);
goto DONE;
}
- svprintf("BOXTITLE", WCS_STRING, "User list for %s",
- serv_info.serv_humannode);
-
- do_template("beginbox");
- wprintf("<CENTER>");
- wprintf("<TABLE border>");
- wprintf("<TR><TH>User Name</TH><TH>Number</TH><TH>Access Level</TH>");
- wprintf("<TH>Last Call</TH><TH>Total Calls</TH><TH>Total Posts</TH></TR>\n");
-
- while (serv_gets(buf), strcmp(buf, "000")) {
- extract(fl, buf, 0);
+ wprintf("<div class=\"fix_scrollbar_bug\">"
+ "<table class=\"userlist_background\"><tr><td>\n");
+ wprintf("<tr><th>%s</th><th>%s</th><th>%s</th>"
+ "<th>%s</th><th>%s</th><th>%s</th></tr>",
+ _("User Name"),
+ _("Number"),
+ _("Access Level"),
+ _("Last Login"),
+ _("Total Logins"),
+ _("Total Posts"));
+
+ while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ extract_token(fl, buf, 0, '|', sizeof fl);
has_bio = 0;
for (bptr = bio; bptr != NULL; bptr = bptr->next) {
if (!strcasecmp(fl, bptr->name))
has_bio = 1;
}
- wprintf("<TR><TD>");
+ bg = 1 - bg;
+ wprintf("<tr bgcolor=\"#%s\"><td>",
+ (bg ? "DDDDDD" : "FFFFFF")
+ );
if (has_bio) {
- wprintf("<A HREF=\"/showuser&who=");
+ wprintf("<a href=\"showuser&who=");
urlescputs(fl);
wprintf("\">");
escputs(fl);
} else {
escputs(fl);
}
- wprintf("</TD><TD>%ld</TD><TD>%d</TD><TD>",
+ wprintf("</td><td>%ld</td><td>%d</td><td>",
extract_long(buf, 2),
extract_int(buf, 1));
lc = extract_long(buf, 3);
- tmbuf = (struct tm *) localtime(&lc);
+ localtime_r(&lc, &tmbuf);
wprintf("%02d/%02d/%04d ",
- (tmbuf->tm_mon + 1),
- tmbuf->tm_mday,
- (tmbuf->tm_year + 1900));
+ (tmbuf.tm_mon + 1),
+ tmbuf.tm_mday,
+ (tmbuf.tm_year + 1900));
- wprintf("</TD><TD>%ld</TD><TD>%5ld</TD></TR>\n",
+ wprintf("</td><td>%ld</td><td>%5ld</td></tr>\n",
extract_long(buf, 4), extract_long(buf, 5));
}
- wprintf("</TABLE>");
- wprintf("</CENTER>\n");
- do_template("endbox");
+ wprintf("</table></div>\n");
DONE: wDumpContent(1);
}
-/*
- * Display (non confidential) information about a particular user
+/**
+ * \brief Display (non confidential) information about a particular user
*/
void showuser(void)
{
- char who[SIZ];
- char buf[SIZ];
+ char who[256];
+ char buf[256];
int have_pic;
- output_headers(3);
+ strcpy(who, bstr("who"));
- svprintf("BOXTITLE", WCS_STRING, "User profile");
- do_template("beginbox");
+ output_headers(1, 1, 2, 0, 0, 0);
+ wprintf("<div id=\"banner\">\n");
+ wprintf("<img src=\"static/usermanag_48x.gif\">");
+ wprintf("<h1>");
+ wprintf(_("User profile"));
+ wprintf("</h1>");
+ wprintf("</div>");
+
+ wprintf("<div id=\"content\" class=\"service\">\n");
+
+ wprintf("<div class=\"fix_scrollbar_bug\">"
+ "<table class=\"userlist_background\"><tr><td>\n");
- strcpy(who, bstr("who"));
serv_printf("OIMG _userpic_|%s", who);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '2') {
have_pic = 1;
serv_puts("CLOS");
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
} else {
have_pic = 0;
}
- wprintf("<CENTER><TABLE><TR><TD>");
+ wprintf("<center><table><tr><td>");
if (have_pic == 1) {
- wprintf("<IMG SRC=\"/image&name=_userpic_&parm=");
+ wprintf("<img src=\"image&name=_userpic_&parm=");
urlescputs(who);
wprintf("\">");
}
- wprintf("</TD><TD><H1>%s</H1></TD></TR></TABLE></CENTER>\n", who);
+ wprintf("</td><td><h1>");
+ escputs(who);
+ wprintf("</h1></td></tr></table></center>\n");
serv_printf("RBIO %s", who);
- serv_gets(buf);
+ serv_getln(buf, sizeof buf);
if (buf[0] == '1') {
- fmout(NULL);
+ fmout("JUSTIFY");
}
- wprintf("<BR><A HREF=\"/display_page&recp=");
+ wprintf("<br /><a href=\"display_page?recp=");
urlescputs(who);
wprintf("\">"
- "<IMG SRC=\"/static/page.gif\" ALIGN=MIDDLE BORDER=0>"
- " "
- "Click here to page this user (send an instant message)"
- "</A>\n");
+ "<img src=\"static/citadelchat_24x.gif\" "
+ "align=middle border=0> ");
+ snprintf(buf, sizeof buf, _("Click here to send an instant message to %s"), who);
+ escputs(buf);
+ wprintf("</a>\n");
- do_template("endbox");
+ wprintf("</td></tr></table></div>\n");
wDumpContent(1);
}
+
+
+/*@}*/