X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=31aec39861201d1ab941a9dc5b0ebc399d66a754;hb=HEAD;hp=5233204e15f740a03af1078766a321ced9c25537;hpb=5a825607ef9581165e382ab6989c1c4d7cdf1254;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 5233204e1..2c326e001 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,377 +1,146 @@ /* - * $Id$ + * The main menu and other things + * + * Copyright (c) 1996-2021 by the citadel.org team + * + * This program is open source software. We call it open source, not + * free software, because Richard Stallman is a communist and an asshole. + * + * The program is licensed under the General Public License, version 3. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. */ #include "webcit.h" -/* - * The Main Menu - */ -void display_main_menu(void) -{ +// The Main Menu +void display_main_menu(void) { begin_burst(); output_headers(1, 0, 0, 0, 1, 0); DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx); end_burst(); - -/* - char buf[SIZ]; - output_headers(1, 1, 1, 0, 0, 0); - - wprintf("
" - "" - "" - "
\n"); - - svput("BOXTITLE", WCS_STRING, _("Basic commands")); - do_template("beginbox", NULL); - - / * start of first column * / - wprintf("\n"); - - / * start of second column * / - - wprintf("\n"); - - / * start of third column * / - - wprintf("\n"); - - wprintf(" "); - - do_template("endbox", NULL); - - 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); -*/ } -/* - * System administration menu - */ -void display_aide_menu(void) -{ +// System administration menu +void display_aide_menu(void) { begin_burst(); output_headers(1, 0, 0, 0, 1, 0); - DoTemplate(HKEY("display_aide_menu"), NULL, &NoCtx); + DoTemplate(HKEY("aide_display_menu"), NULL, &NoCtx); end_burst(); -/* - 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); -*/ } - -/* - * Display the screen to enter a generic server command - */ -void display_generic(void) -{ - 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"), ChrPtr(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[SIZ]; - char gcontent[SIZ]; +// Handle generic server commands, possibly entered from a screen, possibly set up as a way to avoid custom code +void do_generic(void) { + WCTemplputParams SubTP; + int Done = 0; + StrBuf *Buf; + StrBuf *LineBuf; char *junk; size_t len; - if (!havebstr("sc_button")) { + if ( (!havebstr("sc_button")) && (!havebstr("ok_button")) && (!havebstr("cancel_button")) ) { display_main_menu(); return; } - output_headers(1, 1, 0, 0, 0, 0); - - serv_printf("%s", bstr("g_cmd")); - serv_getln(buf, sizeof buf); - - svput("BOXTITLE", WCS_STRING, _("Server command results")); - do_template("beginboxx", NULL); - - wprintf("
Command:"); - escputs(bstr("g_cmd")); - wprintf("
Result:"); - escputs(buf); - wprintf("

\n"); - - if (buf[0] == '8') { - serv_printf("\n\n000"); + if (havebstr("cancel_button")) { + AppendImportantMessage(_("Cancelled. Changes were not saved."), -1); } - if ((buf[0] == '1') || (buf[0] == '8')) { - while (serv_getln(gcontent, sizeof gcontent), strcmp(gcontent, "000")) { - escputs(gcontent); - wprintf("
\n"); + + if (havebstr("ok_button")) { + Buf = NewStrBuf(); + serv_puts(bstr("g_cmd")); + StrBuf_ServGetln(Buf); + + switch (GetServerStatus(Buf, NULL)) { + case 8: + serv_puts("\n\n000"); + if ( (StrLength(Buf)==3) && + !strcmp(ChrPtr(Buf), "000")) { + StrBufAppendBufPlain(Buf, HKEY("\000"), 0); + break; + } + case 1: + LineBuf = NewStrBuf(); + StrBufAppendBufPlain(Buf, HKEY("\n"), 0); + while (!Done) { + if (StrBuf_ServGetln(LineBuf) < 0) + break; + if ( (StrLength(LineBuf)==3) && + !strcmp(ChrPtr(LineBuf), "000")) { + Done = 1; + } + StrBufAppendBuf(Buf, LineBuf, 0); + StrBufAppendBufPlain(Buf, HKEY("\n"), 0); + } + FreeStrBuf(&LineBuf); + break; + case 2: + break; + case 4: + text_to_server(bstr("g_input")); + serv_puts("000"); + 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); + break; } - wprintf("000"); + FreeStrBuf(&Buf); } - if (buf[0] == '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]); - 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", NULL); - wDumpContent(1); -} - - -/* - * 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) { - - if (as_single_page) { - output_headers(0, 0, 0, 0, 0, 0); - wprintf("\n" - "\n" - "MenuBar\n" - "\n" - "\n"); - do_template("background", NULL); + + // We may have been supplied with instructions regarding the location + // to which we must return after posting. If found, go there. + if (havebstr("return_to")) { + syslog(LOG_DEBUG, "return_to = %s", bstr("return_to")); + http_redirect(bstr("return_to")); } - do_template("menubar", NULL); - - if (as_single_page) { - wDumpContent(2); + // Otherwise, do the generic result screen. + else { + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + + StackContext(NULL, &SubTP, Buf, CTX_STRBUF, 0, NULL); + { + DoTemplate(HKEY("aide_display_generic_result"), NULL, &SubTP); + } + UnStackContext(&SubTP); + wDumpContent(1); } - } -/* - * Display the wait / input dialog while restarting the server. - */ -void display_shutdown(void) -{ - char buf[SIZ]; +// Display the wait / input dialog while restarting the server. +void display_shutdown(void) { + StrBuf *Line; char *when; + Line = NewStrBuf(); when=bstr("when"); 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? */ - - safestrncpy(WC->ImportantMessage, - &buf[4], - sizeof WC->ImportantMessage); - } + StrBuf_ServGetln(Line); + GetServerStatusMsg(Line, NULL, 1, 5); + begin_burst(); output_headers(1, 0, 0, 0, 1, 0); - DoTemplate(HKEY("display_serverrestart"), NULL, &NoCtx); + DoTemplate(HKEY("aide_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,46 +153,41 @@ void display_shutdown(void) { begin_burst(); output_headers(1, 0, 0, 0, 1, 0); - DoTemplate(HKEY("display_serverrestartpage"), NULL, &NoCtx); + DoTemplate(HKEY("aide_display_serverrestart_page"), NULL, &NoCtx); end_burst(); } else { serv_printf("SEXP broadcast|%s", message); - serv_getln(buf, sizeof buf); /* TODO: should we care? */ + StrBuf_ServGetln(Line); + GetServerStatusMsg(Line, NULL, 1, 0); + begin_burst(); output_headers(1, 0, 0, 0, 1, 0); - DoTemplate(HKEY("display_serverrestartpagedo"), NULL, &NoCtx); + DoTemplate(HKEY("aide_display_serverrestart_page"), NULL, &NoCtx); end_burst(); } } else if (!strcmp(when, "idle")) { serv_printf("SCDN 3"); - serv_getln(buf, sizeof buf); + StrBuf_ServGetln(Line); + GetServerStatusMsg(Line, NULL, 1, 2); - 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); + DoTemplate(HKEY("aide_display_menu"), NULL, &NoCtx); end_burst(); } + FreeStrBuf(&Line); } -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); + 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("do_generic"), "", 0, do_generic, 0); }