* add a Display name to our handlers; this will be used by DAV handlers.
[citadel.git] / webcit / mainmenu.c
index 4c1943817d985f9999d27fd803d5ed094932dd07..98e58f59c05d08d7270492e5598de824e1304187 100644 (file)
@@ -11,146 +11,8 @@ void display_main_menu(void)
 {
        begin_burst();
        output_headers(1, 0, 0, 0, 1, 0);
-       DoTemplate(HKEY("display_main_menu"), NULL, NULL, 0);
+       DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx);
        end_burst();
-
-/*
-       char buf[SIZ];
-       output_headers(1, 1, 1, 0, 0, 0);
-
-       wprintf("<div class=\"fix_scrollbar_bug\">"
-               "<table width=\"100%%\" cellspacing=\"10\" cellpadding=\"0\">"
-               "<tr><td colspan=\"2\" class=\"advanced\">\n");
-
-       svput("BOXTITLE", WCS_STRING, _("Basic commands"));
-       do_template("beginbox", NULL);
-
-       / * start of first column * /
-       wprintf("<ul class=\"adminitems col1\">");
-
-       wprintf("<li><a href=\"knrooms\">");
-       wprintf(_("List known rooms"));
-       wprintf("</a><span>");
-       wprintf(_("Where can I go from here?"));
-       wprintf("</span></li>\n");
-
-       wprintf("<li><a href=\"gotonext\">");
-       wprintf(_("Goto next room"));
-       wprintf("</a><span>");
-       wprintf(_("...with <em>unread</em> messages"));
-       wprintf("</span></li>\n");
-
-       wprintf("<li><a href=\"skip\">");
-       wprintf(_("Skip to next room"));
-       wprintf("</a><span>");
-       wprintf(_("(come back here later)"));
-       wprintf("</span></li>\n");
-
-       if ((!IsEmptyStr(WC->ugname)) && (strcasecmp(WC->ugname, WC->wc_roomname))) {
-               wprintf("<li><a href=\"ungoto\">");
-               wprintf(_("Ungoto"));
-               wprintf("</a><span>");
-               wprintf(_("(oops! Back to %s)"), WC->ugname);
-               wprintf("</span></li>\n");
-       }
-
-       wprintf("</ul>\n");
-
-       / * start of second column * /
-
-       wprintf("<ul class=\"adminitems col2\">");
-
-       wprintf("<li><a href=\"readnew\">");
-       wprintf(_("Read new messages"));
-       wprintf("</a><span>");
-       wprintf(_("...in this room"));
-       wprintf("</span></li>\n");
-
-       wprintf("<li><a href=\"readfwd\">");
-       wprintf(_("Read all messages"));
-       wprintf("</a><span>");
-       wprintf(_("...old <EM>and</EM> new"));
-       wprintf("</span></li>\n");
-
-       wprintf("<li><a href=\"display_enter\">");
-       wprintf(_("Enter a message"));
-       wprintf("</a><span>");
-       wprintf(_("(post in this room)"));
-       wprintf("</span></li>\n");
-
-       if (WC->room_flags & QR_VISDIR) {
-               wprintf("<li><a href=\"display_room_directory\">");
-               wprintf(_("File library"));
-               wprintf("</a><span>");
-               wprintf(_("(List files available for download)"));
-               wprintf("</span></li>\n");
-       }
-
-       wprintf("</ul>\n");
-
-       / * start of third column * /
-
-       wprintf("<ul class=\"adminitems lastcol\">");
-
-       wprintf("<li><a href=\"summary\">");
-       wprintf(_("Summary page"));
-       wprintf("</a><span>");
-       wprintf(_("Summary of my account"));
-       wprintf("</span></li>\n");
-
-       wprintf("<li><a href=\"userlist\">\n");
-       wprintf(_("User list"));
-       wprintf("</a><span>");
-       wprintf(_("(all registered users)"));
-       wprintf("</span></li>\n");
-
-       wprintf("<li><a href=\"termquit\" TARGET=\"_top\">");
-       wprintf(_("Log off"));
-       wprintf("</a><span>");
-       wprintf(_("Bye!"));
-       wprintf("</span></li>\n");
-
-       wprintf("</ul>\n");
-
-       wprintf("&nbsp;");
-
-       do_template("endbox", NULL);
-
-       wprintf("</td></tr>"
-               "<tr valign=top><td width=50%%>");
-
-       print_menu_box(_("Your info"), "adminitems", 8,
-                      "display_preferences", _("Change your preferences and settings"),
-                      "display_reg", _("Update your contact information"),
-                      "display_changepw", _("Change your password"),
-                      "display_editbio", _("Enter your 'bio'"),
-                      "display_editpic", _("Edit your online photo"), 
-                      "display_sieve", _("View/edit server-side mail filters"),
-                      "display_pushemail", _("Edit your push email settings"),
-                      "display_openids", _("Manage your OpenIDs")
-       );
-
-       wprintf("</td><td width=50%%>");
-
-       snprintf(buf, SIZ, _("Zap (forget) this room (%s)"), WC->wc_roomname);
-
-       if ( (WC->axlevel >= 6) || (WC->is_room_aide) || (WC->is_mailbox) )
-               print_menu_box(_("Advanced room commands"),"adminitems", 5,
-                              "display_editroom", _("Edit or delete this room"),
-                              "display_private", _("Go to a 'hidden' room"),
-                              "display_entroom", _("Create a new room"),
-                              "display_zap",buf,
-                              "zapped_list",_("List all forgotten rooms"));
-       else
-               print_menu_box(_("Advanced room commands"),"adminitems", 4,
-                              "display_private", _("Go to a 'hidden' room"),
-                              "display_entroom", _("Create a new room"),
-                              "display_zap",buf,
-                              "zapped_list",_("List all forgotten rooms"));
-
-       wprintf("</td></tr></table></div>");
-       wDumpContent(2);
-*/
 }
 
 
@@ -161,51 +23,8 @@ void display_aide_menu(void)
 {
        begin_burst();
        output_headers(1, 0, 0, 0, 1, 0);
-       DoTemplate(HKEY("display_aide_menu"), NULL, NULL, 0);
+       DoTemplate(HKEY("display_aide_menu"), NULL, &NoCtx);
        end_burst();
-/*
-       output_headers(1, 1, 2, 0, 0, 0);
-
-        wprintf("<div id=\"banner\">\n");
-        wprintf("<h1>");
-       wprintf(_("System Administration Menu"));
-        wprintf("</h1>");
-        wprintf("</div>\n");
-
-       wprintf("<div id=\"content\" class=\"service\">");
-
-       wprintf("<div class=\"fix_scrollbar_bug\">"
-               "<table> "
-               "<tr valign=top><td width=50%% valign=\"top\">");
-
-       print_menu_box(_("Global Configuration"), "adminitems", 4,
-                      "display_siteconfig", _("Edit site-wide configuration"), 
-                      "display_inetconf",_("Domain names and Internet mail configuration"),
-                      "display_netconf", _("Configure replication with other Citadel servers"), 
-                      "display_smtpqueue", _("View the outbound SMTP queue"));
-       
-       wprintf("</td><td width=50%% valign=\"top\">");
-
-       print_menu_box(_("User account management"), "adminitems", 2, 
-                      "select_user_to_edit", _("Add, change, delete user accounts"),
-                      "validate", _("Validate new users"));
-
-       wprintf("</td></tr><tr><td width=50%% valign=\"top\">");
-
-
-       print_menu_box(_("Shutdown Citadel"), "adminitems", 3, 
-                      "server_shutdown?when=now", _("Restart Now"),
-                      "server_shutdown?when=page", _("Restart after paging users"),
-                      "server_shutdown?when=idle", _("Restart when all users are idle"));
-
-       wprintf("</td><td width=50%% valign=\"top\">");
-
-       print_menu_box(_("Rooms and Floors"), "adminitems", 1, 
-                      "display_floorconfig", _("Add, change, or delete floors"));
-
-       wprintf("</td></tr></table></div>");
-       wDumpContent(2);
-*/
 }
 
 
@@ -243,7 +62,7 @@ void display_generic(void)
        wprintf("<br /><textarea name=\"g_input\" rows=10 cols=80 width=80></textarea><br />\n");
 
        wprintf("<font size=-2>");
-       wprintf(_("Detected host header is %s://%s"), (is_https ? "https" : "http"), WC->http_host);
+       wprintf(_("Detected host header is %s://%s"), (is_https ? "https" : "http"), ChrPtr(WC->Hdr->HR.http_host));
        wprintf("</font>\n");
        wprintf("<input type=\"submit\" name=\"sc_button\" value=\"%s\">", _("Send command"));
        wprintf("&nbsp;");
@@ -259,8 +78,10 @@ void display_generic(void)
  */
 void do_generic(void)
 {
-       char buf[SIZ];
-       char gcontent[SIZ];
+
+       wcsession *WCC = WC;
+       int Done = 0;
+       StrBuf *Buf;
        char *junk;
        size_t len;
 
@@ -270,50 +91,59 @@ void do_generic(void)
        }
 
        output_headers(1, 1, 0, 0, 0, 0);
-
-       serv_printf("%s", bstr("g_cmd"));
-       serv_getln(buf, sizeof buf);
-
+       Buf = NewStrBuf();
+       serv_puts(bstr("g_cmd"));
+       StrBuf_ServGetln(Buf);
        svput("BOXTITLE", WCS_STRING, _("Server command results"));
-       do_template("beginbox", NULL);
+       do_template("beginboxx", NULL);
 
        wprintf("<table border=0><tr><td>Command:</td><td><tt>");
-       escputs(bstr("g_cmd"));
+       StrEscAppend(WCC->WBuf, sbstr("g_cmd"), NULL, 0, 0);
        wprintf("</tt></td></tr><tr><td>Result:</td><td><tt>");
-       escputs(buf);
+       StrEscAppend(WCC->WBuf, Buf, NULL, 0, 0);
+       StrBufAppendBufPlain(WCC->WBuf, HKEY("<br>\n"), 0);
        wprintf("</tt></td></tr></table><br />\n");
-
-       if (buf[0] == '8') {
-               serv_printf("\n\n000");
-       }
-       if ((buf[0] == '1') || (buf[0] == '8')) {
-               while (serv_getln(gcontent, sizeof gcontent), strcmp(gcontent, "000")) {
-                       escputs(gcontent);
-                       wprintf("<br />\n");
+       
+       switch (GetServerStatus(Buf, NULL)) {
+       case 8:
+               serv_puts("\n\n000");
+               if ( (StrLength(Buf)==3) && 
+                    !strcmp(ChrPtr(Buf), "000")) {
+                       StrBufAppendBufPlain(WCC->WBuf, HKEY("\000"), 0);
+                       break;
                }
-               wprintf("000");
-       }
-       if (buf[0] == '4') {
+       case 1:
+               while (!Done) {
+                       StrBuf_ServGetln(Buf);
+                       if ( (StrLength(Buf)==3) && 
+                            !strcmp(ChrPtr(Buf), "000")) {
+                               Done = 1;
+                       }
+                       StrEscAppend(WCC->WBuf, Buf, NULL, 0, 0);
+                       StrBufAppendBufPlain(WCC->WBuf, HKEY("<br>\n"), 0);
+               }
+               break;
+       case 4:
                text_to_server(bstr("g_input"));
                serv_puts("000");
-       }
-       if (buf[0] == '6') {
-               len = atol(&buf[4]);
-               junk = malloc(len);
-               serv_read(junk, len);
-               free(junk);
-       }
-       if (buf[0] == '7') {
-               len = atol(&buf[4]);
+               break;
+       case 6:
+               len = atol(&ChrPtr(Buf)[4]);
+               StrBuf_ServGetBLOBBuffered(Buf, len);
+               break;
+       case 7:
+               len = atol(&ChrPtr(Buf)[4]);
                junk = malloc(len);
                memset(junk, 0, len);
                serv_write(junk, len);
                free(junk);
        }
+       
        wprintf("<hr />");
        wprintf("<a href=\"display_generic\">Enter another command</a><br />\n");
        wprintf("<a href=\"display_advanced\">Return to menu</a>\n");
        do_template("endbox", NULL);
+       FreeStrBuf(&Buf);
        wDumpContent(1);
 }
 
@@ -369,9 +199,9 @@ void display_shutdown(void)
                }
                begin_burst();
                output_headers(1, 0, 0, 0, 1, 0);
-               DoTemplate(HKEY("display_serverrestart"), NULL, NULL, 0);
+               DoTemplate(HKEY("display_serverrestart"), NULL, &NoCtx);
                end_burst();
-               lingering_close(WC->http_sock);
+               lingering_close(WC->Hdr->http_sock);
                sleeeeeeeeeep(10);
                serv_printf("NOOP");
                serv_printf("NOOP");
@@ -384,16 +214,16 @@ void display_shutdown(void)
                {
                        begin_burst();
                        output_headers(1, 0, 0, 0, 1, 0);
-                       DoTemplate(HKEY("display_serverrestartpage"), NULL, NULL, 0);
+                       DoTemplate(HKEY("display_serverrestartpage"), NULL, &NoCtx);
                        end_burst();
                }
                else
                {
                        serv_printf("SEXP broadcast|%s", message);
-                       serv_getln(buf, sizeof buf); // should we care?
+                       serv_getln(buf, sizeof buf); /* TODO: should we care? */
                        begin_burst();
                        output_headers(1, 0, 0, 0, 1, 0);
-                       DoTemplate(HKEY("display_serverrestartpagedo"), NULL, NULL, 0);
+                       DoTemplate(HKEY("display_serverrestartpagedo"), NULL, &NoCtx);
                        end_burst();                    
                }
        }
@@ -409,7 +239,7 @@ void display_shutdown(void)
                }
                begin_burst();
                output_headers(1, 0, 0, 0, 1, 0);
-               DoTemplate(HKEY("display_aide_menu"), NULL, NULL, 0);
+               DoTemplate(HKEY("display_aide_menu"), NULL, &NoCtx);
                end_burst();                    
        }
 }
@@ -420,10 +250,10 @@ void
 InitModule_MAINMENU
 (void)
 {
-       WebcitAddUrlHandler(HKEY("display_aide_menu"), display_aide_menu, 0);
-       WebcitAddUrlHandler(HKEY("server_shutdown"), display_shutdown, 0);
-       WebcitAddUrlHandler(HKEY("display_main_menu"), display_main_menu, 0);
-       WebcitAddUrlHandler(HKEY("display_generic"), display_generic, 0);
-       WebcitAddUrlHandler(HKEY("do_generic"), do_generic, 0);
-       WebcitAddUrlHandler(HKEY("display_menubar"), _display_menubar, 0);
+       WebcitAddUrlHandler(HKEY("display_aide_menu"), "", 0, display_aide_menu, 0);
+       WebcitAddUrlHandler(HKEY("server_shutdown"), "", 0, display_shutdown, 0);
+       WebcitAddUrlHandler(HKEY("display_main_menu"), "", 0, display_main_menu, 0);
+       WebcitAddUrlHandler(HKEY("display_generic"), "", 0, display_generic, 0);
+       WebcitAddUrlHandler(HKEY("do_generic"), "", 0, do_generic, 0);
+       WebcitAddUrlHandler(HKEY("display_menubar"), "", 0, _display_menubar, 0);
 }