lotsa stuff
authorArt Cancro <ajc@citadel.org>
Sun, 10 Jan 1999 01:41:25 +0000 (01:41 +0000)
committerArt Cancro <ajc@citadel.org>
Sun, 10 Jan 1999 01:41:25 +0000 (01:41 +0000)
webcit/cookie_conversion.c [new file with mode: 0644]
webcit/siteconfig.c [new file with mode: 0644]

diff --git a/webcit/cookie_conversion.c b/webcit/cookie_conversion.c
new file mode 100644 (file)
index 0000000..2f11c21
--- /dev/null
@@ -0,0 +1,43 @@
+#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);
+}
diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c
new file mode 100644 (file)
index 0000000..6976f5b
--- /dev/null
@@ -0,0 +1,164 @@
+/*
+ * 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();
+}