X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=6fcc5499f7b936927f8d9fc7c5f4142c85afe1c5;hb=6c114e1487e4b4032be88563f0f5b76922edd601;hp=1ec145374b3d9a3894174584d2dd7bb9935b6bdf;hpb=76f23da782e9e80dad0a8ae1336230da5a6fa124;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 1ec145374..6fcc5499f 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -9,141 +9,10 @@ */ void display_main_menu(void) { - char buf[SIZ]; - output_headers(1, 1, 1, 0, 0, 0); - - wprintf("
" - "" - "" - "
\n"); - - svput("BOXTITLE", WCS_STRING, _("Basic commands")); - do_template("beginbox"); - - /* start of first column */ - wprintf("\n"); - - /* start of second 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); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx); + end_burst(); } @@ -152,47 +21,10 @@ void display_main_menu(void) */ void display_aide_menu(void) { - output_headers(1, 1, 2, 0, 0, 0); - - wprintf("
\n"); - wprintf("

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

"); - 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(""); - - print_menu_box(_("User account management"), "adminitems", 2, - "select_user_to_edit", _("Add, change, delete user accounts"), - "validate", _("Validate new users")); - - 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")); - - wprintf(""); - - print_menu_box(_("Rooms and Floors"), "adminitems", 1, - "display_floorconfig", _("Add, change, or delete floors")); - - wprintf("
"); - wDumpContent(2); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_aide_menu"), NULL, &NoCtx); + end_burst(); } @@ -230,7 +62,7 @@ void display_generic(void) wprintf("

\n"); wprintf(""); - 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("\n"); wprintf("", _("Send command")); wprintf(" "); @@ -246,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; @@ -258,49 +92,57 @@ void do_generic(void) output_headers(1, 1, 0, 0, 0, 0); - serv_printf("%s", bstr("g_cmd")); - serv_getln(buf, sizeof buf); + serv_puts(bstr("g_cmd")); svput("BOXTITLE", WCS_STRING, _("Server command results")); - do_template("beginbox"); + do_template("beginboxx", NULL); wprintf("
Command:"); - escputs(bstr("g_cmd")); + StrEscAppend(WCC->WBuf, sbstr("g_cmd"), NULL, 0, 0); wprintf("
Result:"); - escputs(buf); + StrEscAppend(WCC->WBuf, Buf, NULL, 0, 0); + StrBufAppendBufPlain(WCC->WBuf, HKEY("
\n"), 0); wprintf("

\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("
\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("
\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("
"); wprintf("Enter another command
\n"); wprintf("Return to menu\n"); - do_template("endbox"); + do_template("endbox", NULL); wDumpContent(1); } @@ -322,10 +164,10 @@ void display_menubar(int as_single_page) { "body { text-decoration: none; }\n" "\n" "\n"); - do_template("background"); + do_template("background", NULL); } - do_template("menubar"); + do_template("menubar", NULL); if (as_single_page) { wDumpContent(2); @@ -344,75 +186,60 @@ void display_shutdown(void) char *when; when=bstr("when"); - if (!strcmp(when, "now")){ + if (strcmp(when, "now") == 0){ 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... ") - ); + + safestrncpy(WC->ImportantMessage, + &buf[4], + sizeof WC->ImportantMessage); } - wDumpContent(0); - lingering_close(WC->http_sock); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_serverrestart"), NULL, &NoCtx); + end_burst(); + lingering_close(WC->Hdr->http_sock); sleeeeeeeeeep(10); serv_printf("NOOP"); serv_printf("NOOP"); } - else if (!strcmp(when, "page")) { + else if (strcmp(when, "page") == 0) { 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); - - + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_serverrestartpage"), NULL, &NoCtx); + end_burst(); } 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... ")); - + serv_getln(buf, sizeof buf); /* TODO: should we care? */ + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_serverrestartpagedo"), NULL, &NoCtx); + end_burst(); } } 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]); + + if (atol(buf) == 500) + { /* upsie. maybe the server is not running as daemon? */ + safestrncpy(WC->ImportantMessage, + &buf[4], + sizeof WC->ImportantMessage); } + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_aide_menu"), NULL, &NoCtx); + end_burst(); } }