X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=cbf9dc38f44007c7658d737af306bbbed9c966a7;hb=814d4bec141c8374ef72a60aeeded0d696483c5e;hp=7459e8deb49ce2a7da89b59f60e5b93f6e7e99bd;hpb=a3520ba38118fca9ad2679bc541b5a25014861f7;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 7459e8deb..cbf9dc38f 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,327 +1,172 @@ -/* $Id$ */ - - - - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include "webcit.h" - - /* * The Main Menu */ void display_main_menu(void) { - output_headers(1); - - wprintf("" - "
" - "Basic commands\n" - "
\n" - "
" - ); - - wprintf("
"); /* start of first column */ - - wprintf("\n"); - - wprintf("\n"); /* start of second column */ - - wprintf("\n"); - - wprintf(""); /* start of third column */ - - wprintf("\n"); - - wprintf("
\n"); - - wprintf("
"); - - wprintf("
"); - wprintf("Interaction\n"); - wprintf("
\n"); - - wprintf("\n"); - - wprintf("
"); - - wprintf("
"); - wprintf("Your info\n"); - wprintf("
\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("
"); - wDumpContent(2); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx); + end_burst(); } - - - /* - * Display the screen to enter a generic server command + * System administration menu */ -void display_generic(void) +void display_aide_menu(void) { - 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("Detected host header is http://%s\n", - WC->http_host); - wprintf(""); - wprintf("
\n"); - - wprintf("
\n"); - wDumpContent(1); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("aide_display_menu"), NULL, &NoCtx); + end_burst(); } + +/* + * Interactive window to perform generic Citadel server commands. + */ void do_generic(void) { - char buf[SIZ]; - char gcontent[SIZ]; + WCTemplputParams SubTP; + int Done = 0; + StrBuf *Buf; + StrBuf *LineBuf; char *junk; size_t len; - if (strcasecmp(bstr("sc"), "Send command")) { + if (!havebstr("sc_button")) { display_main_menu(); return; } - output_headers(1); - - serv_printf("%s", bstr("g_cmd")); - serv_gets(buf); - - wprintf("
"); - wprintf("Server command results\n"); - wprintf("
\n"); - - wprintf("
Command:"); - escputs(bstr("g_cmd")); - wprintf("
Result:"); - escputs(buf); - wprintf("

\n"); - - if (buf[0] == '8') { - serv_printf("\n\n000"); - } - if ((buf[0] == '1') || (buf[0] == '8')) { - while (serv_gets(gcontent), strcmp(gcontent, "000")) { - escputs(gcontent); - wprintf("
\n"); + memset(&SubTP, 0, sizeof(WCTemplputParams)); + 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; } - wprintf("000"); - } - if (buf[0] == '4') { - text_to_server(bstr("g_input"), 0); + 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"); - } - 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); + break; } - wprintf("
"); - wprintf("Enter another command
\n"); - wprintf("Return to menu\n"); - wDumpContent(1); -} + + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + SubTP.Filter.ContextType = CTX_STRBUF; + SubTP.Context = Buf; + DoTemplate(HKEY("aide_display_generic_result"), NULL, &SubTP); + wDumpContent(1); + + FreeStrBuf(&Buf); +} /* - * 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. + * Display the wait / input dialog while restarting the server. */ -void display_menubar(int as_single_page) { - - if (as_single_page) { - output_headers(0); - wprintf("\n" - "\n" - "MenuBar\n" - "\n" - "\n"); - do_template("background"); +void display_shutdown(void) +{ + StrBuf *Line; + char *when; + + Line = NewStrBuf(); + when=bstr("when"); + if (strcmp(when, "now") == 0){ + serv_printf("DOWN 1"); + 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"); } - - do_template("menubar"); - - if (as_single_page) { - wDumpContent(2); + else if (strcmp(when, "page") == 0) { + char *message; + + message = bstr("message"); + if ((message == NULL) || (IsEmptyStr(message))) + { + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("aide_display_serverrestart_page"), NULL, &NoCtx); + end_burst(); + } + else + { + serv_printf("SEXP broadcast|%s", message); + 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"); + 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 +InitModule_MAINMENU +(void) +{ + 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); +}