X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=0eda83f50aafc425792c7692217ec0449a6ad797;hb=2b01bf58f1bb034451069a51d0bf312f383f4bb8;hp=53af244cb6ac2c4226a9d8091fbd3dfa20b1c310;hpb=e49824f6ac2938ab146c432edf50696e311a6bc5;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 53af244cb..0eda83f50 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,294 +1,289 @@ -/* $Id$ */ - - - - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include +/* + * $Id$ + */ +/** + * \defgroup DispAdvancedMenu Displays the "advanced" (main) menu. + * \ingroup MenuInfrastructure + * + */ +/*@{*/ #include "webcit.h" - - - - -/* - * menu of commands (just the menu html itself) +/** + * \brief The Main Menu */ - -void embed_main_menu(void) +void display_main_menu(void) { - wprintf("
"); - - wprintf("" + "
"); /* start of first column */ - - wprintf("
"); + + print_menu_box(_("Your info"), "adminitems", 6, + "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")); + + wprintf(""); + + snprintf(buf, SIZ, _("Zap (forget) this room (%s)"), WC->wc_roomname); + + if ((WC->axlevel >= 6) || (WC->is_room_aide)) + 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("
"); + wDumpContent(2); } -/* - * advanced options + +/** + * \brief System administration menu */ -void embed_advanced_menu(void) +void display_aide_menu(void) { + output_headers(1, 1, 2, 0, 0, 0); - wprintf("
"); - - - wprintf("
"); - wprintf("Interaction\n"); - wprintf("
\n"); - - wprintf("\n"); - - wprintf("
"); - - wprintf("
"); - wprintf("Your info\n"); - wprintf("
\n"); - - wprintf("\n"); - - - wprintf("
"); + wprintf("
\n"); + wprintf("

"); + wprintf(_("System Administration Menu")); + wprintf("

"); + wprintf("
\n"); - wprintf("
"); - wprintf("Advanced room commands\n"); - wprintf("
\n"); + wprintf("
"); - wprintf("
    "); - wprintf("
  • \n"); - wprintf("Go to a 'hidden' room\n"); + wprintf("
    " + " " + "
    "); - wprintf("
  • "); - wprintf("Create a new room\n"); + 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("
  • "); - wprintf("
  • "); - wprintf("Zap (forget) this room (%s)\n", WC->wc_roomname); + print_menu_box(_("User account management"), "adminitems", 2, + "select_user_to_edit", _("Add, change, delete user accounts"), + "validate", _("Validate new users")); - wprintf("
  • "); - wprintf("List all forgotten rooms\n"); + wprintf("
  • "); - wprintf("\n"); - wprintf(""); + 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")); - if ((WC->axlevel >= 6) || (WC->is_room_aide)) { - wprintf("
    "); - wprintf("Administrative functions\n"); - wprintf("
    \n"); + wprintf("
    "); - wprintf("\n"); - } - wprintf("
    "); - - wprintf("
    "); - wprintf("Basic commands\n"); - wprintf("
    \n"); - -} - - - - -/* - * menu of commands (as a page) - */ -void display_main_menu(void) -{ - output_headers(1); - embed_main_menu(); + wprintf("
"); wDumpContent(2); } -void display_advanced_menu(void) -{ - output_headers(1); - embed_advanced_menu(); - embed_main_menu(); - wDumpContent(2); -} -/* - * Display the screen to enter a generic server command + +/** + * \brief Display the screen to enter a generic server command */ void display_generic(void) { - output_headers(1); - - wprintf("
"); - wprintf("Enter a server command\n"); - wprintf("
\n"); - - wprintf("
"); - wprintf("This screen allows you to enter Citadel server commands which are\n"); - wprintf("not supported by WebCit. If you do not know what that means,\n"); - wprintf("then this screen will not be of much use to you.
\n"); - - wprintf("
\n"); - - wprintf("Enter command:
\n"); - wprintf("
\n"); - - wprintf("Command input (if requesting SEND_LISTING transfer mode):
\n"); - wprintf("\n"); - - wprintf(""); - wprintf("
\n"); - - wprintf("
\n"); + output_headers(1, 1, 2, 0, 0, 0); + wprintf("
\n"); + wprintf("

"); + wprintf(_("Enter a server command")); + wprintf("

"); + wprintf("
\n"); + + wprintf("
\n"); + + wprintf("
" + "
\n"); + + wprintf("
"); + 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("
\n"); + + wprintf("
\n"); + wprintf("\n", WC->nonce); + + wprintf(_("Enter command:")); + wprintf("

\n"); + + wprintf(_("Command input (if requesting SEND_LISTING transfer mode):")); + wprintf("

\n"); + + wprintf(""); + wprintf(_("Detected host header is %s://%s"), (is_https ? "https" : "http"), WC->http_host); + wprintf("\n"); + wprintf("", _("Send command")); + wprintf(" "); + wprintf("
\n", _("Cancel")); + + wprintf("
\n"); + wprintf("
\n"); wDumpContent(1); } +/** + * \brief Interactive window to perform generic Citadel server commands. + */ void do_generic(void) { - char buf[256]; - char gcontent[256]; + char buf[SIZ]; + char gcontent[SIZ]; char *junk; size_t len; - if (strcasecmp(bstr("sc"), "Send command")) { + if (IsEmptyStr(bstr("sc_button"))) { display_main_menu(); return; } - output_headers(1); + output_headers(1, 1, 0, 0, 0, 0); serv_printf("%s", bstr("g_cmd")); - serv_gets(buf); + serv_getln(buf, sizeof buf); - wprintf("
"); - wprintf("Server command results\n"); - wprintf("
\n"); + svprintf("BOXTITLE", WCS_STRING, _("Server command results")); + do_template("beginbox"); - wprintf("
Command:"); + wprintf("
Command:"); escputs(bstr("g_cmd")); - wprintf("
Result:"); + wprintf("
Result:"); escputs(buf); - wprintf("

\n"); + wprintf("

\n"); if (buf[0] == '8') { serv_printf("\n\n000"); } if ((buf[0] == '1') || (buf[0] == '8')) { - while (serv_gets(gcontent), strcmp(gcontent, "000")) { + while (serv_getln(gcontent, sizeof gcontent), strcmp(gcontent, "000")) { escputs(gcontent); - wprintf("
\n"); + wprintf("
\n"); } wprintf("000"); } @@ -309,48 +304,34 @@ void do_generic(void) serv_write(junk, len); free(junk); } - wprintf("
"); - wprintf("Enter another command
\n"); - wprintf("Return to menu\n"); + wprintf("
"); + wprintf("Enter another command
\n"); + wprintf("Return to menu\n"); + do_template("endbox"); wDumpContent(1); } - - -/* - * Display the menubar. Set as_single_page to - * display HTML headers and footers -- otherwise it's assumed +/** + * \brief Display the menubar. + * \param as_single_page Set to display HTML headers and footers -- otherwise it's assumed * that the menubar is being embedded in another page. */ void display_menubar(int as_single_page) { - FILE *menubar_body; - char buf[256]; if (as_single_page) { - output_headers(0); - wprintf("\n" - "\n" - "MenuBar\n" - "\n" - "\n" - "\n"); + output_headers(0, 0, 0, 0, 0, 0); + wprintf("\n" + "\n" + "MenuBar\n" + "\n" + "\n"); + do_template("background"); } - menubar_body = fopen("static/menubar.html", "r"); - if (menubar_body == NULL) { - wprintf("menubar
%s", strerror(errno)); - } else { - while (fgets(buf, sizeof(buf), menubar_body) != NULL) { - wprintf("%s", buf); - } - fclose(menubar_body); - } - + do_template("menubar"); if (as_single_page) { wDumpContent(2); @@ -358,3 +339,6 @@ void display_menubar(int as_single_page) { } + + +/*@}*/