X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=31aec39861201d1ab941a9dc5b0ebc399d66a754;hb=b7f1665b64318cee1b14d13f7e9fdb6a323189a4;hp=6fcc5499f7b936927f8d9fc7c5f4142c85afe1c5;hpb=6c114e1487e4b4032be88563f0f5b76922edd601;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 6fcc5499f..31aec3986 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,7 +1,3 @@ -/* - * $Id$ - */ - #include "webcit.h" /* @@ -23,65 +19,20 @@ 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(); } - -/* - * 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->Hdr->HR.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) { - - wcsession *WCC = WC; + WCTemplputParams SubTP; int Done = 0; StrBuf *Buf; + StrBuf *LineBuf; char *junk; size_t len; @@ -90,38 +41,34 @@ void do_generic(void) return; } - output_headers(1, 1, 0, 0, 0, 0); - + Buf = NewStrBuf(); serv_puts(bstr("g_cmd")); - - svput("BOXTITLE", WCS_STRING, _("Server command results")); - do_template("beginboxx", NULL); - - wprintf("
Command:"); - StrEscAppend(WCC->WBuf, sbstr("g_cmd"), NULL, 0, 0); - wprintf("
Result:"); - StrEscAppend(WCC->WBuf, Buf, NULL, 0, 0); - StrBufAppendBufPlain(WCC->WBuf, HKEY("
\n"), 0); - wprintf("

\n"); + StrBuf_ServGetln(Buf); switch (GetServerStatus(Buf, NULL)) { case 8: serv_puts("\n\n000"); if ( (StrLength(Buf)==3) && !strcmp(ChrPtr(Buf), "000")) { - StrBufAppendBufPlain(WCC->WBuf, HKEY("\000"), 0); + StrBufAppendBufPlain(Buf, HKEY("\000"), 0); break; } case 1: + LineBuf = NewStrBuf(); + StrBufAppendBufPlain(Buf, HKEY("\n"), 0); while (!Done) { - StrBuf_ServGetln(Buf); - if ( (StrLength(Buf)==3) && - !strcmp(ChrPtr(Buf), "000")) { + if (StrBuf_ServGetln(LineBuf) < 0) + break; + if ( (StrLength(LineBuf)==3) && + !strcmp(ChrPtr(LineBuf), "000")) { Done = 1; } - StrEscAppend(WCC->WBuf, Buf, NULL, 0, 0); - StrBufAppendBufPlain(WCC->WBuf, HKEY("
\n"), 0); + StrBufAppendBuf(Buf, LineBuf, 0); + StrBufAppendBufPlain(Buf, HKEY("\n"), 0); } + FreeStrBuf(&LineBuf); + break; + case 2: break; case 4: text_to_server(bstr("g_input")); @@ -137,68 +84,40 @@ void do_generic(void) memset(junk, 0, len); serv_write(junk, len); free(junk); + break; } - 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); - } - - do_template("menubar", NULL); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); - if (as_single_page) { - wDumpContent(2); + StackContext(NULL, &SubTP, Buf, CTX_STRBUF, 0, NULL); + { + DoTemplate(HKEY("aide_display_generic_result"), NULL, &SubTP); } + UnStackContext(&SubTP); + wDumpContent(1); - + FreeStrBuf(&Buf); } - /* * Display the wait / input dialog while restarting the server. */ void display_shutdown(void) { - char buf[SIZ]; + 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->Hdr->http_sock); sleeeeeeeeeep(10); @@ -213,46 +132,40 @@ 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); }