X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=1ec145374b3d9a3894174584d2dd7bb9935b6bdf;hb=76f23da782e9e80dad0a8ae1336230da5a6fa124;hp=8713620f46809bc4f9b270c6f9c48d69182f4aa8;hpb=d225aa4dd4a08e5f13d3cd2d3082f2434d5b9f01;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 8713620f4..1ec145374 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,282 +1,282 @@ -/* $Id$ */ - -#include -#ifdef HAVE_UNISTD_H -#include -#endif -#include -#include -#include -#include -#include "webcit.h" -#include "child.h" +/* + * $Id$ + */ +#include "webcit.h" -/* - * menu of commands (just the menu html itself) +/* + * The Main Menu */ - -void embed_main_menu(void) +void display_main_menu(void) { - wprintf("
"); - - wprintf("" + "
"); /* start of first column */ - - wprintf("\n"); + + /* start of third column */ + + wprintf("\n"); + + wprintf(" "); + + do_template("endbox"); + + wprintf("
"); + + 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(""); + + 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("
"); + wDumpContent(2); } + /* - * advanced options + * 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(""); + 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("Your info\n"); - wprintf("
\n"); + print_menu_box(_("User account management"), "adminitems", 2, + "select_user_to_edit", _("Add, change, delete user accounts"), + "validate", _("Validate new users")); - wprintf("
"); - wprintf("
  • \n"); - wprintf("Edit your online photo\n"); - wprintf("
  • \n"); - wprintf("Re-enter your registration info (name, address, etc.)\n"); + 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("
  • \n"); - wprintf("Change your password\n"); - - wprintf("\n"); - - - wprintf("
  • "); - - wprintf("
    "); - wprintf("Advanced room commands\n"); - wprintf("
    \n"); - - wprintf("\n"); - - wprintf("
    "); - - if ((WC->axlevel >= 6) || (WC->is_room_aide)) { - wprintf("
    "); - wprintf("Administrative functions\n"); - wprintf("
    \n"); - - wprintf("\n"); - } - wprintf("
    "); - - wprintf("
    "); - wprintf("Basic commands\n"); - wprintf("
    \n"); - -} + wprintf("
    "); + print_menu_box(_("Rooms and Floors"), "adminitems", 1, + "display_floorconfig", _("Add, change, or delete floors")); - - -/* - * menu of commands (as a page) - */ -void display_main_menu(void) -{ - printf("HTTP/1.0 200 OK\n"); - output_headers(1); - embed_main_menu(); + wprintf("
    "); wDumpContent(2); } -void display_advanced_menu(void) -{ - printf("HTTP/1.0 200 OK\n"); - output_headers(1); - embed_advanced_menu(); - embed_main_menu(); - wDumpContent(2); -} - /* * Display the screen to enter a generic server command */ void display_generic(void) { - printf("HTTP/1.0 200 OK\n"); - 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); } +/* + * 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 (!havebstr("sc_button")) { display_main_menu(); return; } - printf("HTTP/1.0 200 OK\n"); - 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"); + svput("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"); } @@ -293,53 +293,39 @@ void do_generic(void) if (buf[0] == '7') { len = atol(&buf[4]); junk = malloc(len); - bzero(junk, len); + memset(junk, 0, len); 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 + * Display the menubar. + * + * Set 'as_single_page' 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) { - printf("HTTP/1.0 200 OK\n"); - 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); @@ -347,3 +333,99 @@ void display_menubar(int as_single_page) { } + + +/* + * Display the wait / input dialog while restarting the server. + */ +void display_shutdown(void) +{ + char buf[SIZ]; + char *when; + + when=bstr("when"); + if (!strcmp(when, "now")){ + serv_printf("DOWN 1"); + serv_getln(buf, sizeof buf); + if (atol(buf) == 500) + { /* upsie. maybe the server is not running as daemon? */ + wprintf("Attention: %s", &buf[4]); + + } + else { + wprintf("\n" + "\n" + "\n" + "\n" + "\n" + " %s " + "\n\n", + _("Please wait while the Citadel server is restarted... ") + ); + } + wDumpContent(0); + lingering_close(WC->http_sock); + sleeeeeeeeeep(10); + serv_printf("NOOP"); + serv_printf("NOOP"); + } + else if (!strcmp(when, "page")) { + char *message; + + message = bstr("message"); + if ((message == NULL) || (IsEmptyStr(message))) + { + output_headers(1, 1, 1, 0, 0, 0); + svput("BOXTITLE", WCS_STRING, _("Message to your Users:")); + do_template("beginbox"); + wprintf("
    \n" + "\n" + "\n" + "\n" + "
    \n", + _("The citadel server has to be restarted. It 'll be back in a minute.") + ); + do_template("endbox"); + wDumpContent(1); + + + } + else + { + // TODO: page the users... wait longer... + serv_printf("SEXP broadcast|%s", message); + serv_getln(buf, sizeof buf); // should we care? + wprintf("\n" + "\n" + "\n" + "\n" + "\n" + " %s " + "\n\n", + _("Please wait while your users are being paged, the citadel server will be restarted after that... ")); + + } + } + else if (!strcmp(when, "idle")) { + serv_printf("SCDN 3"); + serv_getln(buf, sizeof buf); + if (atol(buf) == 500) { + /* oops ... maybe the server is not running as a daemon? */ + wprintf("Attention: %s", &buf[4]); + } + } +} + +void _display_menubar(void) { display_menubar(0); } + +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); +}