X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=8942e93905b0e2b1758d3393070385dbb5701348;hb=fa4703876cbb0330af860bb686d044ddb59dbadb;hp=92b11d4efc92dc80123af6df73bff760ea1cfa40;hpb=c7a28913ad7fbcd263888e0bbb24b380d3a81b9c;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 92b11d4ef..8942e9390 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,399 +1,178 @@ -/* - * $Id$ - */ -/** - * \defgroup DispAdvancedMenu Displays the "advanced" (main) menu. - * - */ -/*@{*/ #include "webcit.h" -/** - * \brief The Main Menu +/* + * The Main Menu */ void display_main_menu(void) { - output_headers(1, 1, 1, 0, 0, 0); - - wprintf("
" - "" - "" - "
\n"); - - svprintf("BOXTITLE", WCS_STRING, _("Basic commands")); - do_template("beginbox"); - - wprintf("\n" - "" - "" - "
"); /**< start of first column */ - - wprintf(""); - wprintf(_("List known rooms")); - wprintf("
"); - wprintf(_("Where can I go from here?")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Goto next room")); - wprintf("
" - ""); - wprintf(_("...with unread messages")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Skip to next room")); - wprintf("
" - ""); - wprintf(_("(come back here later)")); - wprintf("\n"); - - if ((strlen(WC->ugname) > 0) && (strcasecmp(WC->ugname, WC->wc_roomname))) { - wprintf("
" - "" - ""); - wprintf(_("Ungoto")); - wprintf("
" - ""); - wprintf(_("(oops! Back to %s)"), WC->ugname); - wprintf("\n"); - } - - wprintf("
\n"); /* start of second column */ - - wprintf("" - ""); - wprintf(_("Read new messages")); - wprintf("
" - ""); - wprintf(_("...in this room")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Read all messages")); - wprintf("
" - ""); - wprintf(_("...old and new")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Enter a message")); - wprintf("
" - ""); - wprintf(_("(post in this room)")); - wprintf("\n"); - - wprintf("
"); /* start of third column */ - - wprintf("" - ""); - wprintf(_("Summary page")); - wprintf("
" - ""); - wprintf(_("Summary of my account")); - wprintf("
\n"); - - wprintf("\n" - ""); - wprintf(_("User list")); - wprintf("
" - ""); - wprintf(_("(all registered users)")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Log off")); - wprintf("
" - ""); - wprintf(_("Bye!")); - wprintf("\n"); - - wprintf("
\n"); - do_template("endbox"); - - wprintf("
"); - - svprintf("BOXTITLE", WCS_STRING, _("Your info")); - do_template("beginbox"); - - wprintf("" - ""); - wprintf(_("Change your preferences and settings")); - wprintf("
\n"); - - wprintf("
" - ""); - wprintf(_("Update your contact information")); - wprintf("
\n"); - - wprintf("
" - ""); - wprintf(_("Change your password")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Enter your 'bio'")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Edit your online photo")); - wprintf("\n"); - - do_template("endbox"); - - wprintf("
"); - - svprintf("BOXTITLE", WCS_STRING, _("Advanced room commands")); - do_template("beginbox"); - - if ((WC->axlevel >= 6) || (WC->is_room_aide)) { - wprintf("" - ""); - wprintf(_("Edit or delete this room")); - wprintf("
\n"); - } - - wprintf("" - ""); - wprintf(_("Go to a 'hidden' room")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Create a new room")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Zap (forget) this room (%s)"), WC->wc_roomname); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("List all forgotten rooms")); - wprintf("\n"); - - do_template("endbox"); - - wprintf("
"); - wDumpContent(2); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx); + end_burst(); } -/** - * \brief System administration menu +/* + * System administration menu */ void display_aide_menu(void) { - output_headers(1, 1, 2, 0, 0, 0); - wprintf("
\n" - "
" - ""); - wprintf(_("System Administration Menu")); - wprintf("" - "
\n" - "
\n
\n" - ); - - wprintf("
" - "
"); - - svprintf("BOXTITLE", WCS_STRING, _("Global Configuration")); - do_template("beginbox"); - - wprintf("" - ""); - wprintf(_("Edit site-wide configuration")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Domain names and Internet mail configuration")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Configure replication with other Citadel servers")); - wprintf("\n"); - - do_template("endbox"); - - wprintf("
"); - - svprintf("BOXTITLE", WCS_STRING, _("User account management")); - do_template("beginbox"); - - wprintf("" - ""); - wprintf(_("Add, change, delete user accounts")); - wprintf("
\n"); - - wprintf("" - ""); - wprintf(_("Validate new users")); - wprintf("
\n"); - - do_template("endbox"); - - svprintf("BOXTITLE", WCS_STRING, _("Rooms and Floors")); - do_template("beginbox"); - - wprintf("" - ""); - wprintf(_("Add, change, or delete floors")); - wprintf("\n"); - - do_template("endbox"); - - wprintf("
"); - wDumpContent(2); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("aide_display_menu"), NULL, &NoCtx); + end_burst(); } - - - -/** - * \brief Display the screen to enter a generic server command - */ -void display_generic(void) -{ - output_headers(1, 1, 2, 0, 0, 0); - wprintf("
\n" - "
" - ""); - wprintf(_("Enter a server command")); - wprintf("
\n" - "
\n
\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(_("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"), WC->http_host); - wprintf("\n"); - wprintf("", _("Send command")); - wprintf(" "); - wprintf("
\n", _("Cancel")); - - wprintf("
\n"); - wprintf("
\n"); - wDumpContent(1); -} - -/** - * \brief what??? +/* + * 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 (strlen(bstr("sc_button")) == 0) { + if (!havebstr("sc_button")) { display_main_menu(); return; } - output_headers(1, 1, 0, 0, 0, 0); - - serv_printf("%s", bstr("g_cmd")); - serv_getln(buf, sizeof buf); - - svprintf("BOXTITLE", WCS_STRING, _("Server command results")); - do_template("beginbox"); - - 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_getln(gcontent, sizeof 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"); - do_template("endbox"); - wDumpContent(1); -} + + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + SubTP.Filter.ContextType = CTX_STRBUF; + SubTP.Context = Buf; -/** - * \brief Display the menubar. - * \param as_single_page Set 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) { + DoTemplate(HKEY("aide_display_generic_result"), NULL, &SubTP); - if (as_single_page) { - output_headers(0, 0, 0, 0, 0, 0); - wprintf("\n" - "\n" - "MenuBar\n" - "\n" - "\n"); - do_template("background"); - } + wDumpContent(1); - do_template("menubar"); + FreeStrBuf(&Buf); +} - if (as_single_page) { - wDumpContent(2); +/* + * Display the wait / input dialog while restarting the server. + */ +void display_shutdown(void) +{ + char buf[SIZ]; + char *when; + + 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); + } + 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") == 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); + serv_getln(buf, sizeof buf); /* TODO: should we care? */ + 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) + { /* 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("aide_display_menu"), NULL, &NoCtx); + end_burst(); } - - } - -/*@}*/ +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); +}