X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmainmenu.c;h=965f98f603deeb04d5bb6575327496afdc9b3535;hb=c1bfa993f32198515f9994cde602f7bcd4da35d8;hp=a00168b1d702bc3e1d2f41e075a52936b395daa2;hpb=80ef607866a31ea094b49657d660ea13c037e14b;p=citadel.git diff --git a/webcit/mainmenu.c b/webcit/mainmenu.c index a00168b1d..965f98f60 100644 --- a/webcit/mainmenu.c +++ b/webcit/mainmenu.c @@ -1,373 +1,354 @@ -/* $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); - - wprintf("" - "
\n"); + begin_burst(); + output_headers(1, 0, 0, 0, 1, 0); + DoTemplate(HKEY("display_main_menu"), NULL, &NoCtx); + end_burst(); - 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 - ); +/* + char buf[SIZ]; + output_headers(1, 1, 1, 0, 0, 0); + + wprintf("
" + "" + "
\n"); + + svput("BOXTITLE", WCS_STRING, _("Basic commands")); + do_template("beginbox", NULL); + + / * start of first column * / + wprintf("\n"); /* start of second column */ + wprintf("\n"); - wprintf("" - "" - "Read new messages
" - "" - "...in this room
\n" - ); + / * start of second column * / - wprintf("" - "" - "Read all messages
" - "" - "...old and new
\n" - ); + wprintf("
"); /* start of third column */ + wprintf("
  • "); + wprintf(_("Read all messages")); + wprintf(""); + wprintf(_("...old and new")); + wprintf("
  • \n"); - wprintf("" - "" - "Summary page
    " - "" - "Summary of my account
    \n" - ); + wprintf("
  • "); + wprintf(_("Enter a message")); + wprintf(""); + wprintf(_("(post in this room)")); + wprintf("
  • \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 online users
    \n"); + if (WC->room_flags & QR_VISDIR) { + wprintf("
  • "); + wprintf(_("File library")); + wprintf(""); + wprintf(_("(List files available for download)")); + wprintf("
  • \n"); + } - wprintf("\n"); - wprintf("" - "Generic server command\n"); + wprintf("\n"); - do_template("endbox"); + / * start of third column * / - wprintf("
    "); + wprintf("\n"); - wprintf("" - "" - "Change your password\n"); + wprintf(" "); - do_template("endbox"); + do_template("endbox", NULL); - wprintf("
    "); + wprintf("
    "); - svprintf("BOXTITLE", WCS_STRING, "Advanced room commands"); - do_template("beginbox"); + print_menu_box(_("Your info"), "adminitems", 8, + "display_preferences", _("Change your preferences and settings"), + "display_reg", _("Update your contact information"), + "display_changepw", _("Change your password"), + "display_editbio", _("Enter your 'bio'"), + "display_editpic", _("Edit your online photo"), + "display_sieve", _("View/edit server-side mail filters"), + "display_pushemail", _("Edit your push email settings"), + "display_openids", _("Manage your OpenIDs") + ); - wprintf("" - "" - "Go to a "hidden" room
    \n"); + wprintf("
    "); + + snprintf(buf, SIZ, _("Zap (forget) this room (%s)"), WC->wc_roomname); + + if ( (WC->axlevel >= 6) || (WC->is_room_aide) || (WC->is_mailbox) ) + print_menu_box(_("Advanced room commands"),"adminitems", 5, + "display_editroom", _("Edit or delete this room"), + "display_private", _("Go to a 'hidden' room"), + "display_entroom", _("Create a new room"), + "display_zap",buf, + "zapped_list",_("List all forgotten rooms")); + else + print_menu_box(_("Advanced room commands"),"adminitems", 4, + "display_private", _("Go to a 'hidden' room"), + "display_entroom", _("Create a new room"), + "display_zap",buf, + "zapped_list",_("List all forgotten rooms")); + + wprintf("
    "); + wDumpContent(2); +*/ +} - wprintf("" - "" - "Create a new room
    \n"); - wprintf("" - "" - "Zap (forget) this room (%s)
    \n", - WC->wc_roomname); +/* + * 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(); +/* + output_headers(1, 1, 2, 0, 0, 0); - wprintf("\n" - "" - "Access controls for this room
    \n"); + wprintf("
    \n"); + wprintf("

    "); + wprintf(_("System Administration Menu")); + wprintf("

    "); + wprintf("
    \n"); - wprintf("" - "" - "List all forgotten rooms\n"); + wprintf("
    "); - do_template("endbox"); + wprintf("
    " + " " + "
    "); - wprintf(""); + print_menu_box(_("Global Configuration"), "adminitems", 4, + "display_siteconfig", _("Edit site-wide configuration"), + "display_inetconf",_("Domain names and Internet mail configuration"), + "display_netconf", _("Configure replication with other Citadel servers"), + "display_smtpqueue", _("View the outbound SMTP queue")); + + wprintf(""); - if ((WC->axlevel >= 6) || (WC->is_room_aide)) { - svprintf("BOXTITLE", WCS_STRING, "Administrative functions"); - do_template("beginbox"); + print_menu_box(_("User account management"), "adminitems", 2, + "select_user_to_edit", _("Add, change, delete user accounts"), + "validate", _("Validate new users")); - wprintf("" - "" - "Edit or delete this room
    \n"); + wprintf("
    "); - wprintf("" - "" - "Edit site-wide configuration\n"); - if (WC->axlevel >= 6) { - wprintf("
    " - "" - "" - "Add, change, delete user accounts" - "
    \n"); + 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("" - "" - "Validate new users
    \n"); + wprintf("
    "); - wprintf("" - "" - "Add, change, or delete floors" - "
    \n"); + print_menu_box(_("Rooms and Floors"), "adminitems", 1, + "display_floorconfig", _("Add, change, or delete floors")); - wprintf("" - "" - "Configure networking with other systems" - "\n"); - } - do_template("endbox"); - } - wprintf("
    "); + wprintf("
    "); wDumpContent(2); +*/ } - - /* * Display the screen to enter a generic server command */ void display_generic(void) { - output_headers(3); - - svprintf("BOXTITLE", WCS_STRING, "Enter a server command"); - do_template("beginbox"); - - 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"); - do_template("endbox"); + 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->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) { - 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(3); - - 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("
    "); + 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); - 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); @@ -377,3 +358,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->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); +}