]> code.citadel.org Git - citadel.git/blobdiff - webcit/mainmenu.c
Nearly all <FORM> blocks now contain a hidden input
[citadel.git] / webcit / mainmenu.c
index c67efa414508e654d02b4114b074c68cabdc0984..0436a77a270abb0c7783ebff2052da8ed70f8b32 100644 (file)
@@ -17,184 +17,172 @@ void display_main_menu(void)
        output_headers(1, 1, 1, 0, 0, 0);
 
        wprintf("<div class=\"fix_scrollbar_bug\">"
-               "<TABLE WIDTH=100%%>"
-               "<TR><TD COLSPAN=2>\n");
+               "<table width=100%%>"
+               "<tr><td colspan=\"2\">\n");
 
        svprintf("BOXTITLE", WCS_STRING, _("Basic commands"));
        do_template("beginbox");
 
        wprintf("\n"
-               "<TABLE border=0 cellspacing=1 cellpadding=1 width=100%%>"
-               "<TR>"
-               "<TD>");        /**< start of first column */
+               "<table border=0 cellspacing=1 cellpadding=1 width=99%%>"
+               "<tr>"
+               "<td>");        /**< start of first column */
 
-       wprintf("<a href=\"knrooms\"><span class=\"mainmenu\">");
+       wprintf("<ul class=\"adminitems\">");
+
+       wprintf("<li><a href=\"knrooms\">");
        wprintf(_("List known rooms"));
-       wprintf("</span></A><br /><span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("Where can I go from here?"));
-       wprintf("</span><br />\n");
+       wprintf("</span></li>\n");
 
-       wprintf("<a href=\"gotonext\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"gotonext\">");
        wprintf(_("Goto next room"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
-       wprintf(_("...with <EM>unread</EM> messages"));
-       wprintf("</span><br />\n");
+       wprintf("</a><span>");
+       wprintf(_("...with <em>unread</em> messages"));
+       wprintf("</span></li>\n");
 
-       wprintf("<a href=\"skip\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"skip\">");
        wprintf(_("Skip to next room"));
-       wprintf("</span></a><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("(come back here later)"));
-       wprintf("</span>\n");
+       wprintf("</span></li>\n");
 
        if ((strlen(WC->ugname) > 0) && (strcasecmp(WC->ugname, WC->wc_roomname))) {
-               wprintf("<br />"
-                       "<a href=\"ungoto\">"
-                       "<span class=\"mainmenu\">");
+               wprintf("<li><a href=\"ungoto\">");
                wprintf(_("Ungoto"));
-               wprintf("</span></A><br />"
-                       "<span class=\"menudesc\">");
+               wprintf("</a><span>");
                wprintf(_("(oops! Back to %s)"), WC->ugname);
-               wprintf("</span>\n");
+               wprintf("</span></li>\n");
        }
 
-       wprintf("</TD><TD>\n"); /* start of second column */
+       wprintf("</ul>\n");
+
+       wprintf("</td><td>\n"); /* start of second column */
+
+       wprintf("<ul class=\"adminitems\">");
 
-       wprintf("<a href=\"readnew\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"readnew\">");
        wprintf(_("Read new messages"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("...in this room"));
-       wprintf("</span><br />\n");
+       wprintf("</span></li>\n");
 
-       wprintf("<a href=\"readfwd\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"readfwd\">");
        wprintf(_("Read all messages"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("...old <EM>and</EM> new"));
-       wprintf("</span><br />\n");
+       wprintf("</span></li>\n");
 
-       wprintf("<a href=\"display_enter\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_enter\">");
        wprintf(_("Enter a message"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("(post in this room)"));
-       wprintf("</span>\n");
+       wprintf("</span></li>\n");
 
        if (WC->room_flags & QR_VISDIR) {
-               wprintf("<br /><a href=\"display_room_directory\">"
-                       "<span class=\"mainmenu\">");
+               wprintf("<li><a href=\"display_room_directory\">");
                wprintf(_("File library"));
-               wprintf("</span></A><br />"
-                       "<span class=\"menudesc\">");
+               wprintf("</a><span>");
                wprintf(_("(List files available for download)"));
-               wprintf("</span>\n");
+               wprintf("</span></li>\n");
        }
 
-       wprintf("</TD><TD>");   /* start of third column */
+       wprintf("</ul>\n");
 
-       wprintf("<a href=\"summary\">"
-               "<span class=\"mainmenu\">");
+       wprintf("</td><td>");   /* start of third column */
+
+       wprintf("<ul class=\"adminitems\">");
+
+       wprintf("<li><a href=\"summary\">");
        wprintf(_("Summary page"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("Summary of my account"));
-       wprintf("</span><br />\n");
+       wprintf("</span></li>\n");
 
-       wprintf("<a href=\"userlist\">\n"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"userlist\">\n");
        wprintf(_("User list"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("(all registered users)"));
-       wprintf("</span><br />\n");
+       wprintf("</span></li>\n");
 
-       wprintf("<a href=\"termquit\" TARGET=\"_top\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"termquit\" TARGET=\"_top\">");
        wprintf(_("Log off"));
-       wprintf("</span></A><br />"
-               "<span class=\"menudesc\">");
+       wprintf("</a><span>");
        wprintf(_("Bye!"));
-       wprintf("</span>\n");
+       wprintf("</span></li>\n");
+
+       wprintf("</ul>\n");
 
-       wprintf("</TD></TR></TABLE>\n");
+       wprintf("</td></tr></table>\n");
        do_template("endbox");
 
-       wprintf("</TD></TR>"
-               "<TR VALIGN=TOP><TD>");
+       wprintf("</td></tr>"
+               "<tr valign=top><td width=50%%>");
 
        svprintf("BOXTITLE", WCS_STRING, _("Your info"));
        do_template("beginbox");
 
-       wprintf("<a href=\"display_preferences\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<ul class=\"adminitems\">");
+
+       wprintf("<li><a href=\"display_preferences\">");
        wprintf(_("Change your preferences and settings"));
-       wprintf("</span><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_reg\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_reg\">");
        wprintf(_("Update your contact information"));
-       wprintf("</span><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_changepw\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_changepw\">");
        wprintf(_("Change your password"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_editbio\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_editbio\">");
        wprintf(_("Enter your 'bio'"));
-       wprintf("</span></a><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_editpic\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_editpic\">");
        wprintf(_("Edit your online photo"));
-       wprintf("</span></a><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_sieve\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_sieve\">");
        wprintf(_("View/edit server-side mail filters"));
-       wprintf("</span></a>\n");
+       wprintf("</a></li>\n");
+
+       wprintf("</ul>\n");
 
        do_template("endbox");
 
-       wprintf("</TD><TD>");
+       wprintf("</td><td width=50%%>");
 
        svprintf("BOXTITLE", WCS_STRING, _("Advanced room commands"));
        do_template("beginbox");
 
+       wprintf("<ul class=\"adminitems\">");
+
        if ((WC->axlevel >= 6) || (WC->is_room_aide)) {
-               wprintf("<a href=\"display_editroom\">"
-                       "<span class=\"mainmenu\">");
+               wprintf("<li><a href=\"display_editroom\">");
                wprintf(_("Edit or delete this room"));
-               wprintf("</span></A><br />\n");
+               wprintf("</a></li>\n");
        }
 
-       wprintf("<a href=\"display_private\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_private\">");
        wprintf(_("Go to a 'hidden' room"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_entroom\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_entroom\">");
        wprintf(_("Create a new room"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_zap\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_zap\">");
        wprintf(_("Zap (forget) this room (%s)"), WC->wc_roomname);
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"zapped_list\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"zapped_list\">");
        wprintf(_("List all forgotten rooms"));
-       wprintf("</span></A>\n");
+       wprintf("</a></li>\n");
+
+       wprintf("</ul>\n");
 
        do_template("endbox");
 
@@ -209,67 +197,76 @@ void display_main_menu(void)
 void display_aide_menu(void)
 {
        output_headers(1, 1, 2, 0, 0, 0);
-       wprintf("<div id=\"banner\">\n"
-               "<TABLE class=\"mainmenu_banner\"><TR><TD>"
-               "<SPAN CLASS=\"titlebar\">");
+
+        wprintf("<div id=\"banner\">\n");
+        wprintf("<div class=\"service_banner\">\n");
+        wprintf("<h1>");
        wprintf(_("System Administration Menu"));
-       wprintf("</SPAN>"
-               "</TD></TR></TABLE>\n"
-               "</div>\n<div id=\"content\">\n"
-       );
+        wprintf("</h1>");
+        wprintf("</div></div>");
+
+       wprintf("<div id=\"content\">");
 
        wprintf("<div class=\"fix_scrollbar_bug\">"
-               "<table border=0 width=100%%><tr valign=top><td>");
+               "<table border=0 width=99%%> "
+               "<tr valign=top><td width=50%% rowspan=2>");
 
        svprintf("BOXTITLE", WCS_STRING, _("Global Configuration"));
        do_template("beginbox");
 
-       wprintf("<a href=\"display_siteconfig\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<ul class=\"adminitems\">");
+
+       wprintf("<li><a href=\"display_siteconfig\">");
        wprintf(_("Edit site-wide configuration"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_inetconf\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_inetconf\">");
        wprintf(_("Domain names and Internet mail configuration"));
-       wprintf("</span></a><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_netconf\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_netconf\">");
        wprintf(_("Configure replication with other Citadel servers"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"display_smtpqueue\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"display_smtpqueue\">");
        wprintf(_("View the outbound SMTP queue"));
-       wprintf("</span></A>\n");
+       wprintf("</a></li>\n");
+
+       wprintf("</ul>");
 
        do_template("endbox");
 
-       wprintf("</td><td>");
+       wprintf("</td><td width=50%%>");
 
        svprintf("BOXTITLE", WCS_STRING, _("User account management"));
        do_template("beginbox");
 
-       wprintf("<a href=\"select_user_to_edit\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<ul class=\"adminitems\">");
+
+       wprintf("<li><a href=\"select_user_to_edit\">");
        wprintf(_("Add, change, delete user accounts"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
 
-       wprintf("<a href=\"validate\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<li><a href=\"validate\">");
        wprintf(_("Validate new users"));
-       wprintf("</span></A><br />\n");
+       wprintf("</a></li>\n");
+
+       wprintf("</ul>");
 
        do_template("endbox");
 
+       wprintf("</td></tr><tr><td width=50%%>");
+
        svprintf("BOXTITLE", WCS_STRING, _("Rooms and Floors"));
        do_template("beginbox");
 
-       wprintf("<a href=\"display_floorconfig\">"
-               "<span class=\"mainmenu\">");
+       wprintf("<ul class=\"adminitems\">");
+
+       wprintf("<li><a href=\"display_floorconfig\">");
        wprintf(_("Add, change, or delete floors"));
-       wprintf("</span></A>\n");
+       wprintf("</a></li>\n");
+
+       wprintf("</ul>");
 
        do_template("endbox");
 
@@ -288,38 +285,39 @@ void display_generic(void)
 {
        output_headers(1, 1, 2, 0, 0, 0);
        wprintf("<div id=\"banner\">\n"
-               "<TABLE class=\"mainmenu_banner\"><TR><TD>"
-               "<SPAN CLASS=\"titlebar\">");
+               "<table class=\"mainmenu_banner\"><tr><td>"
+               "<span class=\"titlebar\">");
        wprintf(_("Enter a server command"));
-       wprintf("</SPAN></TD></TR></TABLE>\n"
+       wprintf("</span></td></tr></table>\n"
                "</div>\n<div id=\"content\">\n"
        );
 
        wprintf("<div class=\"fix_scrollbar_bug\">"
                "<table class=\"mainmenu_background\"><tr><td>\n");
 
-       wprintf("<CENTER>");
+       wprintf("<center>");
        wprintf(_("This screen allows you to enter Citadel server commands which are "
                "not supported by WebCit.  If you do not know what that means, "
                "then this screen will not be of much use to you."));
        wprintf("<br />\n");
 
-       wprintf("<FORM METHOD=\"POST\" action=\"do_generic\">\n");
+       wprintf("<form method=\"post\" action=\"do_generic\">\n");
+       wprintf("<input type=\"hidden\" name=\"nonce\" value=\"%ld\">\n", WC->nonce);
 
        wprintf(_("Enter command:"));
-       wprintf("<br /><INPUT TYPE=\"text\" NAME=\"g_cmd\" SIZE=80 MAXLENGTH=\"250\"><br />\n");
+       wprintf("<br /><input type=\"text\" name=\"g_cmd\" size=80 maxlength=\"250\"><br />\n");
 
        wprintf(_("Command input (if requesting SEND_LISTING transfer mode):"));
-       wprintf("<br /><TEXTAREA NAME=\"g_input\" ROWS=10 COLS=80 WIDTH=80></TEXTAREA><br />\n");
+       wprintf("<br /><textarea name=\"g_input\" rows=10 cols=80 width=80></textarea><br />\n");
 
-       wprintf("<FONT SIZE=-2>");
+       wprintf("<font size=-2>");
        wprintf(_("Detected host header is %s://%s"), (is_https ? "https" : "http"), WC->http_host);
-       wprintf("</FONT>\n");
-       wprintf("<INPUT TYPE=\"submit\" NAME=\"sc_button\" VALUE=\"%s\">", _("Send command"));
+       wprintf("</font>\n");
+       wprintf("<input type=\"submit\" name=\"sc_button\" value=\"%s\">", _("Send command"));
        wprintf("&nbsp;");
-       wprintf("<INPUT TYPE=\"submit\" NAME=\"cancel_button\" VALUE=\"%s\"><br />\n", _("Cancel"));
+       wprintf("<input type=\"submit\" name=\"cancel_button\" value=\"%s\"><br />\n", _("Cancel"));
 
-       wprintf("</FORM></CENTER>\n");
+       wprintf("</form></center>\n");
        wprintf("</td></tr></table></div>\n");
        wDumpContent(1);
 }
@@ -347,11 +345,11 @@ void do_generic(void)
        svprintf("BOXTITLE", WCS_STRING, _("Server command results"));
        do_template("beginbox");
 
-       wprintf("<TABLE border=0><TR><TD>Command:</TD><TD><TT>");
+       wprintf("<table border=0><tr><td>Command:</td><td><tt>");
        escputs(bstr("g_cmd"));
-       wprintf("</TT></TD></TR><TR><TD>Result:</TD><TD><TT>");
+       wprintf("</tt></td></tr><tr><td>Result:</td><td><tt>");
        escputs(buf);
-       wprintf("</TT></TD></TR></TABLE><br />\n");
+       wprintf("</tt></td></tr></table><br />\n");
 
        if (buf[0] == '8') {
                serv_printf("\n\n000");
@@ -381,8 +379,8 @@ void do_generic(void)
                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");
+       wprintf("<a href=\"display_generic\">Enter another command</a><br />\n");
+       wprintf("<a href=\"display_advanced\">Return to menu</a>\n");
        do_template("endbox");
        wDumpContent(1);
 }
@@ -397,13 +395,13 @@ void display_menubar(int as_single_page) {
 
        if (as_single_page) {
                output_headers(0, 0, 0, 0, 0, 0);
-               wprintf("<HTML>\n"
-                       "<HEAD>\n"
-                       "<TITLE>MenuBar</TITLE>\n"
-                       "<STYLE TYPE=\"text/css\">\n"
-                       "BODY   { text-decoration: none; }\n"
-                       "</STYLE>\n"
-                       "</HEAD>\n");
+               wprintf("<html>\n"
+                       "<head>\n"
+                       "<title>MenuBar</title>\n"
+                       "<style type=\"text/css\">\n"
+                       "body   { text-decoration: none; }\n"
+                       "</style>\n"
+                       "</head>\n");
                do_template("background");
        }