X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=ab3d2f38ab51ca6ebd484a74b41b52ffa924e335;hb=1f494963f66495189901c38c84cbc6d6b3e9f952;hp=5a9e0d74d2ac3f70a907c5b5caa040acbac993cd;hpb=792253218528e4327e0ddf1da78e424c9c9f08a4;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index 5a9e0d74d..ab3d2f38a 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,269 +1,31 @@ -/* $Id$ */ - - - - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include "webcit.h" - +/* + * $Id$ + */ +#include "webcit.h" /* * The Main Menu */ void display_main_menu(void) { - output_headers(1, 1, 1, 0, 0, 0, 0); - - wprintf("" - "" - "
\n"); - - svprintf("BOXTITLE", WCS_STRING, "Basic commands"); - do_template("beginbox"); - - wprintf("\n" - "" - "" - "
"); /* start of first column */ - - wprintf("" - "" - "List known rooms
" - "" - "Where can I go from here?
\n" - ); - - wprintf("" - "" - "Goto next room
" - "" - "...with unread messages" - "
\n" - ); - - wprintf("" - "" - "Skip to next room
" - "" - "(come back here later)" - "\n" - ); - - if ((strlen(WC->ugname) > 0) && (strcasecmp(WC->ugname, WC->wc_roomname))) { - wprintf("
" - "" - "" - "Ungoto
" - "" - "(oops! Back to %s)" - "\n", WC->ugname - ); - } - - wprintf("
\n"); /* start of second column */ - - wprintf("" - "" - "Read new messages
" - "" - "...in this room
\n" - ); - - wprintf("" - "" - "Read all messages
" - "" - "...old and new
\n" - ); - - wprintf("" - "" - "Enter a message
" - "" - "(post in this room)\n" - ); - - wprintf("
"); /* start of third column */ - - wprintf("" - "" - "Summary page
" - "" - "Summary of my account
\n" - ); - - wprintf("\n" - "" - "User list
" - "" - "(all registered users)
\n" - ); - - wprintf("" - "" - "Log off
" - "" - "Bye!\n" - ); - - wprintf("
\n"); - do_template("endbox"); - - wprintf("
"); - - svprintf("BOXTITLE", WCS_STRING, "Interaction"); - do_template("beginbox"); - - wprintf("" - "" - "Who is online?" - "" - " (users currently logged on)" - "
\n" - ); - - wprintf("" - "" - "Chat with other users in " - ); - escputs(WC->wc_roomname); - wprintf("
\n"); - - wprintf("\n"); - wprintf("" - "Generic server command\n"); - - do_template("endbox"); - - wprintf("
"); - - svprintf("BOXTITLE", WCS_STRING, "Your info"); - do_template("beginbox"); - - wprintf("" - "" - "Update your contact information " - "" - "(name, address, etc.)
\n"); - - wprintf("" - "" - "Change your password
\n"); - - wprintf("" - "" - "Enter your 'bio' " - "" - "(a few words about yourself)" - "
\n"); - - wprintf("" - "" - "Edit your online photo\n"); - - do_template("endbox"); - - wprintf("
"); - - svprintf("BOXTITLE", WCS_STRING, "Advanced room commands"); - do_template("beginbox"); - - if ((WC->axlevel >= 6) || (WC->is_room_aide)) { - wprintf("" - "" - "Edit or delete this room
\n"); - } - - wprintf("" - "" - "Go to a "hidden" room
\n"); - - wprintf("" - "" - "Create a new room
\n"); - - wprintf("" - "" - "Zap (forget) this room (%s)
\n", - WC->wc_roomname); - - wprintf("\n" - "" - "Access controls for this room
\n"); - - wprintf("" - "" - "List all forgotten rooms\n"); - - do_template("endbox"); - - wprintf("
"); - - if ((WC->axlevel >= 6) || (WC->is_room_aide)) { - svprintf("BOXTITLE", WCS_STRING, "Administrative functions"); - do_template("beginbox"); - - wprintf("" - "" - "Edit site-wide configuration\n"); - - if (WC->axlevel >= 6) { - wprintf("
" - "" - "" - "Add, change, delete user accounts" - "
\n"); - - wprintf("" - "" - "Validate new users
\n"); - - wprintf("" - "" - "Add, change, or delete floors" - "
\n"); - - wprintf("" - "" - "Configure networking with other systems" - "
\n"); - - wprintf("" - "" - "Internet configuration " - "" - "(domain names, etc.)
\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(); } +/* + * 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); + end_burst(); +} @@ -272,118 +34,140 @@ void display_main_menu(void) */ void display_generic(void) { - output_headers(1, 1, 0, 0, 0, 0, 0); + output_headers(1, 1, 2, 0, 0, 0); + wprintf("
\n"); + wprintf("

"); + wprintf(_("Enter a server command")); + wprintf("

"); + wprintf("
\n"); + + wprintf("
\n"); - svprintf("BOXTITLE", WCS_STRING, "Enter a server command"); - do_template("beginbox"); + 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("
"); + 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"); + wprintf("\n", WC->nonce); - wprintf("Enter command:
\n"); - wprintf("
\n"); + wprintf(_("Enter command:")); + wprintf("

\n"); - wprintf("Command input (if requesting SEND_LISTING transfer mode):
\n"); - wprintf("
\n"); + wprintf(_("Command input (if requesting SEND_LISTING transfer mode):")); + wprintf("

\n"); - wprintf("Detected host header is http://%s\n", - WC->http_host); - wprintf(""); + wprintf(""); + wprintf(_("Detected host header is %s://%s"), (is_https ? "https" : "http"), ChrPtr(WC->Hdr->http_host)); + wprintf("\n"); + wprintf("", _("Send command")); wprintf(" "); - wprintf("
\n"); + wprintf("
\n", _("Cancel")); - wprintf("
\n"); - do_template("endbox"); + wprintf("
\n"); + wprintf("
\n"); wDumpContent(1); } +/* + * Interactive window to perform generic Citadel server commands. + */ void do_generic(void) { - char buf[SIZ]; - char gcontent[SIZ]; + + wcsession *WCC = WC; + int Done = 0; + StrBuf *Buf; char *junk; size_t len; - if (strcasecmp(bstr("sc"), "Send command")) { + if (!havebstr("sc_button")) { display_main_menu(); return; } - output_headers(1, 1, 0, 0, 0, 0, 0); - - serv_printf("%s", bstr("g_cmd")); - serv_gets(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_gets(gcontent), strcmp(gcontent, "000")) { - escputs(gcontent); - wprintf("
\n"); + output_headers(1, 1, 0, 0, 0, 0); + + 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"); + + switch (GetServerStatus(Buf, NULL)) { + case 8: + serv_puts("\n\n000"); + if ( (StrLength(Buf)==3) && + !strcmp(ChrPtr(Buf), "000")) { + StrBufAppendBufPlain(WCC->WBuf, HKEY("\000"), 0); + break; } - wprintf("000"); - } - if (buf[0] == '4') { - text_to_server(bstr("g_input"), 0); + case 1: + while (!Done) { + StrBuf_ServGetln(Buf); + if ( (StrLength(Buf)==3) && + !strcmp(ChrPtr(Buf), "000")) { + Done = 1; + } + StrEscAppend(WCC->WBuf, Buf, NULL, 0, 0); + StrBufAppendBufPlain(WCC->WBuf, HKEY("
\n"), 0); + } + 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); } + wprintf("
"); - wprintf("Enter another command
\n"); - wprintf("Return to menu\n"); - do_template("endbox"); + 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 + * 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, 0); - wprintf("\n" - "\n" - "MenuBar\n" - "\n" - "\n"); - do_template("background"); + output_headers(0, 0, 0, 0, 0, 0); + wprintf("\n" + "\n" + "MenuBar\n" + "\n" + "\n"); + do_template("background", NULL); } - do_template("menubar"); + do_template("menubar", NULL); if (as_single_page) { wDumpContent(2); @@ -393,3 +177,82 @@ void display_menubar(int as_single_page) { } +/* + * 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("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("display_serverrestartpage"), 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("display_serverrestartpagedo"), 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("display_aide_menu"), NULL, &NoCtx); + end_burst(); + } +} + +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); +}