/**************************************************************************** * * $Id$ * Purpose ...............: Global Setup Program * ***************************************************************************** * Copyright (C) 1997-2002 * * Michiel Broek FIDO: 2:280/2802 * Beekmansbos 10 * 1971 BV IJmuiden * the Netherlands * * This file is part of MBSE BBS. * * This BBS is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2, or (at your option) any * later version. * * MB BBS is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with MB BBS; see the file COPYING. If not, write to the Free * Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. *****************************************************************************/ #include "../config.h" #include "../lib/libs.h" #include "../lib/memwatch.h" #include "../lib/structs.h" #include "../lib/users.h" #include "../lib/records.h" #include "../lib/common.h" #include "../lib/clcomm.h" #include "../lib/mberrors.h" #include "screen.h" #include "mutil.h" #include "ledit.h" #include "m_node.h" #include "m_marea.h" #include "m_ticarea.h" #include "m_new.h" #include "m_global.h" char *some_fn; int some_fd; extern int exp_golded; #define WRLONG cnt = write(some_fd, &longvar, sizeof(longvar)); void config_check(char *path) { static char buf[PATH_MAX]; sprintf(buf, "%s/etc/config.data", path); some_fn = buf; /* * Check if the configuration file exists. If not, exit. */ some_fd = open(some_fn, O_RDONLY); if (some_fd == -1) { perror(""); fprintf(stderr, "Fatal, %s/etc/config.data not found, is mbtask running?\n", path); exit(MBERR_CONFIG_ERROR); } close(some_fd); } int config_read(void) { some_fd = open(some_fn, O_RDONLY); if (some_fd == -1) return -1; memset(&CFG, 0, sizeof(CFG)); read(some_fd, &CFG, sizeof(CFG)); close(some_fd); return 0; } int config_write(void) { some_fd = open(some_fn, O_CREAT | O_WRONLY, S_IRUSR | S_IWUSR | S_IRGRP); if (some_fd == -1) return -1; write(some_fd, &CFG, sizeof(CFG)); close(some_fd); chmod(some_fn, 0640); exp_golded = TRUE; return 0; } int cf_open(void) { clr_index(); working(1, 0, 0); IsDoing("Edit Global"); working(1, 0, 0); if (0 == config_read()) { working(0, 0, 0); return 0; } working(2, 0, 0); return -1; } void cf_close(void) { working(1, 0, 0); if (config_write() != 0) working(2, 0, 0); working(0, 0, 0); } void e_reginfo(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.2 EDIT REGISTRATION INFO"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. System name"); mvprintw( 8, 6, "2. Domain name"); mvprintw( 9, 6, "3. Sysop uid"); mvprintw(10, 6, "4. Sysop Fido"); mvprintw(11, 6, "5. Location"); mvprintw(12, 6, "6. QWK/Bluewave"); mvprintw(13, 6, "7. Omen id"); mvprintw(14, 6, "8. Comment"); mvprintw(15, 6, "9. Origin line"); mvprintw(16, 6, "10. Startup uid"); for (;;) { set_color(WHITE, BLACK); show_str( 7,25,35, CFG.bbs_name); show_str( 8,25,35, CFG.sysdomain); show_str( 9,25, 8, CFG.sysop); show_str(10,25,35, CFG.sysop_name); show_str(11,25,35, CFG.location); show_str(12,25, 8, CFG.bbsid); show_str(13,25, 2, CFG.bbsid2); show_str(14,25,55, CFG.comment); show_str(15,25,50, CFG.origin); show_str(16,25, 8, CFG.startname); switch(select_menu(10)) { case 0: return; case 1: E_STR( 7,25,35, CFG.bbs_name, "Name of this ^BBS^ system") case 2: E_STR( 8,25,35, CFG.sysdomain, "Internet ^mail domain^ name of this system") case 3: E_STR( 9,25, 8, CFG.sysop, "^Unix name^ of the sysop") case 4: E_STR(10,25,35, CFG.sysop_name, "^Fidonet name^ of the sysop") case 5: E_STR(11,25,35, CFG.location, "^Location^ (city) of this system") case 6: E_UPS(12,25, 8, CFG.bbsid, "^QWK/Bluewave^ packets name") case 7: E_UPS(13,25, 2, CFG.bbsid2, "^Omen offline^ reader ID characters") case 8: E_STR(14,25,55, CFG.comment, "Some ^comment^ you may like to give") case 9: E_STR(15,25,50, CFG.origin, "Default ^origin^ line under echomail messages") case 10:E_STR(16,25, 8, CFG.startname, "The ^Unix username^ that is used to start the bbs") } }; } void e_filenames(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.3 EDIT GLOBAL FILENAMES"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. System logfile"); mvprintw( 8, 6, "2. Error logfile"); mvprintw( 9, 6, "3. Mgr logfile"); mvprintw(10, 6, "4. Default Menu"); mvprintw(11, 6, "5. Default Language"); mvprintw(12, 6, "6. Chat Logfile"); mvprintw(13, 6, "7. Welcome Logo"); for (;;) { set_color(WHITE, BLACK); show_str( 7,28,14, CFG.logfile); show_str( 8,28,14, CFG.error_log); show_str( 9,28,14, CFG.mgrlog); show_str(10,28,14, CFG.default_menu); show_str(11,28,14, CFG.current_language); show_str(12,28,14, CFG.chat_log); show_str(13,28,14, CFG.welcome_logo); switch(select_menu(7)) { case 0: return; case 1: E_STR( 7,28,14, CFG.logfile, "The name of the ^system^ logfile.") case 2: E_STR( 8,28,14, CFG.error_log, "The name of the ^errors^ logfile.") case 3: E_STR( 9,28,14, CFG.mgrlog, "The name of the ^area-/filemgr^ logfile.") case 4: E_STR(10,28,14, CFG.default_menu, "The name of the ^default^ (top) ^menu^.") case 5: E_STR(11,28,14, CFG.current_language, "The name of the ^default language^.") case 6: E_STR(12,28,14, CFG.chat_log, "The name of the ^chat^ logfile.") case 7: E_STR(13,28,14, CFG.welcome_logo, "The name of the ^BBS logo^ file.") } } } void e_global2(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 4, 6, "1.4 EDIT GLOBAL PATHS - 2"); set_color(CYAN, BLACK); mvprintw( 6, 2, "1. Magic's"); mvprintw( 7, 2, "2. DOS path"); mvprintw( 8, 2, "3. Unix path"); mvprintw( 9, 2, "4. LeaveCase"); mvprintw(10, 2, "5. Ftp base"); mvprintw(11, 2, "6. Arealists"); mvprintw(12, 2, "7. Ext. edit"); for (;;) { set_color(WHITE, BLACK); show_str( 6,16,64, CFG.req_magic); show_str( 7,16,64, CFG.dospath); show_str( 8,16,64, CFG.uxpath); show_bool(9,16, CFG.leavecase); show_str(10,16,64, CFG.ftp_base); show_str(11,16,64, CFG.alists_path); show_str(12,16,64, CFG.externaleditor); switch(select_menu(7)) { case 0: return; case 1: E_PTH( 6,16,64, CFG.req_magic, "The path to the ^magic filerequest^ files.", 0750) case 2: E_STR( 7,16,64, CFG.dospath, "The translated ^DOS^ drive and path, empty disables translation") case 3: E_PTH( 8,16,64, CFG.uxpath, "The translated ^Unix^ path.", 0750) case 4: E_BOOL(9,16, CFG.leavecase, "^Leave^ outbound flo filenames as is, ^No^ forces uppercase.") case 5: E_PTH(10,16,64, CFG.ftp_base, "The ^FTP home^ directory to strip of the real directory", 0750) case 6: E_PTH(11,16,64, CFG.alists_path, "The path where ^area lists^ and ^filebone lists^ are stored.", 0750) case 7: E_STR(12,16,64, CFG.externaleditor, "The full path and filename to the ^external message editor^ (blank=disable)") } }; } void s_global(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 4, 6, "1.4 EDIT GLOBAL PATHS"); set_color(CYAN, BLACK); mvprintw( 6, 2, "1. BBS menus"); mvprintw( 7, 2, "2. Txtfiles"); mvprintw( 8, 2, "3. Macro's"); mvprintw( 9, 2, "4. Home dirs"); mvprintw(10, 2, "5. Nodelists"); mvprintw(11, 2, "6. Inbound"); mvprintw(12, 2, "7. Prot inb."); mvprintw(13, 2, "8. Outbound"); mvprintw(14, 2, "9. Out queue"); mvprintw(15, 2, "10. *.msgs"); mvprintw(16, 2, "11. Bad TIC's"); mvprintw(17, 2, "12. TIC queue"); mvprintw(18, 2, "13. Next Screen"); } void e_global(void) { s_global(); for (;;) { set_color(WHITE, BLACK); show_str( 6,16,64, CFG.bbs_menus); show_str( 7,16,64, CFG.bbs_txtfiles); show_str( 8,16,64, CFG.bbs_macros); show_str( 9,16,64, CFG.bbs_usersdir); show_str(10,16,64, CFG.nodelists); show_str(11,16,64, CFG.inbound); show_str(12,16,64, CFG.pinbound); show_str(13,16,64, CFG.outbound); show_str(14,16,64, CFG.out_queue); show_str(15,16,64, CFG.msgs_path); show_str(16,16,64, CFG.badtic); show_str(17,16,64, CFG.ticout); switch(select_menu(13)) { case 0: return; case 1: E_PTH( 6,16,64, CFG.bbs_menus, "The path to the ^default menus^.", 0750) case 2: E_PTH( 7,16,64, CFG.bbs_txtfiles, "The path to the ^default textfiles^.", 0750) case 3: E_PTH( 8,16,64, CFG.bbs_macros, "The path to the ^default macro templates^.", 0750) case 4: E_PTH( 9,16,64, CFG.bbs_usersdir, "The path to the ^users home^ directories.", 0770) case 5: E_PTH(10,16,64, CFG.nodelists, "The path to the ^nodelists^.", 0750) case 6: E_PTH(11,16,64, CFG.inbound, "The path to the ^inbound^ for unknown systems.", 0750) case 7: E_PTH(12,16,64, CFG.pinbound, "The path to the ^nodelists^ for protected systems.", 0750) case 8: E_PTH(13,16,64, CFG.outbound, "The path to the base ^outbound^ directory.", 0750) case 9: E_PTH(14,16,64, CFG.out_queue, "The path to the ^temp outbound queue^ directory.", 0750) case 10:E_PTH(15,16,64, CFG.msgs_path, "The path to the ^*.msgs^ directory.", 0750) case 11:E_PTH(16,16,64, CFG.badtic, "The path to the ^bad tic files^.", 0750) case 12:E_PTH(17,16,64, CFG.ticout, "The path to the ^outgoing TIC^ files.", 0750) case 13:e_global2(); s_global(); break; } }; } void b_screen(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.5 EDIT GLOBAL SETTINGS"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Exclude Sysop"); mvprintw( 8, 2, "2. Show Connect"); mvprintw( 9, 2, "3. Ask Protocols"); mvprintw(10, 2, "4. Sysop Level"); mvprintw(11, 2, "5. Password Length"); mvprintw(12, 2, "6. Passwd Character"); mvprintw(13, 2, "7. Idle timeout"); mvprintw(14, 2, "8. Login Enters"); mvprintw(15, 2, "9. Homedir Quota"); mvprintw(16, 2, "10. Location length"); mvprintw( 7,37, "11. Show new msgarea"); mvprintw( 8,37, "12. OLR Max. msgs."); mvprintw( 9,37, "13. OLR Newfile days"); mvprintw(10,37, "14. OLR Max Filereq"); mvprintw(11,37, "15. BBS Log Level"); mvprintw(12,37, "16. Utils loglevel"); mvprintw(13,37, "17. Utils slowly"); mvprintw(14,37, "18. CrashMail level"); mvprintw(15,37, "19. FileAttach level"); mvprintw(16,37, "20. Min diskspace MB"); set_color(WHITE, BLACK); show_bool( 7,24, CFG.exclude_sysop); show_bool( 8,24, CFG.iConnectString); show_bool( 9,24, CFG.iAskFileProtocols); show_int( 10,24, CFG.sysop_access); show_int( 11,24, CFG.password_length); show_int( 12,24, CFG.iPasswd_Char); show_int( 13,24, CFG.idleout); show_int( 14,24, CFG.iCRLoginCount); show_int( 15,24, CFG.iQuota); show_int( 16,24, CFG.CityLen); show_bool( 7,59, CFG.NewAreas); show_int( 8,59, CFG.OLR_MaxMsgs); show_int( 9,59, CFG.OLR_NewFileLimit); show_int( 10,59, CFG.OLR_MaxReq); show_logl(11,59, CFG.bbs_loglevel); show_logl(12,59, CFG.util_loglevel); show_bool(13,59, CFG.slow_util); show_int( 14,59, CFG.iCrashLevel); show_int( 15,59, CFG.iAttachLevel); show_int( 16,59, CFG.freespace); } void e_bbsglob(void) { b_screen(); for (;;) { switch(select_menu(20)) { case 0: return; case 1: E_BOOL( 7,24, CFG.exclude_sysop, "^Exclude^ sysop from lists.") case 2: E_BOOL( 8,24, CFG.iConnectString, "Show ^connect string^ at logon") case 3: E_BOOL( 9,24, CFG.iAskFileProtocols, "Ask ^file protocol^ before every up- download") case 4: E_INT( 10,24, CFG.sysop_access, "Sysop ^access level^") case 5: E_INT( 11,24, CFG.password_length, "Mimimum ^password^ length.") case 6: E_INT( 12,24, CFG.iPasswd_Char, "Ascii number of ^password^ character") case 7: E_INT( 13,24, CFG.idleout, "^Idle timeout^ in minutes") case 8: E_INT( 14,24, CFG.iCRLoginCount, "Maximum ^Login Return^ count") case 9: E_INT( 15,24, CFG.iQuota, "Maximum ^Quota^ in MBytes in users homedirectory"); case 10:E_INT( 16,24, CFG.CityLen, "Minimum ^Location name^ length (3..6)") case 11:E_BOOL( 7,59, CFG.NewAreas, "Show ^new^ or ^deleted^ message areas to the user at login.") case 12:E_INT( 8,59, CFG.OLR_MaxMsgs, "^Maximum messages^ to pack for download (0=unlimited)") case 13:E_INT( 9,59, CFG.OLR_NewFileLimit, "^Limit Newfiles^ listing for maximum days") case 14:E_INT( 10,59, CFG.OLR_MaxReq, "Maximum ^Filerequests^ to honor") case 15:E_LOGL(CFG.bbs_loglevel, "1.5.15", b_screen) case 16:E_LOGL(CFG.util_loglevel, "1.5.16", b_screen) case 17:E_BOOL(13,59, CFG.slow_util, "Let background utilities run ^slowly^") case 18:E_INT( 14,59, CFG.iCrashLevel, "The user level to allow sending ^CrashMail^") case 19:E_INT( 15,59, CFG.iAttachLevel, "The user level to allow sending ^File Attaches^") case 20:E_INT( 16,59, CFG.freespace, "Minimum ^free diskspace^ in MBytes on filesystems") } }; } void s_newuser(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.7 EDIT NEW USERS DEFAULTS"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. Access level"); mvprintw( 8, 6, "2. Cap. Username"); mvprintw( 9, 6, "3. Ask ANSI"); mvprintw(10, 6, "4. Ask Sex"); mvprintw(11, 6, "5. Ask Voicephone"); mvprintw(12, 6, "6. Ask Dataphone"); mvprintw(13, 6, "7. Telephone scan"); mvprintw(14, 6, "8. Ask Handle"); mvprintw( 8,46, "9. Ask Birth date"); mvprintw( 9,46, "10. Ask Location"); mvprintw(10,46, "11. Ask Hot-Keys"); mvprintw(11,46, "12. One word names"); mvprintw(12,46, "13. Ask Address"); mvprintw(13,46, "14. Give email"); } void e_newuser(void) { s_newuser(); for (;;) { set_color(WHITE, BLACK); show_sec( 7,28, CFG.newuser_access); show_bool( 8,28, CFG.iCapUserName); show_bool( 9,28, CFG.iAnsi); show_bool(10,28, CFG.iSex); show_bool(11,28, CFG.iVoicePhone); show_bool(12,28, CFG.iDataPhone); show_bool(13,28, CFG.iTelephoneScan); show_bool(14,28, CFG.iHandle); show_bool( 8,68, CFG.iDOB); show_bool( 9,68, CFG.iLocation); show_bool(10,68, CFG.iHotkeys); show_bool(11,68, CFG.iOneName); show_bool(12,68, CFG.AskAddress); show_bool(13,68, CFG.GiveEmail); switch(select_menu(14)) { case 0: return; case 1: E_SEC( 7,28, CFG.newuser_access, "1.7.1 NEWUSER SECURITY", s_newuser) case 2: E_BOOL( 8,28, CFG.iCapUserName, "^Capitalize^ username") case 3: E_BOOL( 9,28, CFG.iAnsi, "Ask user if he wants ^ANSI^ colors") case 4: E_BOOL(10,28, CFG.iSex, "Ask users ^sex^") case 5: E_BOOL(11,28, CFG.iVoicePhone, "Ask users ^Voice^ phone number") case 6: E_BOOL(12,28, CFG.iDataPhone, "Ask users ^Data^ phone number") case 7: E_BOOL(13,28, CFG.iTelephoneScan, "Perform ^Telephone^ number scan") case 8: E_BOOL(14,28, CFG.iHandle, "Ask users ^handle^") case 9: E_BOOL( 8,68, CFG.iDOB, "Ask users ^Date of Birth^") case 10:E_BOOL( 9,68, CFG.iLocation, "Ask users ^Location^") case 11:E_BOOL(10,68, CFG.iHotkeys, "Ask user if he wants ^Hot-Keys^") case 12:E_BOOL(11,68, CFG.iOneName, "Allow ^one word^ (not in Unixmode) usernames") case 13:E_BOOL(12,68, CFG.AskAddress, "Aks users ^home address^ in 3 lines") case 14:E_BOOL(13,68, CFG.GiveEmail, "Give new users an ^private email^ box") } }; } void e_colors(void) { int fg, bg; /* * With this macro intermediate variables are passed to the color editor to prevent SIGBUS * on some CPU's (Sparc). */ #define ED_COL(f, b, t, h) fg = f; bg = b; edit_color(&fg, &bg, (char *)t, (char *)h); f = fg; b = bg; break; for (;;) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.8 EDIT TEXT COLOURS"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. Normal text"); mvprintw( 8, 6, "2. Underline"); mvprintw( 9, 6, "3. Input lines"); mvprintw(10, 6, "4. CR text"); mvprintw(11, 6, "5. More prompt"); mvprintw(12, 6, "6. Hilite text"); mvprintw(13, 6, "7. File name"); mvprintw(14, 6, "8. File size"); mvprintw(15, 6, "9. File date"); mvprintw(16, 6, "10. File descr."); mvprintw(17, 6, "11. Msg. input"); S_COL( 7,24, "Normal Text ", CFG.TextColourF, CFG.TextColourB) S_COL( 8,24, "Underline Text ", CFG.UnderlineColourF, CFG.UnderlineColourB) S_COL( 9,24, "Input Text ", CFG.InputColourF, CFG.InputColourB) S_COL(10,24, "CR Text ", CFG.CRColourF, CFG.CRColourB) S_COL(11,24, "More Prompt ", CFG.MoreF, CFG.MoreB) S_COL(12,24, "Hilite Text ", CFG.HiliteF, CFG.HiliteB) S_COL(13,24, "File Name ", CFG.FilenameF, CFG.FilenameB) S_COL(14,24, "File Size ", CFG.FilesizeF, CFG.FilesizeB) S_COL(15,24, "File Date ", CFG.FiledateF, CFG.FiledateB) S_COL(16,24, "File Description", CFG.FiledescF, CFG.FiledescB) S_COL(17,24, "Message Input ", CFG.MsgInputColourF, CFG.MsgInputColourB) switch(select_menu(11)) { case 0: return; case 1: ED_COL(CFG.TextColourF, CFG.TextColourB, "1.8.1 EDIT COLOR", "normal text") case 2: ED_COL(CFG.UnderlineColourF, CFG.UnderlineColourB, "1.8.2 EDIT COLOR", "underline") case 3: ED_COL(CFG.InputColourF, CFG.InputColourB, "1.8.3 EDIT COLOR", "input") case 4: ED_COL(CFG.CRColourF, CFG.CRColourB, "1.8.4 EDIT COLOR", "") case 5: ED_COL(CFG.MoreF, CFG.MoreB, "1.8.5 EDIT COLOR", "more prompt") case 6: ED_COL(CFG.HiliteF, CFG.HiliteB, "1.8.6 EDIT COLOR", "hilite text") case 7: ED_COL(CFG.FilenameF, CFG.FilenameB, "1.8.7 EDIT COLOR", "file name") case 8: ED_COL(CFG.FilesizeF, CFG.FilesizeB, "1.8.8 EDIT COLOR", "file size") case 9: ED_COL(CFG.FiledateF, CFG.FiledateB, "1.8.9 EDIT COLOR", "file date") case 10:ED_COL(CFG.FiledescF, CFG.FiledescB, "1.8.10 EDIT COLOR", "file description") case 11:ED_COL(CFG.MsgInputColourF, CFG.MsgInputColourB, "1.8.11 EDIT COLOR", "message input") } }; } void e_nu_door(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.9 EDIT NEXT USER DOOR"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Text file"); mvprintw( 8, 2, "2. Quote"); for (;;) { set_color(WHITE, BLACK); show_str( 7,17,49, CFG.sNuScreen); show_str( 8,17,64, CFG.sNuQuote); switch(select_menu(2)) { case 0: return; case 1: E_STR(7,17,49, CFG.sNuScreen, "The ^text file^ to display to the next user.") case 2: E_STR(8,17,64, CFG.sNuQuote, "The ^quote^ to insert in the next user text.") } }; } void e_safe_door(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.10 EDIT SAFE DOOR"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Digit 1"); mvprintw( 8, 2, "2. Digit 2"); mvprintw( 9, 2, "3. Digit 3"); mvprintw(10, 2, "4. Max trys"); mvprintw(11, 2, "5. Max numb"); mvprintw(12, 2, "6. Num gen"); mvprintw(13, 2, "7. Prize"); mvprintw(14, 2, "8. Welcome"); mvprintw(15, 2, "9. Opened"); for (;;) { set_color(WHITE, BLACK); show_int( 7,16, CFG.iSafeFirstDigit); show_int( 8,16, CFG.iSafeSecondDigit); show_int( 9,16, CFG.iSafeThirdDigit); show_int(10,16, CFG.iSafeMaxTrys); show_int(11,16, CFG.iSafeMaxNumber); show_bool(12,16, CFG.iSafeNumGen); show_str(13,16,64, CFG.sSafePrize); show_str(14,16,64, CFG.sSafeWelcome); show_str(15,16,64, CFG.sSafeOpened); switch(select_menu(9)) { case 0: return; case 1: E_INT( 7,16, CFG.iSafeFirstDigit, "Enter ^first^ digit of the safe") case 2: E_INT( 8,16, CFG.iSafeSecondDigit, "Enter ^second^ digit of the safe") case 3: E_INT( 9,16, CFG.iSafeThirdDigit, "Enter ^third^ digit of the safe") case 4: E_INT( 10,16, CFG.iSafeMaxTrys, "Maximum ^trys^ per day") case 5: E_INT( 11,16, CFG.iSafeMaxNumber, "^Maximum number^ of each digit") case 6: E_BOOL(12,16, CFG.iSafeNumGen, "^Automatic^ number generation") case 7: E_STR( 13,16,64, CFG.sSafePrize, "The ^prize^ the user wins when he opens the safe") case 8: E_STR( 14,16,64, CFG.sSafeWelcome, "The ^welcome^ screen for the safe door") case 9: E_STR( 15,16,64, CFG.sSafeOpened, "The file to display when the safe is ^opened^") } }; } void e_timebank(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.11 EDIT TIME BANK"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. Users time balance"); mvprintw( 8, 6, "2. Max time withdraw"); mvprintw( 9, 6, "3. Max time deposit"); mvprintw(10, 6, "4. Users Kb. balance"); mvprintw(11, 6, "5. Max Kb. withdraw"); mvprintw(12, 6, "6. Max Kb. deposit"); mvprintw(13, 6, "7. Users time ratio"); mvprintw(14, 6, "8. Users Kb. ratio"); for (;;) { set_color(WHITE, BLACK); show_int( 7,31, CFG.iMaxTimeBalance); show_int( 8,31, CFG.iMaxTimeWithdraw); show_int( 9,31, CFG.iMaxTimeDeposit); show_int(10,31, CFG.iMaxByteBalance); show_int(11,31, CFG.iMaxByteWithdraw); show_int(12,31, CFG.iMaxByteDeposit); show_str(13,31,6, CFG.sTimeRatio); show_str(14,31,6, CFG.sByteRatio); switch(select_menu(8)) { case 0: return; case 1: E_INT( 7,31, CFG.iMaxTimeBalance, "Maximum ^time balance^") case 2: E_INT( 8,31, CFG.iMaxTimeWithdraw, "Maximum ^time withdraw^") case 3: E_INT( 9,31, CFG.iMaxTimeDeposit, "Maximum ^time deposit^") case 4: E_INT(10,31, CFG.iMaxByteBalance, "Maximum ^bytes balance^") case 5: E_INT(11,31, CFG.iMaxByteWithdraw, "Maximum ^bytes withdraw^") case 6: E_INT(12,31, CFG.iMaxByteDeposit, "Maximum ^bytes deposit^") case 7: E_STR(13,31,6, CFG.sTimeRatio, "^Time ratio^") case 8: E_STR(14,31,6, CFG.sByteRatio, "^Bytes ratio^") } }; } void e_paging(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.12 EDIT SYSOP PAGING"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Ext. Chat"); mvprintw( 8, 2, "2. Chat Device"); mvprintw( 9, 2, "3. Call Script"); mvprintw(10, 2, "4. Page Length"); mvprintw(11, 2, "5. Page Times"); mvprintw(12, 2, "6. Sysop Area"); mvprintw(13, 2, "7. Ask Reason"); mvprintw(14, 2, "8. Use Extern"); mvprintw(15, 2, "9. Log Chat"); mvprintw(16, 2, "10. Prompt Chk."); mvprintw(17, 2, "11. Freeze Time"); mvprintw(11,42, "12. Sunday"); mvprintw(12,42, "13. Monday"); mvprintw(13,42, "14. Tuesday"); mvprintw(14,42, "15. Wednesday"); mvprintw(15,42, "16. Thursday"); mvprintw(16,42, "17. Friday"); mvprintw(17,42, "18. Saterday"); for (;;) { set_color(WHITE, BLACK); show_str( 7,20,49, CFG.sExternalChat); show_str( 8,20,19, CFG.sChatDevice); show_str( 9,20,50, CFG.sCallScript); show_int(10,20, CFG.iPageLength); show_int(11,20, CFG.iMaxPageTimes); show_int(12,20, CFG.iSysopArea); show_bool(13,20, CFG.iAskReason); show_bool(14,20, CFG.iExternalChat); show_bool(15,20, CFG.iAutoLog); show_bool(16,20, CFG.iChatPromptChk); show_bool(17,20, CFG.iStopChatTime); show_str(11,58,5, CFG.cStartTime[0]); show_str(12,58,5, CFG.cStartTime[1]); show_str(13,58,5, CFG.cStartTime[2]); show_str(14,58,5, CFG.cStartTime[3]); show_str(15,58,5, CFG.cStartTime[4]); show_str(16,58,5, CFG.cStartTime[5]); show_str(17,58,5, CFG.cStartTime[6]); show_str(11,65,5, CFG.cStopTime[0]); show_str(12,65,5, CFG.cStopTime[1]); show_str(13,65,5, CFG.cStopTime[2]); show_str(14,65,5, CFG.cStopTime[3]); show_str(15,65,5, CFG.cStopTime[4]); show_str(16,65,5, CFG.cStopTime[5]); show_str(17,65,5, CFG.cStopTime[6]); switch(select_menu(18)) { case 0: return; case 1: E_STR( 7,20,49, CFG.sExternalChat, "The name of the ^External Chat^ program.") case 2: E_STR( 8,20,19, CFG.sChatDevice, "The ^device^ to use for chat") case 3: E_STR( 9,20,50, CFG.sCallScript, "The ^Call Script^ to connect to remote sysop") case 4: E_INT( 10,20, CFG.iPageLength, "The ^Length^ of paging in seconds") case 5: E_INT( 11,20, CFG.iMaxPageTimes, "The ^Maximum times^ a user may page in a session") case 6: E_INT( 12,20, CFG.iSysopArea, "The ^Message Area^ for ^Message to sysop^ when page fails") case 7: E_BOOL(13,20, CFG.iAskReason, "Ask the user the ^reason for chat^") case 8: E_BOOL(14,20, CFG.iExternalChat, "Use ^External Chat^ program") case 9: E_BOOL(15,20, CFG.iAutoLog, "^Automatic log^ chat sessions") case 10:E_BOOL(16,20, CFG.iChatPromptChk, "Check for chat at the ^prompt^") case 11:E_BOOL(17,20, CFG.iStopChatTime, "^Stop^ users time during chat") case 12:strcpy(CFG.cStartTime[0], edit_str(11,58,5, CFG.cStartTime[0], (char *)"Start Time paging on ^Sunday^")); strcpy(CFG.cStopTime[0], edit_str(11,65,5, CFG.cStopTime[0], (char *)"Stop Time paging on ^Sunday^")); break; case 13:strcpy(CFG.cStartTime[1], edit_str(12,58,5, CFG.cStartTime[1], (char *)"Start Time paging on ^Monday^")); strcpy(CFG.cStopTime[1], edit_str(12,65,5, CFG.cStopTime[1], (char *)"Stop Time paging on ^Monday^")); break; case 14:strcpy(CFG.cStartTime[2], edit_str(13,58,5, CFG.cStartTime[2], (char *)"Start Time paging on ^Tuesday^")); strcpy(CFG.cStopTime[2], edit_str(13,65,5, CFG.cStopTime[2], (char *)"Stop Time paging on ^Tuesday^")); break; case 15:strcpy(CFG.cStartTime[3], edit_str(14,58,5, CFG.cStartTime[3], (char *)"Start Time paging on ^Wednesday^")); strcpy(CFG.cStopTime[3], edit_str(14,65,5, CFG.cStopTime[3], (char *)"Stop Time paging on ^Wednesday^")); break; case 16:strcpy(CFG.cStartTime[4], edit_str(15,58,5, CFG.cStartTime[4], (char *)"Start Time paging on ^Thursday^")); strcpy(CFG.cStopTime[4], edit_str(15,65,5, CFG.cStopTime[4], (char *)"Stop Time paging on ^Thursday^")); break; case 17: strcpy(CFG.cStartTime[5], edit_str(16,58,5, CFG.cStartTime[5], (char *)"Start Time paging on ^Friday^")); strcpy(CFG.cStopTime[5], edit_str(16,65,5, CFG.cStopTime[5], (char *)"Stop Time paging on ^Friday^")); break; case 18:strcpy(CFG.cStartTime[6], edit_str(17,58,5, CFG.cStartTime[6], (char *)"Start Time paging on ^Saterday^")); strcpy(CFG.cStopTime[6], edit_str(17,65,5, CFG.cStopTime[6], (char *)"Stop Time paging on ^Saterday^")); break; } }; } void e_flags(int Users) { int i, x, y, z; char temp[80]; clr_index(); set_color(WHITE, BLACK); if (Users) mvprintw( 5, 6, "1.6 EDIT USER FLAG DESCRIPTIONS"); else mvprintw( 5, 6, "1.20 EDIT MANAGER FLAG DESCRIPTIONS"); set_color(CYAN, BLACK); for (i = 0; i < 32; i++) { if (i < 11) mvprintw(i + 7, 2, (char *)"%d.", i+1); else if (i < 22) mvprintw(i - 4, 28, (char *)"%d.", i+1); else mvprintw(i - 15, 54, (char *)"%d.", i+1); } for (;;) { set_color(WHITE, BLACK); for (i = 0; i < 32; i++) { if (i < 11) { if (Users) show_str(i + 7, 6, 16, CFG.fname[i]); else show_str(i + 7, 6, 16, CFG.aname[i]); } else { if (i < 22) { if (Users) show_str(i - 4, 32, 16, CFG.fname[i]); else show_str(i - 4, 32, 16, CFG.aname[i]); } else { if (Users) show_str(i -15, 58, 16, CFG.fname[i]); else show_str(i - 15,58, 16, CFG.aname[i]); } } } z = select_menu(32); if (z == 0) return; if (z < 12) { x = 6; y = z + 6; } else { if (z < 23) { x = 32; y = z - 5; } else { x = 58; y = z - 16; } } sprintf(temp, "Enter a short ^description^ of flag bit %d", z); if (Users) { strcpy(CFG.fname[z-1], edit_str(y, x, 16, CFG.fname[z-1], temp)); } else { strcpy(CFG.aname[z-1], edit_str(y, x, 16, CFG.aname[z-1], temp)); } } } void e_ticconf(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.13 EDIT FILEECHO PROCESSING"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Keep days"); mvprintw( 8, 2, "2. Hatch pwd"); mvprintw( 9, 2, "3. Drv space"); mvprintw(10, 2, "4. Systems"); mvprintw(11, 2, "5. Groups"); mvprintw(12, 2, "6. Max. dupes"); mvprintw(13, 2, "7. Keep date"); mvprintw(14, 2, "8. Keep netm"); mvprintw(15, 2, "9. Res future"); mvprintw(16, 2, "10. Loc resp"); mvprintw( 7,42, "11. Repl ext"); mvprintw( 8,42, "12. Plus all"); mvprintw( 9,42, "13. Notify"); mvprintw(10,42, "14. Passwd"); mvprintw(11,42, "15. Message"); mvprintw(12,42, "16. Tic on/off"); mvprintw(13,42, "17. Pause"); for (;;) { set_color(WHITE, BLACK); show_int( 7,18, CFG.tic_days); show_str( 8,18,20, (char *)"********************"); show_int( 9,18, CFG.drspace); show_int(10,18, CFG.tic_systems); show_int(11,18, CFG.tic_groups); show_int(12,18, CFG.tic_dupes); show_bool(13,18, CFG.ct_KeepDate); show_bool(14,18, CFG.ct_KeepMgr); show_bool(15,18, CFG.ct_ResFuture); show_bool(16,18, CFG.ct_LocalRep); show_bool( 7,58, CFG.ct_ReplExt); show_bool( 8,58, CFG.ct_PlusAll); show_bool( 9,58, CFG.ct_Notify); show_bool(10,58, CFG.ct_Passwd); show_bool(11,58, CFG.ct_Message); show_bool(12,58, CFG.ct_TIC); show_bool(13,58, CFG.ct_Pause); switch(select_menu(17)) { case 0: return; case 1: E_INT( 7,18, CFG.tic_days, "Number of days to ^keep^ files on hold.") case 2: E_STR( 8,18,20, CFG.hatchpasswd, "Enter the internal ^hatch^ password.") case 3: E_INT( 9,18, CFG.drspace, "Enter the minimal ^free drivespace^ in KBytes.") case 4: CFG.tic_systems = edit_int(10,18, CFG.tic_systems, (char *)"Enter the maximum number of ^connected systems^ in the database."); if ((OpenTicarea() == 0)) CloseTicarea(TRUE); working(0, 0, 0); break; case 5: CFG.tic_groups = edit_int(11,18, CFG.tic_groups, (char *)"Enter the maximum number of ^fileecho groups^ in the database."); if ((OpenNoderec() == 0)) CloseNoderec(TRUE); working(0, 0, 0); break; case 6: E_INT( 12,18, CFG.tic_dupes, "Enter the maximum number of ^dupes^ in the dupe database.") case 7: E_BOOL(13,18, CFG.ct_KeepDate, "^Keep^ original filedate on import") case 8: E_BOOL(14,18, CFG.ct_KeepMgr, "Keep ^Areamgr^ netmails.") case 9: E_BOOL(15,18, CFG.ct_ResFuture, "Reset ^future^ filedates.") case 10:E_BOOL(16,18, CFG.ct_LocalRep, "Respond to local ^filesearch^ requests.") case 11:E_BOOL( 7,58, CFG.ct_ReplExt, "Replace file ^extention^ to * during filesearch") case 12:E_BOOL( 8,58, CFG.ct_PlusAll, "Allow ^+%*^ (Plus all) in areamgr requests.") case 13:E_BOOL( 9,58, CFG.ct_Notify, "Allow turning ^notify^ messages on or off.") case 14:E_BOOL(10,58, CFG.ct_Passwd, "Allow changing the areamgr ^password^.") case 15:E_BOOL(11,58, CFG.ct_Message, "Allow turning areamgr ^messages^ on or off.") case 16:E_BOOL(12,58, CFG.ct_TIC, "Allow turning ^TIC^ files on or off.") case 17:E_BOOL(13,58, CFG.ct_Pause, "Allow the ^pause^ areamgr command.") } }; } void s_fidomailcfg(void); void s_fidomailcfg(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 5, "1.14 EDIT FIDONET MAIL AND ECHOMAIL PROCESSING"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Badboard"); mvprintw( 8, 2, "2. Dupeboard"); mvprintw( 9, 2, "3. Pktdate"); mvprintw(10, 2, "4. Max pkts."); mvprintw(11, 2, "5. Max arcs."); mvprintw(12, 2, "6. Keep days"); mvprintw(13, 2, "7. Echo dupes"); mvprintw(14, 2, "8. Reject old"); mvprintw(15, 2, "9. Max msgs"); mvprintw(16, 1, "10. Days old"); mvprintw(12,42, "11. Max systems"); mvprintw(13,42, "12. Max groups"); mvprintw(14,42, "13. 4d address"); mvprintw(15,42, "14. Split at"); mvprintw(16,42, "15. Force at"); set_color(WHITE, BLACK); show_str( 7,16,64, CFG.badboard); show_str( 8,16,64, CFG.dupboard); show_str( 9,16,64, CFG.pktdate); show_int( 10,16, CFG.maxpktsize); show_int( 11,16, CFG.maxarcsize); show_int( 12,16, CFG.toss_days); show_int( 13,16, CFG.toss_dupes); show_int( 14,16, CFG.toss_old); show_int( 15,16, CFG.defmsgs); show_int( 16,16, CFG.defdays); show_int( 12,58, CFG.toss_systems); show_int( 13,58, CFG.toss_groups); show_bool(14,58, CFG.addr4d); show_int( 15,58, CFG.new_split); show_int( 16,58, CFG.new_force); } void e_fidomailcfg(void) { s_fidomailcfg(); for (;;) { switch(select_menu(15)) { case 0: return; case 1: E_JAM( 7,16,64, CFG.badboard, "The path to the ^bad echomail^ board.") case 2: E_JAM( 8,16,64, CFG.dupboard, "The path to the ^dupe echomail^ board.") case 3: E_STR( 9,16,64, CFG.pktdate, "The filename and parameters to the ^pktdate^ program.") case 4: E_INT( 10,16, CFG.maxpktsize, "The maximum size in KB for mail ^packets^, 0 if unlimited.") case 5: E_INT( 11,16, CFG.maxarcsize, "The maximum size in KB for ^arcmail^ archives, 0 if unlimited.") case 6: E_INT( 12,16, CFG.toss_days, "The number of ^days^ to keep mail on hold.") case 7: E_INT( 13,16, CFG.toss_dupes, "The number of ^dupes^ to store in the echomail dupes database.") case 8: E_INT( 14,16, CFG.toss_old, "^Reject^ mail older then days, 0 means never reject.") case 9: E_INT( 15,16, CFG.defmsgs, "The default maximum number of ^messages^ in each mail area.") case 10:E_INT( 16,16, CFG.defdays, "The default maximum ^age in days^ in each mail area.") case 11:CFG.toss_systems = edit_int(12,58, CFG.toss_systems, (char *)"The maximum number of connected ^systems^ in the database."); if ((OpenMsgarea() == 0)) CloseMsgarea(TRUE); working(0, 0, 0); break; case 12:CFG.toss_groups = edit_int(13,58, CFG.toss_groups, (char *)"The maximum number of ^groups^ in the database."); if ((OpenNoderec() == 0)) CloseNoderec(TRUE); working(0, 0, 0); break; case 13:E_BOOL(14,58, CFG.addr4d, "Use ^4d^ addressing instead of ^5d^ addressing.") case 14:E_INT( 15,58, CFG.new_split, "Gently ^split^ newfiles reports after n kilobytes (12..60).") case 15:E_INT( 16,58, CFG.new_force, "Force ^split^ of newfiles reports after n kilobytes (16..64).") } }; } void s_intmailcfg(void); void s_intmailcfg(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 5, "1.15 EDIT INTERNET MAIL AND NEWS PROCESSING"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. POP3 node"); mvprintw( 8, 2, "2. SMTP node"); switch (CFG.newsfeed) { case FEEDINN: mvprintw( 9, 2, "3. N/A"); mvprintw(10, 2, "4. NNTP node"); mvprintw(11, 2, "5. NNTP m.r."); mvprintw(12, 2, "6. NNTP user"); mvprintw(13, 2, "7. NNTP pass"); break; case FEEDRNEWS: mvprintw( 9, 2, "3. Path rnews"); mvprintw(10, 2, "4. N/A"); mvprintw(11, 2, "5. N/A"); mvprintw(12, 2, "6. N/A"); mvprintw(13, 2, "7. N/A"); break; case FEEDUUCP: mvprintw( 9, 2, "3. UUCP path"); mvprintw(10, 2, "4. UUCP node"); mvprintw(11, 2, "5. N/A"); mvprintw(12, 2, "6. N/A"); mvprintw(13, 2, "7. N/A"); break; } mvprintw(14, 2, "8. News dupes"); mvprintw(15, 2, "9. Email aka"); mvprintw(16, 1, "10. UUCP aka"); mvprintw(17, 1, "11. Emailmode"); mvprintw(12,42, "12. Articles"); mvprintw(13,42, "13. News mode"); mvprintw(14,42, "14. Split at"); mvprintw(15,42, "15. Force at"); mvprintw(16,42, "16. Control ok"); mvprintw(17,42, "17. No regate"); set_color(WHITE, BLACK); show_str( 7,16,64, CFG.popnode); show_str( 8,16,64, CFG.smtpnode); show_str( 9,16,64, CFG.rnewspath); show_str(10,16,64, CFG.nntpnode); show_bool(11,16, CFG.modereader); show_str(12,16,15, CFG.nntpuser); show_str(13,16,15, (char *)"**************"); show_int(14,16, CFG.nntpdupes); show_aka(15,16, CFG.EmailFidoAka); show_aka(16,16, CFG.UUCPgate); show_emailmode(17,16, CFG.EmailMode); show_int( 12,57, CFG.maxarticles); show_newsmode(13,57, CFG.newsfeed); show_int( 14,57, CFG.new_split); show_int( 15,57, CFG.new_force); show_bool(16,57, CFG.allowcontrol); show_bool(17,57, CFG.dontregate); } /* * Edit UUCP gateway, return -1 if there are errors, 0 if ok. */ void e_uucp(void) { int j; clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.15 EDIT UUCP GATEWAY"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. Zone"); mvprintw( 8, 6, "2. Net"); mvprintw( 9, 6, "3. Node"); mvprintw(10, 6, "4. Point"); mvprintw(11, 6, "5. Domain"); for (;;) { set_color(WHITE, BLACK); show_int( 7,19, CFG.UUCPgate.zone); show_int( 8,19, CFG.UUCPgate.net); show_int( 9,19, CFG.UUCPgate.node); show_int(10,19, CFG.UUCPgate.point); show_str(11,19,12, CFG.UUCPgate.domain); j = select_menu(5); switch(j) { case 0: return; case 1: E_INT( 7,19, CFG.UUCPgate.zone, "The ^zone^ number for the UUCP gateway") case 2: E_INT( 8,19, CFG.UUCPgate.net, "The ^Net^ number for the UUCP gateway") case 3: E_INT( 9,19, CFG.UUCPgate.node, "The ^Node^ number for the UUCP gateway") case 4: E_INT( 10,19, CFG.UUCPgate.point, "The ^Point^ number for the UUCP gateway") case 5: E_STR( 11,19,11, CFG.UUCPgate.domain, "The ^FTN Domain^ for the UUCP gateway without a dot") } } } void e_intmailcfg(void) { int tmp; s_intmailcfg(); for (;;) { switch(select_menu(17)) { case 0: return; case 1: E_STR( 7,16,64, CFG.popnode, "The ^FQDN^ of the node where the ^POP3^ server runs.") case 2: E_STR( 8,16,64, CFG.smtpnode, "The ^FQDN^ of the node where the ^SMTP^ server runs.") case 3: if (CFG.newsfeed == FEEDRNEWS) strcpy(CFG.rnewspath, edit_pth(9,16,64, CFG.rnewspath, (char *)"The path and filename to the ^rnews^ command.", 0775)); if (CFG.newsfeed == FEEDUUCP) strcpy(CFG.rnewspath, edit_pth(9,16,64, CFG.rnewspath, (char *)"The path to the ^uucppublic^ directory.", 0775)); break; case 4: if (CFG.newsfeed == FEEDINN) strcpy(CFG.nntpnode, edit_str(10,16,64, CFG.nntpnode, (char *)"The ^FQDN^ of the node where the ^NNTP^ server runs.")); if (CFG.newsfeed == FEEDUUCP) strcpy(CFG.nntpnode, edit_str(10,16,64, CFG.nntpnode, (char *)"The ^UUCP^ nodename of the remote UUCP system")); break; case 5: E_BOOL(11,16, CFG.modereader, "Does the NNTP server needs the ^Mode Reader^ command.") case 6: E_STR( 12,16,15, CFG.nntpuser, "The ^Username^ for the NNTP server if needed.") case 7: E_STR( 13,16,15, CFG.nntppass, "The ^Password^ for the NNTP server if needed.") case 8: E_INT( 14,16, CFG.nntpdupes, "The number of ^dupes^ to store in the news articles dupes database.") case 9: tmp = PickAka((char *)"1.15.9", FALSE); if (tmp != -1) CFG.EmailFidoAka = CFG.aka[tmp]; s_intmailcfg(); break; case 10:e_uucp(); s_intmailcfg(); break; case 11:CFG.EmailMode = edit_emailmode(17,16, CFG.EmailMode); s_intmailcfg(); break; case 12:E_INT( 12,57, CFG.maxarticles, "Default maximum ^news articles^ to fetch") case 13:CFG.newsfeed = edit_newsmode(13,57, CFG.newsfeed); s_intmailcfg(); break; case 14:E_INT( 14,57, CFG.new_split, "Gently ^split^ messages after n kilobytes (12..60).") case 15:E_INT( 15,57, CFG.new_force, "Force ^split^ of messages after n kilobytes (16..64).") case 16:E_BOOL(16,57, CFG.allowcontrol, "^Allow control^ messages for news to be gated.") case 17:E_BOOL(17,57, CFG.dontregate, "Don't ^regate^ already gated messages.") } }; } void s_newfiles(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.16 ALLFILES & NEWFILES LISTINGS"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. New days"); mvprintw( 8, 2, "2. Security"); mvprintw( 9, 2, "3. Groups"); } void e_newfiles(void) { s_newfiles(); for (;;) { set_color(WHITE, BLACK); show_int( 7,16, CFG.newdays); show_sec( 8,16, CFG.security); show_int( 9,16, CFG.new_groups); switch(select_menu(3)) { case 0: return; case 1: E_INT(7,16, CFG.newdays, "Add files younger than this in newfiles report.") case 2: E_SEC(8,16, CFG.security, "1.14 NEWFILES REPORTS SECURITY", s_newfiles) case 3: CFG.new_groups = edit_int( 9, 16, CFG.new_groups, (char *)"The maximum of ^newfiles^ groups in the newfiles database"); if (OpenNewfiles() == 0) CloseNewfiles(TRUE); working(0, 0, 0); break; } }; } /* * Edit one aka, return -1 if there are errors, 0 if ok. */ void e_aka(int Area) { int j; clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.1 EDIT AKA"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. Zone"); mvprintw( 8, 6, "2. Net"); mvprintw( 9, 6, "3. Node"); mvprintw(10, 6, "4. Point"); mvprintw(11, 6, "5. Domain"); mvprintw(12, 6, "6. Active"); for (;;) { set_color(WHITE, BLACK); show_int( 7,19, CFG.aka[Area].zone); show_int( 8,19, CFG.aka[Area].net); show_int( 9,19, CFG.aka[Area].node); show_int(10,19, CFG.aka[Area].point); show_str(11,19,12, CFG.aka[Area].domain); show_bool(12,19, CFG.akavalid[Area]); j = select_menu(6); switch(j) { case 0: return; case 1: E_INT( 7,19, CFG.aka[Area].zone, "The ^zone^ number for this aka") case 2: E_INT( 8,19, CFG.aka[Area].net, "The ^Net^ number for this aka") case 3: E_INT( 9,19, CFG.aka[Area].node, "The ^Node^ number for this aka") case 4: E_INT( 10,19, CFG.aka[Area].point, "The ^Point^ number for this node (if any)") case 5: E_STR( 11,19,11, CFG.aka[Area].domain, "The ^FTN Domain^ for this aka without a dot (ie no .org)") case 6: E_BOOL(12,19, CFG.akavalid[Area], "Is this aka ^available^") } } } void e_fidoakas(void) { int i, j, k, x, y, o = 0, error, from, too; char pick[12]; char temp[121]; for (;;) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.1 EDIT FIDONET AKA'S"); set_color(CYAN, BLACK); x = 2; y = 7; set_color(CYAN, BLACK); for (i = 1; i <= 20; i++) { if (i == 11) { x = 42; y = 7; } if ((o + i) <= 40) { if (CFG.akavalid[o+i-1]) set_color(CYAN, BLACK); else set_color(LIGHTBLUE, BLACK); if (CFG.akavalid[o+i-1]) { sprintf(temp, "%3d %s", o+i, aka2str(CFG.aka[o+i-1])); temp[38] = '\0'; } else sprintf(temp, "%3d", o+i); mvprintw(y, x, temp); y++; } } strcpy(pick, select_aka(40, 20)); if (strncmp(pick, "-", 1) == 0) { error = FALSE; /* * Various checks on the system aka's. */ if ((! CFG.aka[0].zone) && (! CFG.akavalid[0])) { errmsg("First aka (main aka) must be valid"); error = TRUE; } if (error == FALSE) { /* * Check if aka's are in one continues block */ k = 0; for (j = 0; j < 40; j++) if (CFG.akavalid[j] && CFG.aka[j].zone) k++; for (j = k; j < 40; j++) if (CFG.akavalid[j] || CFG.aka[j].zone) error = TRUE; if (error) errmsg("All aka's must be in one continues block"); } if (! error) return; } if (strncmp(pick, "N", 1) == 0) if ((o + 20) < 40) o = o + 20; if (strncmp(pick, "P", 1) == 0) if ((o - 20) >= 0) o = o - 20; if (strncmp(pick, "M", 1) == 0) { from = too = 0; mvprintw(LINES -3, 6, "Enter aka number (1..40) to move >"); from = edit_int(LINES -3, 42, from, (char *)"Enter record number"); locate(LINES -3, 6); clrtoeol(); mvprintw(LINES -3, 6, "Enter new position (1..40) >"); too = edit_int(LINES -3, 36, too, (char *)"Enter destination record number"); if ((from == too) || (from == 0) || (too == 0) || (from > 40) || (too > 40)) { errmsg("That makes no sense"); } else if (CFG.akavalid[from - 1] == FALSE) { errmsg("Origin aka is invalid"); } else if (CFG.akavalid[too - 1]) { errmsg("Destination record is in use"); } else if (yes_no((char *)"Proceed move")) { CFG.aka[too -1].zone = CFG.aka[from -1].zone; CFG.aka[too -1].net = CFG.aka[from -1].net; CFG.aka[too -1].node = CFG.aka[from -1].node; CFG.aka[too -1].point = CFG.aka[from -1].point; strcpy(CFG.aka[too -1].domain, CFG.aka[from -1].domain); CFG.akavalid[too -1] = TRUE; CFG.akavalid[from -1] = FALSE; memset(&CFG.aka[from -1], 0, sizeof(fidoaddr)); } } if ((atoi(pick) >= 1) && (atoi(pick) <= 40)) e_aka(atoi(pick)-1); } } void s_mailer(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.17 EDIT MAILER SETTINGS"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Mailer logl."); mvprintw( 8, 2, "2. Default phone"); mvprintw( 9, 2, "3. TCP/IP flags"); mvprintw(10, 2, "4. Default speed"); mvprintw(11, 2, "5. Timeout reset"); mvprintw(12, 2, "6. Timeout connect"); mvprintw(13, 2, "7. Dial delay"); mvprintw(14, 2, "8. No Filerequests"); mvprintw(15, 2, "9. No callout"); mvprintw(16, 2, "10. No EMSI session"); mvprintw(17, 2, "11. No Yooho/2U2"); mvprintw(12,31, "12. No Zmodem"); mvprintw(13,31, "13. No Zedzap"); mvprintw(14,31, "14. No Hydra"); mvprintw(15,31, "15. No IBN binkp"); mvprintw(16,31, "16. No IFC ifcico"); mvprintw(17,31, "17. No ITN telnet"); mvprintw(12,59, "18. Phonetrans 1-10"); mvprintw(13,59, "19. Phonetrans 11-20"); mvprintw(14,59, "20. Phonetrans 21-30"); mvprintw(15,59, "21. Phonetrans 31-40"); mvprintw(16,59, "22. Max. files"); mvprintw(17,59, "23. Max. MB."); } void e_trans(int start) { int i, j; char temp[21]; clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1.17 EDIT PHONE TRANSLATION"); set_color(CYAN, BLACK); mvprintw( 7, 12, "String to match String to replace"); for (i = 0; i < 10; i++) { sprintf(temp, "%2d.", i+1); mvprintw( 9+i, 6, temp); } for (;;) { set_color(WHITE, BLACK); for (i = 0; i < 10; i++) { show_str( 9+i,12,20,CFG.phonetrans[i+start].match); show_str( 9+i,34,20,CFG.phonetrans[i+start].repl); } j = select_menu(10); if (j == 0) { s_mailer(); return; } strcpy(CFG.phonetrans[j+start-1].match, edit_str(j+8,12,20, CFG.phonetrans[j+start-1].match, (char *)"The phone entry to ^match^")); strcpy(CFG.phonetrans[j+start-1].repl, edit_str(j+8,34,20, CFG.phonetrans[j+start-1].repl, (char *)"The phone string to ^replace^")); } } void e_mailer(void) { s_mailer(); for (;;) { set_color(WHITE, BLACK); show_logl( 7,23, CFG.cico_loglevel); show_str( 8,23,20,CFG.Phone); show_str( 9,23,30,CFG.Flags); show_int( 10,23, CFG.Speed); show_int( 11,23, CFG.timeoutreset); show_int( 12,23, CFG.timeoutconnect); show_int( 13,23, CFG.dialdelay); show_bool(14,23, CFG.NoFreqs); show_bool(15,23, CFG.NoCall); show_bool(16,23, CFG.NoEMSI); show_bool(17,23, CFG.NoWazoo); show_bool(12,52, CFG.NoZmodem); show_bool(13,52, CFG.NoZedzap); show_bool(14,52, CFG.NoHydra); show_bool(15,52, CFG.NoIBN); show_bool(16,52, CFG.NoIFC); show_bool(17,52, CFG.NoITN); show_int( 16,75, CFG.Req_Files); show_int( 17,75, CFG.Req_MBytes); switch(select_menu(23)) { case 0: return; case 1: E_LOGL(CFG.cico_loglevel, "1.17.1", s_mailer) case 2: E_STR( 8,23,20,CFG.Phone, "The mailer default ^phone number^ for this system") case 3: E_STR( 9,23,30,CFG.Flags, "The mailer ^TCP/IP capability flags^ for this system") case 4: E_INT( 10,23, CFG.Speed, "The mailer ^default linespeed^ for this system") case 5: E_INT( 11,23, CFG.timeoutreset, "The modem ^reset timeout^ in seconds") case 6: E_INT( 12,23, CFG.timeoutconnect, "The modem ^wait for connect timeout^ in seconds") case 7: E_INT( 13,23, CFG.dialdelay, "The ^random dialdelay^ in seconds ((^n^ <= delay) and (^n^ > (delay / 10)))") case 8: E_BOOL(14,23, CFG.NoFreqs, "Set to true if ^No Filerequests^ are allowed") case 9: E_BOOL(15,23, CFG.NoCall, "Set to true if ^No Calls^ are allowed") case 10:E_BOOL(16,23, CFG.NoEMSI, "If set then ^EMSI handshake^ is diabled") case 11:E_BOOL(17,23, CFG.NoWazoo, "If set then ^YooHoo/2U2^ (FTSC-0006) is disabled") case 12:E_BOOL(12,52, CFG.NoZmodem, "If set then the ^Zmodem^ protocol is disabled") case 13:E_BOOL(13,52, CFG.NoZedzap, "If set then the ^Zedzap^ protocol is disabled") case 14:E_BOOL(14,52, CFG.NoHydra, "If set then the ^Hydra^ protocol is disabled") case 15:E_BOOL(15,52, CFG.NoIBN, "If set then the ^TCP/IP IBN binkp^ protocol is disabled") case 16:E_BOOL(16,52, CFG.NoIFC, "If set then the ^TCP/IP IFC ifcico^ protocol is disabled") case 17:E_BOOL(17,52, CFG.NoITN, "If set then the ^TCP/IP ITN telnet^ protocol is disabled") case 18:e_trans(0); break; case 19:e_trans(10); break; case 20:e_trans(20); break; case 21:e_trans(30); break; case 22:E_INT(16,75, CFG.Req_Files, "Maximum ^files^ to request, 0 is unlimited") case 23:E_INT(17,75, CFG.Req_MBytes, "Maximum ^MBytes^ to request, 0 is unlimited") } }; } void e_ftpd(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.18 EDIT FTPD SETTINGS"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Upload pth"); mvprintw( 8, 2, "2. Banner msg"); mvprintw( 9, 2, "3. Pth filter"); mvprintw(10, 2, "4. Pth msg"); mvprintw(11, 2, "5. Email addr"); mvprintw(12, 2, "6. Shutdown"); mvprintw(13, 2, "7. Rdm login"); mvprintw(14, 2, "8. Rdm cwd*"); mvprintw(15, 2, "9. Msg login"); mvprintw(16, 1,"10. Msg cwd*"); mvprintw(17, 1,"11. Userslimit"); mvprintw(18, 1,"12. Loginfails"); mvprintw(13,60,"13. Compress"); mvprintw(14,60,"14. Tar"); mvprintw(15,60,"15. Mkdir ok"); mvprintw(16,60,"16. Log cmds"); mvprintw(17,60,"17. Anonymous"); mvprintw(18,60,"18. User mbse"); set_color(WHITE, BLACK); show_str( 7,18,59, CFG.ftp_upl_path); show_str( 8,18,59, CFG.ftp_banner); show_str( 9,18,40, CFG.ftp_pth_filter); show_str(10,18,59, CFG.ftp_pth_message); show_str(11,18,40, CFG.ftp_email); show_str(12,18,40, CFG.ftp_msg_shutmsg); show_str(13,18,20, CFG.ftp_readme_login); show_str(14,18,20, CFG.ftp_readme_cwd); show_str(15,18,20, CFG.ftp_msg_login); show_str(16,18,20, CFG.ftp_msg_cwd); show_int(17,18, CFG.ftp_limit); show_int(18,18, CFG.ftp_loginfails); show_bool(13,75, CFG.ftp_compress); show_bool(14,75, CFG.ftp_tar); show_bool(15,75, CFG.ftp_upl_mkdir); show_bool(16,75, CFG.ftp_log_cmds); show_bool(17,75, CFG.ftp_anonymousok); show_bool(18,75, CFG.ftp_mbseok); for (;;) { set_color(WHITE, BLACK); switch(select_menu(18)) { case 0: return; case 1: E_STR( 7,18,59, CFG.ftp_upl_path, "Public ^upload^ path, must be in the base path") case 2: E_STR( 8,18,59, CFG.ftp_banner, "^Banner^ file to show before login") case 3: E_STR( 9,18,40, CFG.ftp_pth_filter, "^Filter^ with allowed characters in upload filename") case 4: E_STR(10,18,59, CFG.ftp_pth_message, "^Message^ to display if illegal characters in filename") case 5: E_STR(11,18,40, CFG.ftp_email, "^Email^ address of the ftp server administrator") case 6: E_STR(12,18,40, CFG.ftp_msg_shutmsg, "^Shutdown message^, if this file is present, login if forbidden") case 7: E_STR(13,18,20, CFG.ftp_readme_login,"^README^ file to display at login") case 8: E_STR(14,18,20, CFG.ftp_readme_cwd, "^README^ file to display when entering a new directory") case 9: E_STR(15,18,20, CFG.ftp_msg_login, "^Message^ file to display at login") case 10:E_STR(16,18,20, CFG.ftp_msg_cwd, "^Message^ file to display when entering a new directory") case 11:E_INT(17,18, CFG.ftp_limit, "^Limit^ the number of concurent ftp users") case 12:E_INT(18,18, CFG.ftp_loginfails, "Maximum ^login fails^ before a user is disconnected") case 13:E_BOOL(13,75, CFG.ftp_compress, "Allow the use of the ^compress^ command") case 14:E_BOOL(14,75, CFG.ftp_tar, "Allow the use if the ^tar^ command") case 15:E_BOOL(15,75, CFG.ftp_upl_mkdir, "Allow ^mkdir^ in the upload directory") case 16:E_BOOL(16,75, CFG.ftp_log_cmds, "^Log^ all user ^commands^") case 17:E_BOOL(17,75, CFG.ftp_anonymousok, "Allow ^anonymous^ users to login") case 18:E_BOOL(18,75, CFG.ftp_mbseok, "Allow the ^mbse^ user to login") } }; } void e_html(void) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 2, "1.19 EDIT HTML SETTINGS"); set_color(CYAN, BLACK); mvprintw( 7, 2, "1. Docs root"); mvprintw( 8, 2, "2. Link to ftp"); mvprintw( 9, 2, "3. URL name"); mvprintw(10, 2, "4. Charset"); mvprintw(11, 2, "5. Author name"); mvprintw(12, 2, "6. Convert cmd"); mvprintw(13, 2, "7. Files/page"); set_color(WHITE, BLACK); show_str( 7,18,59, CFG.www_root); show_str( 8,18,20, CFG.www_link2ftp); show_str( 9,18,40, CFG.www_url); show_str(10,18,20, CFG.www_charset); show_str(11,18,40, CFG.www_author); show_str(12,18,59, CFG.www_convert); show_int(13,18, CFG.www_files_page); for (;;) { set_color(WHITE, BLACK); switch(select_menu(7)) { case 0: return; case 1: E_STR( 7,18,59, CFG.www_root, "The ^Document root^ of your http server") case 2: E_STR( 8,18,20, CFG.www_link2ftp, "The ^link^ name from the Document root to the FTP base directory") case 3: E_STR( 9,18,40, CFG.www_url, "The ^URL^ name of your http server") case 4: E_STR(10,18,20, CFG.www_charset, "The ^ISO character set^ name to include in the web pages") case 5: E_STR(11,18,40, CFG.www_author, "The ^Author name^ to include in the http headers") case 6: E_STR(12,18,59, CFG.www_convert, "The ^convert^ command to create thumbnails") case 7: E_INT(13,18, CFG.www_files_page, "The number of files on each web page") } }; } void global_menu(void) { unsigned long crc, crc1; int i; if (! check_free()) return; if (cf_open() == -1) return; Syslog('+', "Opened main config"); crc = 0xffffffff; crc = upd_crc32((char *)&CFG, crc, sizeof(CFG)); if (CFG.xmax_login) { /* * Do automatic upgrade for unused fields, erase them. */ Syslog('+', "Main config, clearing unused fields"); memset(&CFG.alists_path, 0, sizeof(CFG.alists_path)); CFG.xmax_login = 0; CFG.xUseSysDomain = FALSE; CFG.xChkMail = FALSE; memset(&CFG.xquotestr, 0, sizeof(CFG.xquotestr)); CFG.xNewBytes = FALSE; memset(&CFG.extra4, 0, sizeof(CFG.extra4)); memset(&CFG.xmgrname, 0, sizeof(CFG.xmgrname)); memset(&CFG.xtoss_log, 0, sizeof(CFG.xtoss_log)); memset(&CFG.xareamgr, 0, sizeof(CFG.xareamgr)); CFG.xNoJanus = FALSE; memset(&CFG.extra5, 0, sizeof(CFG.extra5)); sprintf(CFG.alists_path, "%s/var/arealists", getenv("MBSE_ROOT")); } if (strlen(CFG.bbs_macros) == 0) { sprintf(CFG.bbs_macros, "%s/english/macro", getenv("MBSE_ROOT")); Syslog('+', "Main config, upgraded default macro path"); } if (strlen(CFG.out_queue) == 0) { sprintf(CFG.out_queue, "%s/var/queue", getenv("MBSE_ROOT")); Syslog('+', "Main config, upgraded for new queue"); } if (strlen(CFG.mgrlog) == 0) { sprintf(CFG.mgrlog, "manager.log"); for (i = 0; i < 32; i++) sprintf(CFG.aname[i], "Flags %d", i+1); sprintf(CFG.aname[0], "Everyone"); Syslog('+', "Main config, upgraded for manager security"); } for (;;) { clr_index(); set_color(WHITE, BLACK); mvprintw( 5, 6, "1. GLOBAL SETUP"); set_color(CYAN, BLACK); mvprintw( 7, 6, "1. Edit Fidonet Aka's"); mvprintw( 8, 6, "2. Edit Registration Info"); mvprintw( 9, 6, "3. Edit Global Filenames"); mvprintw(10, 6, "4. Edit Global Paths"); mvprintw(11, 6, "5. Edit Global Settings"); mvprintw(12, 6, "6. Edit User flag Descriptions"); mvprintw(13, 6, "7. Edit New Users defaults"); mvprintw(14, 6, "8. Edit Text Colors"); mvprintw(15, 6, "9. Edit Next User Door"); mvprintw(16, 6, "10. Edit Safe Door"); mvprintw( 7,46, "11. Edit Time Bank Door"); mvprintw( 8,46, "12. Edit Sysop Paging"); mvprintw( 9,46, "13. Edit Files Processing"); mvprintw(10,46, "14. Edit Fidonet Mail/Echomail"); mvprintw(11,46, "15. Edit Internet Mail/News"); mvprintw(12,46, "16. Edit All-/Newfiles lists"); mvprintw(13,46, "17. Edit Mailer global setup"); mvprintw(14,46, "18. Edit Ftp daemon setup"); mvprintw(15,46, "19. Edit HTML pages setup"); mvprintw(16,46, "20. Edit Mgr flag descriptions"); switch(select_menu(20)) { case 0: crc1 = 0xffffffff; crc1 = upd_crc32((char *)&CFG, crc1, sizeof(CFG)); if (crc != crc1) { if (yes_no((char *)"Configuration is changed, save") == 1) { cf_close(); Syslog('+', "Saved main config"); } } open_bbs(); return; case 1: e_fidoakas(); break; case 2: e_reginfo(); break; case 3: e_filenames(); break; case 4: e_global(); break; case 5: e_bbsglob(); break; case 6: e_flags(TRUE); break; case 7: e_newuser(); break; case 8: e_colors(); break; case 9: e_nu_door(); break; case 10: e_safe_door(); break; case 11: e_timebank(); break; case 12: e_paging(); break; case 13: e_ticconf(); break; case 14: e_fidomailcfg(); break; case 15: e_intmailcfg(); break; case 16: e_newfiles(); break; case 17: e_mailer(); break; case 18: e_ftpd(); break; case 19: e_html(); break; case 20: e_flags(FALSE); break; } } } int PickAka(char *msg, int openit) { char temp[81]; static char pick[12]; int i, o = 0, x, y; if (openit) { if (cf_open() == -1) return -1; cf_close(); } for (;;) { clr_index(); set_color(WHITE, BLACK); sprintf(temp, "%s. AKA SELECT", msg); mvprintw( 5, 4, temp); set_color(CYAN, BLACK); x = 2; y = 7; for (i = 1; i <= 20; i++) { if (i == 11) { x = 42; y = 7; } if ((o + i) <= 40) { if (CFG.akavalid[o+i-1]) { set_color(CYAN, BLACK); sprintf(temp, "%3d %s", o+i, aka2str(CFG.aka[o+i-1])); temp[38] = '\0'; } else { set_color(LIGHTBLUE, BLACK); sprintf(temp, "%3d", o+i); } mvprintw(y, x, temp); y++; } } strcpy(pick, select_pick(40, 20)); if (strncmp(pick, "-", 1) == 0) return -1; if (strncmp(pick, "N", 1) == 0) if ((o + 20) < 40) o = o + 20; if (strncmp(pick, "P", 1) == 0) if ((o - 20) >= 0) o = o - 20; if ((atoi(pick) >= 1) && (atoi(pick) <= 40) && (CFG.akavalid[atoi(pick)-1])) return (atoi(pick) -1); } } int global_doc(FILE *fp, FILE *toc, int page) { int i, j; struct utsname utsbuf; time_t now; char *p; if (config_read()) return page; page = newpage(fp, page); addtoc(fp, toc, 1, 0, page, (char *)"Global system setup"); addtoc(fp, toc, 1, 1, page, (char *)"Host system information"); memset(&utsbuf, 0, sizeof(utsbuf)); if (uname(&utsbuf) == 0) { fprintf(fp, " Node name %s\n", utsbuf.nodename); #ifdef __USE_GNU fprintf(fp, " Domain name %s\n", utsbuf.domainname); #else #ifdef __linux__ fprintf(fp, " Domain name %s\n", utsbuf.__domainname); #endif #endif fprintf(fp, " Operating system %s %s\n", utsbuf.sysname, utsbuf.release); fprintf(fp, " Kernel version %s\n", utsbuf.version); fprintf(fp, " Machine type %s\n", utsbuf.machine); } fprintf(fp, " MBSE_ROOT %s\n", getenv("MBSE_ROOT")); now = time(NULL); fprintf(fp, " Date created %s", ctime(&now)); addtoc(fp, toc, 1, 2, page, (char *)"System fidonet addresses"); for (i = 0; i < 40; i++) if (CFG.akavalid[i]) fprintf(fp, " Aka %2d %s\n", i+1, aka2str(CFG.aka[i])); page = newpage(fp, page); addtoc(fp, toc, 1, 3, page, (char *)"Registration information"); fprintf(fp, " System name %s\n", CFG.bbs_name); fprintf(fp, " Domain name %s\n", CFG.sysdomain); fprintf(fp, " Sysop unix name %s\n", CFG.sysop); fprintf(fp, " Sysop fido name %s\n", CFG.sysop_name); fprintf(fp, " System location %s\n", CFG.location); fprintf(fp, " QWK/Bluewave id %s\n", CFG.bbsid); fprintf(fp, " Omen id %s\n", CFG.bbsid2); fprintf(fp, " Comment %s\n", CFG.comment); fprintf(fp, " Origin line %s\n", CFG.origin); fprintf(fp, " Start unix name %s\n", CFG.startname); addtoc(fp, toc, 1, 4, page, (char *)"Global filenames"); fprintf(fp, " System logfile %s\n", CFG.logfile); fprintf(fp, " Error logfile %s\n", CFG.error_log); fprintf(fp, " Manager logfile %s\n", CFG.mgrlog); fprintf(fp, " Default menu %s\n", CFG.default_menu); fprintf(fp, " Default language %s\n", CFG.current_language); fprintf(fp, " Chat logfile %s\n", CFG.chat_log); fprintf(fp, " Welcome logo %s\n", CFG.welcome_logo); addtoc(fp, toc, 1, 5, page, (char *)"Pathnames"); fprintf(fp, " Menufiles %s\n", CFG.bbs_menus); fprintf(fp, " Textfiles %s\n", CFG.bbs_txtfiles); fprintf(fp, " Macros %s\n", CFG.bbs_macros); fprintf(fp, " Users homedirs %s\n", CFG.bbs_usersdir); fprintf(fp, " Nodelists %s\n", CFG.nodelists); fprintf(fp, " Unsafe inbound %s\n", CFG.inbound); fprintf(fp, " Known inbound %s\n", CFG.pinbound); fprintf(fp, " Outbound %s\n", CFG.outbound); fprintf(fp, " Out queue %s\n", CFG.out_queue); fprintf(fp, " *.msgs path %s\n", CFG.msgs_path); fprintf(fp, " Bad TIC's %s\n", CFG.badtic); fprintf(fp, " TIC queue %s\n", CFG.ticout); fprintf(fp, " Magic filereq. %s\n", CFG.req_magic); fprintf(fp, " DOS path %s\n", CFG.dospath); fprintf(fp, " Unix path %s\n", CFG.uxpath); fprintf(fp, " Leave case as is %s\n", getboolean(CFG.leavecase)); fprintf(fp, " FTP base path %s\n", CFG.ftp_base); fprintf(fp, " Area lists %s\n", CFG.alists_path); fprintf(fp, " External editor %s\n", CFG.externaleditor); page = newpage(fp, page); addtoc(fp, toc, 1, 6, page, (char *)"Global settings"); fprintf(fp, " Show new msgarea %s\n", getboolean(CFG.NewAreas)); fprintf(fp, " Exclude sysop %s\n", getboolean(CFG.exclude_sysop)); fprintf(fp, " Show connect %s\n", getboolean(CFG.iConnectString)); fprintf(fp, " Ask protocols %s\n", getboolean(CFG.iAskFileProtocols)); fprintf(fp, " Sysop level %d\n", CFG.sysop_access); fprintf(fp, " Password length %d\n", CFG.password_length); p = getloglevel(CFG.bbs_loglevel); fprintf(fp, " BBS loglevel %s\n", p); free(p); p = getloglevel(CFG.util_loglevel); fprintf(fp, " Util loglevel %s\n", p); free(p); fprintf(fp, " Password char %c\n", CFG.iPasswd_Char); fprintf(fp, " Idle timeout %d mins\n", CFG.idleout); fprintf(fp, " Login enters %d\n", CFG.iCRLoginCount); fprintf(fp, " Homedir quota %d MB.\n", CFG.iQuota); fprintf(fp, " Location length %d\n", CFG.CityLen); fprintf(fp, " OLR Max. msgs. %d\n", CFG.OLR_MaxMsgs); fprintf(fp, " OLR Newfile days %d\n", CFG.OLR_NewFileLimit); fprintf(fp, " OLR Max Freq's %d\n", CFG.OLR_MaxReq); fprintf(fp, " Slow utilities %s\n", getboolean(CFG.slow_util)); fprintf(fp, " CrashMail level %d\n", CFG.iCrashLevel); fprintf(fp, " FileAttach level %d\n", CFG.iAttachLevel); fprintf(fp, " Free diskspace %d MB.\n", CFG.freespace); page = newpage(fp, page); addtoc(fp, toc, 1, 7, page, (char *)"Users flag descriptions"); fprintf(fp, " 1 1 2 2 3 3\n"); fprintf(fp, " 1 5 0 5 0 5 0 2\n"); fprintf(fp, " --------------------------------\n"); fprintf(fp, " ||||||||||||||||||||||||||||||||\n"); for (i = 0; i < 32; i++) { fprintf(fp, " "); for (j = 0; j < (31 - i); j++) fprintf(fp, "|"); fprintf(fp, "+"); for (j = (32 - i); j < 32; j++) fprintf(fp, "-"); fprintf(fp, " %s\n", CFG.fname[31 - i]); } page = newpage(fp, page); addtoc(fp, toc, 1, 8, page, (char *)"New users defaults"); fprintf(fp, " Access level %s\n", get_secstr(CFG.newuser_access)); fprintf(fp, " Cap. username %s\n", getboolean(CFG.iCapUserName)); fprintf(fp, " Ask ANSI %s\n", getboolean(CFG.iAnsi)); fprintf(fp, " Ask Sex %s\n", getboolean(CFG.iSex)); fprintf(fp, " Ask voicephone %s\n", getboolean(CFG.iVoicePhone)); fprintf(fp, " Ask dataphone %s\n", getboolean(CFG.iDataPhone)); fprintf(fp, " Telephone scan %s\n", getboolean(CFG.iTelephoneScan)); fprintf(fp, " Ask handle %s\n", getboolean(CFG.iHandle)); fprintf(fp, " Ask birthdate %s\n", getboolean(CFG.iDOB)); fprintf(fp, " Ask location %s\n", getboolean(CFG.iLocation)); fprintf(fp, " Ask hotkeys %s\n", getboolean(CFG.iHotkeys)); fprintf(fp, " One word names %s\n", getboolean(CFG.iOneName)); fprintf(fp, " Ask address %s\n", getboolean(CFG.AskAddress)); fprintf(fp, " Give email box %s\n", getboolean(CFG.GiveEmail)); addtoc(fp, toc, 1, 9, page, (char *)"Text colors"); fprintf(fp, " Normal text %s on %s\n", get_color(CFG.TextColourF), get_color(CFG.TextColourB)); fprintf(fp, " Underline text %s on %s\n", get_color(CFG.UnderlineColourF), get_color(CFG.UnderlineColourB)); fprintf(fp, " Input text %s on %s\n", get_color(CFG.InputColourF), get_color(CFG.InputColourB)); fprintf(fp, " CR text %s on %s\n", get_color(CFG.CRColourF), get_color(CFG.CRColourB)); fprintf(fp, " More prompt %s on %s\n", get_color(CFG.MoreF), get_color(CFG.MoreB)); fprintf(fp, " Hilite text %s on %s\n", get_color(CFG.HiliteF), get_color(CFG.HiliteB)); fprintf(fp, " File name %s on %s\n", get_color(CFG.FilenameF), get_color(CFG.FilenameB)); fprintf(fp, " File size %s on %s\n", get_color(CFG.FilesizeF), get_color(CFG.FilesizeB)); fprintf(fp, " File date %s on %s\n", get_color(CFG.FiledateF), get_color(CFG.FiledateB)); fprintf(fp, " File description %s on %s\n", get_color(CFG.FiledescF), get_color(CFG.FiledescB)); fprintf(fp, " Message input %s on %s\n", get_color(CFG.MsgInputColourF), get_color(CFG.MsgInputColourB)); addtoc(fp, toc, 1, 10, page, (char *)"Next user door"); fprintf(fp, " Text file %s\n", CFG.sNuScreen); fprintf(fp, " Quote %s\n", CFG.sNuQuote); addtoc(fp, toc, 1, 11, page, (char *)"Safecracker door"); fprintf(fp, " Digit nr 1 %d\n", CFG.iSafeFirstDigit); fprintf(fp, " Digit nr 2 %d\n", CFG.iSafeSecondDigit); fprintf(fp, " Digit nr 3 %d\n", CFG.iSafeThirdDigit); fprintf(fp, " Maximum tries %d\n", CFG.iSafeMaxTrys); fprintf(fp, " Maximum number %d\n", CFG.iSafeMaxNumber); fprintf(fp, " Show generator %s\n", getboolean(CFG.iSafeNumGen)); fprintf(fp, " Prize %s\n", CFG.sSafePrize); fprintf(fp, " Safe welcome %s\n", CFG.sSafeWelcome); fprintf(fp, " Safe opened file %s\n", CFG.sSafeOpened); page = newpage(fp, page); addtoc(fp, toc, 1, 12, page, (char *)"Timebank door"); fprintf(fp, " Users time balance %d\n", CFG.iMaxTimeBalance); fprintf(fp, " Max. time withdraw %d\n", CFG.iMaxTimeWithdraw); fprintf(fp, " Max. time deposit %d\n", CFG.iMaxTimeDeposit); fprintf(fp, " Users kb. balance %d\n", CFG.iMaxByteBalance); fprintf(fp, " Max. Kb. withdraw %d\n", CFG.iMaxByteWithdraw); fprintf(fp, " Max. Kb. deposit %d\n", CFG.iMaxByteDeposit); fprintf(fp, " Users time ratio %s\n", CFG.sTimeRatio); fprintf(fp, " Users Kb. ratio %s\n", CFG.sByteRatio); addtoc(fp, toc, 1, 13, page, (char *)"Sysop paging"); fprintf(fp, " Ext. Chat program %s\n", CFG.sExternalChat); fprintf(fp, " Chat device %s\n", CFG.sChatDevice); fprintf(fp, " Call sysop script %s\n", CFG.sCallScript); fprintf(fp, " Page length %d seconds\n", CFG.iPageLength); fprintf(fp, " Page times %d\n", CFG.iMaxPageTimes); fprintf(fp, " Sysop msg area %d\n", CFG.iSysopArea); fprintf(fp, " Ask chat reason %s\n", getboolean(CFG.iAskReason)); fprintf(fp, " Use external chat %s\n", getboolean(CFG.iExternalChat)); fprintf(fp, " Log chat %s\n", getboolean(CFG.iAutoLog)); fprintf(fp, " Check at prompt %s\n", getboolean(CFG.iChatPromptChk)); fprintf(fp, " Freeze online time %s\n", getboolean(CFG.iStopChatTime)); fprintf(fp, "\n Weekday Start Stop\n"); fprintf(fp, " ------------- ----- -----\n"); fprintf(fp, " Sunday %s %s\n", CFG.cStartTime[0], CFG.cStopTime[0]); fprintf(fp, " Monday %s %s\n", CFG.cStartTime[1], CFG.cStopTime[1]); fprintf(fp, " Tuesday %s %s\n", CFG.cStartTime[2], CFG.cStopTime[2]); fprintf(fp, " Wednesday %s %s\n", CFG.cStartTime[3], CFG.cStopTime[3]); fprintf(fp, " Thursday %s %s\n", CFG.cStartTime[4], CFG.cStopTime[4]); fprintf(fp, " Friday %s %s\n", CFG.cStartTime[5], CFG.cStopTime[5]); fprintf(fp, " Saterday %s %s\n", CFG.cStartTime[6], CFG.cStopTime[6]); addtoc(fp, toc, 1, 14, page, (char *)"Fileecho processing"); fprintf(fp, " Keep days on hold %d\n", CFG.tic_days); fprintf(fp, " Hatch password %s\n", CFG.hatchpasswd); fprintf(fp, " Free drivespave %lu\n", CFG.drspace); fprintf(fp, " Max. systems %ld\n", CFG.tic_systems); fprintf(fp, " Max. groups %ld\n", CFG.tic_groups); fprintf(fp, " Max. dupes %ld\n", CFG.tic_dupes); fprintf(fp, " Keep filedate %s\n", getboolean(CFG.ct_KeepDate)); fprintf(fp, " Keep mgr netmail %s\n", getboolean(CFG.ct_KeepMgr)); fprintf(fp, " Reset future dates %s\n", getboolean(CFG.ct_ResFuture)); fprintf(fp, " Local requests %s\n", getboolean(CFG.ct_LocalRep)); fprintf(fp, " Replace extention %s\n", getboolean(CFG.ct_ReplExt)); fprintf(fp, " Areamgr: allow +%%* %s\n", getboolean(CFG.ct_PlusAll)); fprintf(fp, " Areamgr: notify %s\n", getboolean(CFG.ct_Notify)); fprintf(fp, " Areamgr: passwd %s\n", getboolean(CFG.ct_Passwd)); fprintf(fp, " Areamgr: message %s\n", getboolean(CFG.ct_Message)); fprintf(fp, " Areamgr: TIC %s\n", getboolean(CFG.ct_TIC)); fprintf(fp, " Areamgr: pause %s\n", getboolean(CFG.ct_Pause)); page = newpage(fp, page); addtoc(fp, toc, 1, 15, page, (char *)"Fidonet Mail and Echomail processing"); fprintf(fp, " Max .pkt size %d Kb.\n", CFG.maxpktsize); fprintf(fp, " Max archive size %d Kb.\n", CFG.maxarcsize); fprintf(fp, " Bad mail board %s\n", CFG.badboard); fprintf(fp, " Dupe mail board %s\n", CFG.dupboard); fprintf(fp, " Pktdate program %s\n", CFG.pktdate); fprintf(fp, " Keep on hold %d days\n", CFG.toss_days); fprintf(fp, " Dupes in database %d\n", CFG.toss_dupes); fprintf(fp, " Default max msgs %d\n", CFG.defmsgs); fprintf(fp, " Default days %d\n", CFG.defdays); fprintf(fp, " Reject older then %d days\n", CFG.toss_old); fprintf(fp, " Maximum systems %ld\n", CFG.toss_systems); fprintf(fp, " Maximum groups %ld\n", CFG.toss_groups); fprintf(fp, " Use 4d addressing %s\n", getboolean(CFG.addr4d)); addtoc(fp, toc, 1, 16, page, (char *)"Internet Mail and News processing"); fprintf(fp, " Split messages at %d KBytes\n", CFG.new_split); fprintf(fp, " Force split at %d KBytes\n", CFG.new_force); fprintf(fp, " ISP Email Mode %s\n", getemailmode(CFG.EmailMode)); fprintf(fp, " Email fido aka %s\n", aka2str(CFG.EmailFidoAka)); fprintf(fp, " UUCP gateway %s\n", aka2str(CFG.UUCPgate)); fprintf(fp, " POP3 host %s\n", CFG.popnode); fprintf(fp, " SMTP host %s\n", CFG.smtpnode); fprintf(fp, " News transfermode %s\n", getnewsmode(CFG.newsfeed)); switch (CFG.newsfeed) { case FEEDINN: fprintf(fp, " NNTP host %s\n", CFG.nntpnode); fprintf(fp, " NNTP mode reader %s\n", getboolean(CFG.modereader)); fprintf(fp, " NNTP username %s\n", CFG.nntpuser); fprintf(fp, " NNTP password %s\n", getboolean(strlen(CFG.nntppass))); break; case FEEDRNEWS: fprintf(fp, " Path to rnews %s\n", CFG.rnewspath); break; case FEEDUUCP: fprintf(fp, " NNTP host %s\n", CFG.nntpnode); fprintf(fp, " Path to rnews %s\n", CFG.rnewspath); break; } fprintf(fp, " Max articles fetch %d\n", CFG.maxarticles); fprintf(fp, " Allow control msgs %s\n", getboolean(CFG.allowcontrol)); fprintf(fp, " Don't regate msgs %s\n", getboolean(CFG.dontregate)); addtoc(fp, toc, 1, 17, page, (char *)"Newfile reports"); fprintf(fp, " New files days %d\n", CFG.newdays); fprintf(fp, " Highest sec. level %s\n", get_secstr(CFG.security)); fprintf(fp, " Max. newfile grps %ld\n", CFG.new_groups); page = newpage(fp, page); addtoc(fp, toc, 1, 18, page, (char *)"Mailer setup"); p = getloglevel(CFG.cico_loglevel); fprintf(fp, " Mailer loglevel %s\n", p); free(p); fprintf(fp, " Res. modem timeout %ld\n", CFG.timeoutreset); fprintf(fp, " Connect timeout %ld\n", CFG.timeoutconnect); fprintf(fp, " Random dialdelay %ld\n", CFG.dialdelay); fprintf(fp, " Default phone nr. %s\n", CFG.Phone); fprintf(fp, " Default speed %lu\n", CFG.Speed); fprintf(fp, " TCP/IP flags %s\n", CFG.Flags); fprintf(fp, " No Filerequests %s\n", getboolean(CFG.NoFreqs)); fprintf(fp, " No Calls %s\n", getboolean(CFG.NoCall)); fprintf(fp, " No EMSI %s\n", getboolean(CFG.NoEMSI)); fprintf(fp, " No YooHoo/2U2 %s\n", getboolean(CFG.NoWazoo)); fprintf(fp, " No Zmodem %s\n", getboolean(CFG.NoZmodem)); fprintf(fp, " No Zedzap %s\n", getboolean(CFG.NoZedzap)); fprintf(fp, " No Hydra %s\n", getboolean(CFG.NoHydra)); fprintf(fp, " No TCP/IP IBN %s\n", getboolean(CFG.NoIBN)); fprintf(fp, " No TCP/IP IFC %s\n", getboolean(CFG.NoIFC)); fprintf(fp, " No TCP/IP ITN %s\n", getboolean(CFG.NoITN)); fprintf(fp, " Max request files %d\n", CFG.Req_Files); fprintf(fp, " Max request MBytes %d\n", CFG.Req_MBytes); for (i = 0; i < 40; i++) if ((CFG.phonetrans[i].match[0] != '\0') || (CFG.phonetrans[i].repl[0] != '\0')) fprintf(fp, " Translate %-20s %s\n", CFG.phonetrans[i].match, CFG.phonetrans[i].repl); page = newpage(fp, page); addtoc(fp, toc, 1, 19, page, (char *)"FTP server setup"); fprintf(fp, " Connections limit %d\n", CFG.ftp_limit); fprintf(fp, " Login fails %d\n", CFG.ftp_loginfails); fprintf(fp, " Allow compress %s\n", getboolean(CFG.ftp_compress)); fprintf(fp, " Allow tar %s\n", getboolean(CFG.ftp_tar)); fprintf(fp, " Log commands %s\n", getboolean(CFG.ftp_log_cmds)); fprintf(fp, " Anonymous login %s\n", getboolean(CFG.ftp_anonymousok)); fprintf(fp, " User mbse login %s\n", getboolean(CFG.ftp_mbseok)); fprintf(fp, " Shutdown message %s\n", CFG.ftp_msg_shutmsg); fprintf(fp, " Upload path %s\n", CFG.ftp_upl_path); fprintf(fp, " README login %s\n", CFG.ftp_readme_login); fprintf(fp, " README cwd* %s\n", CFG.ftp_readme_cwd); fprintf(fp, " Message login %s\n", CFG.ftp_msg_login); fprintf(fp, " Message cwd* %s\n", CFG.ftp_msg_cwd); fprintf(fp, " Login banner %s\n", CFG.ftp_banner); fprintf(fp, " Email address %s\n", CFG.ftp_email); fprintf(fp, " Path filter %s\n", CFG.ftp_pth_filter); fprintf(fp, " Path message %s\n", CFG.ftp_pth_message); addtoc(fp, toc, 1, 20, page, (char *)"WWW server setup"); fprintf(fp, " HTML root %s\n", CFG.www_root); fprintf(fp, " Link to FTP base %s\n", CFG.www_link2ftp); fprintf(fp, " Webserver URL %s\n", CFG.www_url); fprintf(fp, " Character set %s\n", CFG.www_charset); fprintf(fp, " Author name %s\n", CFG.www_author); fprintf(fp, " Convert command %s\n", CFG.www_convert); fprintf(fp, " File per webpage %d\n", CFG.www_files_page); page = newpage(fp, page); addtoc(fp, toc, 1,21, page, (char *)"Manager flag descriptions"); fprintf(fp, " 1 1 2 2 3 3\n"); fprintf(fp, " 1 5 0 5 0 5 0 2\n"); fprintf(fp, " --------------------------------\n"); fprintf(fp, " ||||||||||||||||||||||||||||||||\n"); for (i = 0; i < 32; i++) { fprintf(fp, " "); for (j = 0; j < (31 - i); j++) fprintf(fp, "|"); fprintf(fp, "+"); for (j = (32 - i); j < 32; j++) fprintf(fp, "-"); fprintf(fp, " %s\n", CFG.aname[31 - i]); } return page; }