--- /dev/null
+#include <stdlib.h>
+#include <unistd.h>
+#include <stdio.h>
+#include <signal.h>
+#include <sys/types.h>
+#include <ctype.h>
+#include <string.h>
+#include "webcit.h"
+#include "child.h"
+
+/*
+ * Pack all session info into one easy-to-digest cookie. Healthy and delicious!
+ */
+void stuff_to_cookie(char *cookie, int session, char *user, char *pass, char *room) {
+ char buf[256];
+ int i;
+
+ sprintf(buf, "%d|%s|%s|%s", session, user, pass, room);
+ strcpy(cookie, "");
+
+ for (i=0; i<strlen(buf); ++i)
+ sprintf(&cookie[strlen(cookie)], "%02X", buf[i]);
+
+}
+
+
+/*
+ * Extract all that fun stuff out of the cookie.
+ */
+void cookie_to_stuff(char *cookie, int *session, char *user, char *pass, char *room) {
+ char buf[256];
+ int i;
+
+ for (i=0; i<strlen(cookie); i=i+2) {
+ sscanf(&cookie[i], "%02x", (unsigned int *)&buf[i/2]);
+ buf[(i/2)+1] = 0;
+ }
+
+ if (session != NULL) *session = extract_int(buf, 0);
+ if (user != NULL) extract(user, buf, 1);
+ if (pass != NULL) extract(pass, buf, 2);
+ if (room != NULL) extract(room, buf, 3);
+}
--- /dev/null
+/*
+ * Administrative screen for site-wide configuration
+ *
+ */
+
+#include <stdlib.h>
+#include <unistd.h>
+#include <stdio.h>
+#include <signal.h>
+#include <sys/types.h>
+#include <ctype.h>
+#include <string.h>
+#include "webcit.h"
+#include "child.h"
+
+
+void display_siteconfig(void) {
+ char buf[256];
+ int i = 0;
+
+ serv_printf("CONF get");
+ serv_gets(buf);
+ if (buf[0]!='1') {
+ display_error(&buf[4]);
+ return;
+ }
+
+ printf("HTTP/1.0 200 OK\n");
+ output_headers(1);
+
+ wprintf("<TABLE WIDTH=100% BORDER=0 BGCOLOR=007700><TR><TD>");
+ wprintf("<FONT SIZE=+1 COLOR=\"FFFFFF\"<B>Site configuration");
+ wprintf("</B></FONT></TD></TR></TABLE>\n");
+
+ wprintf("<FORM METHOD=\"POST\" ACTION=\"/siteconfig\">\n");
+ wprintf("<TABLE border=0>\n");
+
+ while (serv_gets(buf), strcmp(buf, "000")) {
+ ++i;
+ switch(i) {
+ case 1: wprintf("<TR><TD>Node name</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_nodename\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 2: wprintf("<TR><TD>Fully qualified domain name</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_fqdn\" MAXLENGTH=\"63\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 3: wprintf("<TR><TD>Human-readable node name</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_humannode\" MAXLENGTH=\"20\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 4: wprintf("<TR><TD>Landline telephone number</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_phonenum\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 5: wprintf("<TR><TD>Automatically grant room-aide status to users who create private rooms</TD><TD>");
+ wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_creataide\" VALUE=\"%s\">", (atoi(buf) ? "yes" : "no"));
+ wprintf("</TD></TR>\n");
+ break;
+ case 6: wprintf("<TR><TD>Server connection idle timeout (in seconds)</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_sleeping\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 7: wprintf("<TR><TD>Initial access level for new users</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_initax\" MAXLENGTH=\"1\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 8: wprintf("<TR><TD>Require registration for new users</TD><TD>");
+ wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_regiscall\" VALUE=\"%s\">", (atoi(buf) ? "yes" : "no"));
+ wprintf("</TD></TR>\n");
+ break;
+ case 9: wprintf("<TR><TD>Move problem user messages to twitroom</TD><TD>");
+ wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_twitdetect\" VALUE=\"%s\">", (atoi(buf) ? "yes" : "no"));
+ wprintf("</TD></TR>\n");
+ break;
+ case 10:wprintf("<TR><TD>Name of twitroom</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_twitroom\" MAXLENGTH=\"63\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 11:wprintf("<TR><TD>Paginator prompt</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_moreprompt\" MAXLENGTH=\"79\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 12:wprintf("<TR><TD>Restrict access to Internet mail</TD><TD>");
+ wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_restrict\" VALUE=\"%s\">", (atoi(buf) ? "yes" : "no"));
+ wprintf("</TD></TR>\n");
+ break;
+ case 13:wprintf("<TR><TD>Geographic location of this system</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_bbs_city\" MAXLENGTH=\"31\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 14:wprintf("<TR><TD>Name of system administrator</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_sysadm\" MAXLENGTH=\"25\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 15:wprintf("<TR><TD>Maximum concurrent sessions</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_maxsessions\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 16:wprintf("<TR><TD>Maximum concurrent sessions</TD><TD>");
+ wprintf("<INPUT TYPE=\"password\" NAME=\"c_net_password\" MAXLENGTH=\"19\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 17:wprintf("<TR><TD>Default user purge time (days)</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_userpurge\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 18:wprintf("<TR><TD>Default room purge time (days)</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_roompurge\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ case 19:wprintf("<TR><TD>Name of room to log pages</TD><TD>");
+ wprintf("<INPUT TYPE=\"text\" NAME=\"c_logpages\" MAXLENGTH=\"63\" VALUE=\"%s\">", buf);
+ wprintf("</TD></TR>\n");
+ break;
+ }
+ }
+
+ wprintf("</TABLE><CENTER>");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">\n");
+ wprintf("</CENTER></FORM></BODY></HTML>\n");
+ wDumpContent();
+}
+
+
+void siteconfig(void) {
+ char buf[256];
+
+ if (strcasecmp(bstr("sc"), "OK")) {
+ display_main_menu();
+ return;
+ }
+
+ serv_printf("SEXP ignatius t foobar|-");
+ serv_gets(buf);
+ if (buf[0]!='4') {
+ display_error(&buf[4]);
+ return;
+ }
+
+ serv_printf("%s", bstr("c_nodename"));
+ serv_printf("%s", bstr("c_fqdn"));
+ serv_printf("%s", bstr("c_humannode"));
+ serv_printf("%s", bstr("c_phonenum"));
+ serv_printf("%s", ( (!strcasecmp(bstr("c_creataide"), "yes") ? 1 : 0)));
+ serv_printf("%s", bstr("c_sleeping"));
+ serv_printf("%s", bstr("c_initax"));
+ serv_printf("%s", ( (!strcasecmp(bstr("c_regiscall"), "yes") ? 1 : 0)));
+ serv_printf("%s", ( (!strcasecmp(bstr("c_twitdetect"), "yes") ? 1 : 0)));
+ serv_printf("%s", bstr("c_twitroom"));
+ serv_printf("%s", bstr("c_moreprompt"));
+ serv_printf("%s", ( (!strcasecmp(bstr("c_restrict"), "yes") ? 1 : 0)));
+ serv_printf("%s", bstr("c_bbs_city"));
+ serv_printf("%s", bstr("c_sysadm"));
+ serv_printf("%s", bstr("c_maxsessions"));
+ serv_printf("%s", bstr("c_net_password"));
+ serv_printf("%s", bstr("c_userpurge"));
+ serv_printf("%s", bstr("c_roompurge"));
+ serv_printf("%s", bstr("c_logpages"));
+ serv_printf("000");
+ display_main_menu();
+}