X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=31aec39861201d1ab941a9dc5b0ebc399d66a754;hb=HEAD;hp=816c5683f62d9c21e8cbb6c1282811365f0da002;hpb=9554bc4a2e17d25153cc6ffa7104375df9335073;p=citadel.git
diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c
index 816c5683f..2c326e001 100644
--- a/webcit/mainmenu.c
+++ b/webcit/mainmenu.c
@@ -1,444 +1,193 @@
/*
- * $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, NULL);
+ DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx);
end_burst();
-
-/*
- char buf[SIZ];
- output_headers(1, 1, 1, 0, 0, 0);
-
- 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");
- 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("beginbox", 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")){
+ 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... ")
- );
- }
- wDumpContent(0);
- lingering_close(WC->http_sock);
+ StrBuf_ServGetln(Line);
+ GetServerStatusMsg(Line, NULL, 1, 5);
+
+ begin_burst();
+ output_headers(1, 0, 0, 0, 1, 0);
+ DoTemplate(HKEY("aide_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", NULL);
- wprintf("\n",
- _("The citadel server has to be restarted. It 'll be back in a minute.")
- );
- do_template("endbox", NULL);
- wDumpContent(1);
-
-
+ begin_burst();
+ output_headers(1, 0, 0, 0, 1, 0);
+ DoTemplate(HKEY("aide_display_serverrestart_page"), 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... "));
-
+ StrBuf_ServGetln(Line);
+ GetServerStatusMsg(Line, NULL, 1, 0);
+
+ begin_burst();
+ output_headers(1, 0, 0, 0, 1, 0);
+ DoTemplate(HKEY("aide_display_serverrestart_page"), 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]);
- }
+ StrBuf_ServGetln(Line);
+ GetServerStatusMsg(Line, NULL, 1, 2);
+
+ begin_burst();
+ output_headers(1, 0, 0, 0, 1, 0);
+ 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);
}