home *** CD-ROM | disk | FTP | other *** search
/ Amiga Elysian Archive / AmigaElysianArchive.iso / comm / c342e19.lha / 68k.man next >
Text File  |  1992-08-30  |  63KB  |  1,268 lines

  1. Citadel-68K System Related Notes
  2. ---------------------------------
  3.  
  4.    The Citadel-86 documentation is generally applicable to Citadel-68K for
  5. the Amiga.  However, there are some features which the Citadel-68k
  6. do not supported, Some will eventually be worked on, and other may never
  7. get done.
  8.  
  9.    In general you can get help on Citadel 68K by calling one of the following
  10. Citadels:
  11.  
  12.    The Amiga Zone:  609-953-8159
  13.    Images           612-884-7951
  14.    Full Circle      612-827-3214
  15.    C-86 Test System 612-470-9635
  16.  
  17. You also can call most any local Citadel and post messages in the Citadel 68K
  18. room or the Amiga room.  Both rooms are netted to the Amiga Zone and will
  19. eventually reach me.  I have spent a fair amount of time on this document,
  20. cannot guarentee everything...  If you find an error, please let me know.
  21.  
  22. I suggest that if you are thinking of starting a Citadel BBS, you should
  23. first become familar with a local sysop of a Citadel BBS.  Next, get a
  24. separate phone line for the BBS alone.  If you run a BBS and it is not a
  25. 24 Hour BBS, you will find few callers.  Next, decide what kind of theme
  26. your BBS will have.  A theme will attract callers.  Now, you need to see
  27. if you have the resources to run a BBS.  I have seen big systems and small
  28. run Citadel.  2 floppies plus 1 MB memory is barely enough to survive.
  29. Since the Amiga multitasks, you can do other things while the BBS is
  30. running.  I would recommend a minimum of 2 megabyte of memory plus at
  31. least 3 floppies or a hard drive.  You can run a Citadel on less, but
  32. probably will not last long with only a few messages and rooms.  I would
  33. recommend 2 MB of memory and a 20 MB HD to most Citadels as the "normal"
  34. configuration.  I have 7 MB of RAM and 112 MB of Hard drive.  The more
  35. memory the better, I get problem reports from people with the "minimum"
  36. RAM that I truely think are due to lack of memory.
  37.  
  38. Lastly, get the lastest Citadel, Documenation files and spend about a week
  39. reading this and the other Citadel documenation.  You will be confuse and
  40. probably will not understand most of it.  Now take the ctdlcnfg.sys from
  41. the archive(if you did not find one in your archive, get the real thing
  42. from one of the systems above) and change the appropriate parameters.
  43. Set things up and go on the air.  Once you have had a few callers, been
  44. working on your BBS and feel confortable with it's operation, check with
  45. local citadel sysops and connect up to the network.  You will have to find
  46. out who is the "local feed" in your area, just ask any sysop.  Make your
  47. arrangements and changes to the ctdlcnfg.sys and you will be connected
  48. coast to coast.  I suggest that you make an attempt to get the Amiga and
  49. Citadel 68K rooms shared with your system.  I and other Sysops will post
  50. information on upgrades and problems.  Remember, Every Sysop was in your
  51. shoes at one time or another.  We all started out the same way.  We are
  52. all pretty much a friendly bunch(no matter how much we argue on the net!)
  53. and are glad to help.  When you connect up to either room, place what
  54. is called a seed message telling everyone who you are,where you are
  55. located, and your Node ID.  You might be surprised who might give you a
  56. call(me for one!)....  Good Luck!
  57.  
  58. INSTALL3.MAN
  59. ------------
  60.  o Later on in this manual is a list of some of the parameters that you
  61.    can control.  All the configuration parameters are documented either in
  62.    the INSTALL3.MAN or later in here.
  63.  
  64.  o Ignore all references to the EASE utility.  Currently, the only Amiga
  65.    Ease program that exists does not work.  It has been given low priority
  66.    over other things.  I am creating an Amigatized version that will make
  67.    it very easy to configure your system.  Check on the Amiga Zone for
  68.    possible demo or crippleware versions.
  69.  
  70.  o Ignore references to supported machines and operating systems.
  71.    Citadel-68k is for the Amiga line of products.
  72.  
  73.  o Ignore references to DOS configuration.  INSTEAD -- you must make sure
  74.    you have STACK 65000 in your Amiga setup.  More it better, If you have
  75.    the memory, use it.  I set my stack to 65K and have had no problems.
  76.    CTDL checks for a minimum of 65000.   CONFG does not check(nor do the
  77.    utilities).  I recommend a 30K stack for them.
  78.  
  79.  o Section II.6.b -- when specifying directories for system data files (like
  80.    #MSGAREA, etc.), you may use either relative or absolute directory
  81.    specifications, rather than being constricted to subdirectories of the
  82.    current directory.  Use standard AmigaDos file and pathnames.
  83.  
  84.  o Parameters not supported in Citadel 68K
  85.  
  86.    #IBM                 #COM           #OLDVIDEO
  87.    #FOREGROUND          #BACKGROUND    #STATUS-FOREGROUND
  88.    #STATUS-BACKGROUND   #SEARCHBAUD
  89.  
  90.  o Ignore Sections II.10.b, II.10.c, II.10.d.1, II.10.e (especially!), and
  91.    Section III.
  92.  
  93. OPER3.MAN
  94. ---------
  95.  o Section VIII.4 (File Transfers while in Chat Mode) references the PC's
  96.    PG UP and PG DN keys as primary methods to download and upload in chat.
  97.    Since the Amiga has no such keys, you must use the alternative described
  98.    -- CTRL-E for Uploads, CTRL-F for downloads -- if you use Citadel for
  99.    BBSing at all.  Performance in Chat mode is not good when calling other
  100.    bulletin boards.  There are problems if you need to use the escape key
  101.    on the BBS you are calling, since Citadel will think you want to exit
  102.    the chat.  Use a terminal program instead!
  103.  
  104.  o Section VIII.7 is not correct for the Amiga.  The Citadel 68K status
  105.    line shows the current user, Room they are in, a time of day(see #CLOCK)
  106.    and some status information which will indicate the state of Citadel.
  107.    If you see:
  108.        E - Echo enabled       C - chat enables, ^A - anytime net session
  109.       ^T - Sysop Call option
  110.  
  111.    For example: a "CE" indicates Chat enabled, Echo enabled.
  112.  
  113.  o Section XII (Outside Editor) is implemented but works a little oddly.
  114.    If you are using an editor like TURBOTEXT that will release the starting
  115.    process, it will not work correctly.  With TURBOTEXT, use the commands
  116.  
  117.    #EDITOR "TTX WAIT"
  118.    #EDIT-AREA "CIT:temp/"
  119.  
  120.    This way it will hold up the process and CTDL will be able to get the
  121.    file AFTER you changed it.  Without the "WAIT"  it does not work correctly.
  122.  
  123. OTHER NOTES
  124. -----------
  125.  o The Read forward command has two parameters which may be substituted
  126.    for the date.  These are YESTERDAY and TODAY.  The commands would look
  127.    like:
  128.  
  129.    .RF TODAY or .RF YESTERDAY
  130.  
  131.    Also instead of the date(i.e. 92APR02), you may specify the number of
  132.    days to go back with:
  133.  
  134.    .RF 5     <-- Read forward from 5 days ago.
  135.  
  136.  o Citadel uses the req.library.  You will need to have that in the libs
  137.    directory.  This is found on the fish disks and other PD collections.
  138.  
  139.  o There is an AREXX port in Amiga Citadel.  The AREXX capabilities of
  140.    Amiga Citadel are limited to execution of simple instructions.  The
  141.    port name of the program is "Citadel68K".  These instructions are as
  142.    follows:
  143.  
  144.      "setchat" 0/1 -- sets chat mode
  145.      "setecho" 0/1 -- sets echo mode
  146.      "setnouserdisable" 0/1 -- sets Call Sysop flag
  147.      "exit" 0/1 -- forces ctdl to exit with 1 bypassing protection
  148.        to keep from kicking off users.
  149.      "version" -- returns version of program
  150.      "serialenable" 0/1 0/1 -- enables/disables serial.device with the
  151.        second parameter determining if the program should override
  152.        protection to prevent a user from getting kicked off.
  153.  
  154.    I plan to add other AREXX command to Citadel 68K as people request
  155.    them(if they are possible to do).
  156.  
  157.  o There are Amiga Specific commands in Ctdlcnfg.sys.  These are:
  158.  
  159.    #WBENCHWINDOW -- Placing this in the file tells ctdl to open a window on
  160.    the workbench screen rather than create a new screen.  The next two
  161.    paramaters work differently based on the presence or absence of this
  162.    paramater.
  163.  
  164.    #SCREENWIDTH n -- Describes the width of the screen when a new screen is
  165.    created.  Otherwise it describes the width of the window created by the
  166.    program on the workbench screen.
  167.  
  168.    #SCREENHEIGHT n -- Describes the height of the screen when a new screen
  169.    is created.  Otherwise it describes the height of the window created by
  170.    the program on the workbench screen.
  171.  
  172.    #SCREENCOLOR0 n -- The background color (pen 0) of the screen that ctdl
  173.    opens.  This is the RGB value broken down in binary expressed as a
  174.    decimal number.  This number is created by the pattern 0000rrrrggggbbbb.
  175.    Example Red Intensity 8 is 2048.
  176.  
  177.    #SCREENCOLOR1 n -- The foreground color (pen 1) of the screen that ctdl
  178.    opens.  This number works the same as screencolor0.
  179.  
  180.    #DISABLEEHO -- if this parameter is present, console echo will be
  181.    disabled upon startup of ctdl.
  182.  
  183.    #DIRECTTOCHIP -- if this parameter is present, serial output will be
  184.    directed directly to the chip that handles serial I/O, bypassing the
  185.    serial.device.  This should work for all systems and is only a selection
  186.    because of choice.
  187.  
  188.  
  189.  System Setup:
  190.  
  191.    The following files are mentioned in the other manuals, this is just a
  192.    summary for the budding sysop.  These files are created by CONFG unless
  193.    otherwise noted.  Some you will create to add features to Citadel.
  194.  
  195.       o CTDLMSG.SYS.   This file contains all the messages in the system.
  196.       o CTDLROOM.SYS.  This file contains information about the rooms in your
  197.                        system.  The size of this file is given later in this
  198.                        manual.
  199.       o CTDLLOG.SYS.   This file contains all the accounts for users on your
  200.                        system.  The size of this file is given later in this
  201.                        manual.
  202.       o CTDLNET.SYS.   This file, if it exists, will be 0 bytes long when
  203.                        initially generated by CONFG.EXE.
  204.       o CTDLFLR.SYS.   This file contains information about the floors in your
  205.                        system.  This is the only file of this group is not
  206.                        static; it grows as you add floors to your system.
  207.                        Don't panic, though.  Each floor only takes 21 bytes.
  208.  
  209.       o CTDLARCH.SYS.  This file contains data about auto-archiving of rooms
  210.                        (an advanced topic to be covered under day-to-day
  211.                        operations).
  212.       o CTDLNET.SYS.   This file, created by CONFG, will be expanded by
  213.                        CTDL if you are participating in a network.
  214.       o CALLLOG.SYS.   This file, an optional text file, is updated as each
  215.                        caller hangs up.  This will be placed in the #CALLAREA
  216.       o CTDLDIR.SYS.   This file contains data about the directory rooms on
  217.                        your system, specifically the name of the DOS directory
  218.                        associated with each directory room on your system.
  219.   Optional items
  220.  
  221.     I will not say too much about these since they are optional and not needed
  222.     to startup your system.  They are covered in detail in the other manuals.
  223.  
  224.       o CTDLPROT.SYS   If this file exists, it contains information about
  225.                        external protocols.  To get Zmodem for example, you
  226.                        need to file a Zmodem program(See P342.lzh) and add
  227.                        the information to this file.
  228.       o RESULTS.SYS    This file specifies your modems response codes.  You
  229.                        really should have one of these that looks something
  230.                        like:
  231.  
  232.                        #result-300 Connect 300
  233.                        #result-1200 Connect 1200
  234.                        #result-2400 Connect 2400
  235.                        #result-9600 Connect 9600
  236.                        #no-dialtone No Dialtone
  237.                        #no-carrier No Carrier
  238.                        #ok OK
  239.                        #error Error
  240.                        #voice Voice
  241.                        #busy Busy
  242.                        #ring Ring
  243.  
  244.                        Without this file, CTDL will work, but you get
  245.                        improved performance with it.  You can cut this section
  246.                        out of this file, remove the leading spaces and use
  247.                        it as is.
  248.  
  249.   CONFG PARAMETERS:
  250.  
  251.      To setup a Citadel, you have to create a file called CTDLCNFG.SYS.  It
  252.      is read by CONFG and all the other files are created.  The most confusing
  253.      part of being a sysop is setting up this file.  The parameters here are
  254.      explained in enough detail so you can setup your system.  Use the example
  255.      file in the archive to setup all the details.
  256.  
  257.      #nodeTitle  "<title>"
  258.  
  259.                   The first parameter you should find is called nodeTitle.
  260.                   It is a string value that obeys formatting directives,
  261.                   and is subject to formatting considerations.  nodeTitle
  262.                   is the title of your installation that is printed when
  263.                   is detected on your system.  More precisely, nodeTitle
  264.                   will show up in the following place on your system:
  265.  
  266.       Welcome to <title>
  267.        Running ...
  268.  
  269.                   However, nodeTitle may not necessarily be printed at
  270.                   this point, because if a help file named BANNER.BLB
  271.                   exists on your system, it will be printed in place of
  272.                   the "Welcome to <nodeTitle>" part.
  273.      EXAMPLE:
  274.  
  275.      #nodeTitle "Test System\n Truly a Heaven in Reverse"
  276.  
  277.                   The #nodeTitle is printed out on .Read Status commands,
  278.                   also.  There is no formal limit on the length of this
  279.                   parameter, but you should definitely use BANNER.BLB for
  280.                   long #nodeTitles, or to vary it easily.
  281.  
  282.      #nodeName  "<nodename>"
  283.  
  284.                   nodeName is, in reality, purely a network parameter,
  285.                   and if you have no plans to ever join a C86net, then
  286.                   there is no need to fill in this parameter.  However,
  287.                   it has always been traditional, even before there was
  288.                   a net for any Citadel system anywhere, to fill in this
  289.                   and the next parameter (and, so, sentimentally we feel
  290.                   this belongs in this Miscellaneous section).   nodeName
  291.                   is a string value which does NOT accept formatting directives
  292.                   (i.e., formatting directives will be ignored).  It can
  293.                   be no longer than 19 letters long.  It should be a short,
  294.                   mnemonic name for your system.  An EXAMPLE of a reasonable
  295.                   value:
  296.  
  297.      #nodeName "ODD-DATA"
  298.  
  299.                   If you ever do join a C86net, messages from your system
  300.                   appearing on another Citadel node of that net will look
  301.                   something like this:
  302.  
  303.         82Nov23 from Cynbe ru Taren @ODD-DATA
  304.  
  305.                   except that ODD-DATA would be replaced with your value
  306.                   for #nodeName.
  307.  
  308.      #nodeId
  309.  
  310.                  As mentioned, this parameter is a network parameter that
  311.                  has traditionally always been set, even for non-network
  312.                  Citadels.  If you have no plans to ever be on a C86net,
  313.                  then you don't have to set this string value parameter
  314.                  to anything important.  If you do plan to join one, though,
  315.                  (we'll go over this in more detail in the section on the
  316.                  network), then you do have to set this parameter correctly.
  317.                  The format of this parameter is
  318.  
  319.           "<Country code><Area Code><Phone number>"
  320.  
  321.                  all of which applies to the phone that your system resides
  322.                  on.  Country code is a two letter sequence indicating
  323.                  what country you live in (US is the United States, CA
  324.                  is Canada.   Area code is the area code of your system
  325.                  (yes, we are aware that there is a clear bias towards
  326.                  US-style telephony).  And Phone number is, of course,
  327.                  the phone number that your system is on.  You can put
  328.                  punctuation (such as parenthesis and dashes), but please
  329.                  be conservative with them.  This string value does not
  330.                  obey formatting directives.  Here's a fairly generic
  331.                  example:
  332.  
  333.    #nodeId "US (612) 953 8159"
  334.  
  335.    #baseRoom  "<firstRoom>"
  336.  
  337.                  OK, now we're into parameters that you must have set,
  338.                  starting with baseRoom.  Citadel always has a minimum
  339.                  of three rooms, the Aide> room for housekeeping, the Mail>
  340.                  room for private correspondence, and the <baseRoom>, which
  341.                  is the room that a caller is always initially placed in.
  342.                  (Historical note: the old CP/M Citadel called this room
  343.                  the Lobby>; we've only made the name of the Lobby> selectable
  344.                  by the sysop.)  This parameter is a string value that
  345.                  obeys formatting directives and goes through the Citadel
  346.                  formatter, and you must limit yourself to 19 characters
  347.                  or less for this value. And one more note, Citadel will
  348.                  append the '>' to this name when it prints the room prompt
  349.                  for this room, you don't have to put it in yourself. If
  350.                  you wished to emulate the old CP/M Citadel, you'd set
  351.                  baseRoom thus:
  352.  
  353.      #baseRoom "Lobby"
  354.  
  355.                  There is no default for this parameter.
  356.  
  357.      #MainFloor
  358.  
  359.                  MainFloor is analogous to #baseRoom.  Any Citadel has
  360.                  a base floor, just as it has an Aide> room, etc.  This
  361.                  parameter allows you to name this base floor.  This parameter
  362.                  is a string value which cannot be longer than 19 characters,
  363.                  and specifies the name of your base floor.  So, if you
  364.                  want to name your base floor MAIN FLOOR, you'd have
  365.  
  366.      #MainFloor "MAIN FLOOR"
  367.  
  368.                  There is no default value for this parameter.
  369.  
  370.      #CRYPTSEED  <number>
  371.                  Citadel automatically encrypts all sensitive data files.
  372.                  While the algorithm used can, of course, be broken by
  373.                  the determined, particularly since the code is available
  374.                  for perusal, the encryption does provide protection against
  375.                  casual eyes, mistakes, and amateur system breakers.  We
  376.                  do encourage you to take precautions of your own, such
  377.                  as not opening directory rooms that look at sensitive data.
  378.                  Encryption can be disabled if you specify a value of zero.
  379.                  You may use any value 0-65536.
  380.  
  381.                  CRYPTSEED is an encryption seed that Citadel uses to encrypt
  382.                  your data; if someone should acquire of all of your data
  383.                  files but for CTDLCNFG.SYS, then they still won't have
  384.                  access to your system until they figure out what your
  385.                  CRYPTSEED is.  DON'T EVER CHANGE THIS VALUE WHILE RUNNING
  386.                  A CITADEL, OR EVERYTHING WILL BECOME MESSED UP!  If you
  387.                  are rebuilding your system from scratch, you may change
  388.                  the value at that time.  An example:
  389.  
  390.      #CRYPTSEED    69
  391.  
  392.      #MESSAGEK   <size in K>
  393.  
  394.                  MESSAGEK defines how much disk space you wish to allocate
  395.                  for messages on your installation.  There is no way to
  396.                  define how many messages you want in your system, or how
  397.                  fast they turnover.  All the messages in your system will
  398.                  reside in CTDLMSG.SYS, and thus the number of messages
  399.                  in your system at any given moment will depend on the
  400.                  length of the messages being entered into the system by
  401.                  your users.  The turnover rate of your messages  will
  402.                  depend on how busy your system is.  As an example, Test
  403.                  System has a 611K message base, which holds 2100 messages
  404.                  +/- 300, of which some are of fairly good length.  Turnover
  405.                  seems to between 3 weeks and a month, since 80-160 messages
  406.                  are entered a day.  However, Test System is also a busy
  407.                  system.
  408.  
  409.                  The sysop of an installation should also keep in mind
  410.                  that very large systems, with many new messages, can be
  411.                  intimidating to new users, so large message spaces should
  412.                  be approached with caution.  Remember, there is a utility
  413.                  for expanding the message base, but not for shrinking it.
  414.  
  415.                  This is a numerical value which you specify in 'K', which
  416.                  is actually 1024 bytes/K.  So, for example, to specify
  417.                  a 250K message file.
  418.  
  419.      #MESSAGEK 250               -- 250K message base
  420.  
  421.      #MSG-SLOTS
  422.                  This numerical parameter specifies how many messages per
  423.                  room will be used on this system (the lone exception is
  424.                  the Mail>, which is covered by the following parameter).
  425.                  If you wanted to use Citadel's traditional number of messages
  426.                  per room, you'd have
  427.  
  428.      #MSG-SLOTS 58
  429.  
  430.      #MAIL-SLOTS
  431.  
  432.                  This is a numerical parameter specifying how many messages
  433.                  per log record that you wish to reserve for Mail.  The
  434.                  Mail> room is the only room in the system whose data is
  435.                  not kept in CTDLROOM.SYS.  Instead, the file CTDLLOG.SYS
  436.                  contains the "Mail>" room, reserving for each account
  437.                  enough room for MAIL-SLOTS Mail messages.  Therefore,
  438.                  this parameter gives you the ability to decide the maximum
  439.                  number of Mail> messages per user that they can access.
  440.                  Please remember that if a user gets more messages in Mail>
  441.                  than there are MAIL-SLOTS between two successive logins,
  442.                  then they will lose the earlier messages sent to them.
  443.                  Another consideration is that many users like to review
  444.                  old Mail when engaged in an in-depth private conversation.
  445.                  Therefore, setting MAIL-SLOTS to a low value may not be
  446.                  the attractive alternative that it first seems.  However,
  447.                  it should go without saying a high MAIL-SLOTS value may
  448.                  eat up more room than necessary on your drives.  The section
  449.                  on LOGSIZE will give an exact formula for how much space
  450.                  your log will take up.  Example:
  451.  
  452.      #MAIL-SLOTS 58
  453.  
  454.      #MAXROOMS
  455.  
  456.                  This numerical parameter specifies the maximum number
  457.                  of rooms your system will support.  Since the baseRoom,
  458.                  Aide>, and Mail> room are necessary, the smallest value
  459.                  you can give is 3.  The largest number is 65536 (probably).
  460.                  If you wanted to have a 64 room system, you'd have
  461.  
  462.      #MAXROOMS 64
  463.  
  464.                  You can use the following formula to estimate the number
  465.                  of bytes a room file will take up on your system:
  466.  
  467.                  # of bytes = MAXROOMS * (50 + (6 * MSG-SLOTS))
  468.  
  469.      #LOGSIZE
  470.  
  471.                  This numerical parameter gives you, the sysop, the ability
  472.                  to decide how many accounts will be available on your
  473.                  system.  If you run a system in which more accounts are
  474.                  used than there are accounts reserved, then new accounts
  475.                  are generated by killing old accounts.  The account that
  476.                  will be replaced with the new account is that account
  477.                  which has not been used in the longest time (in other
  478.                  words, accounts that are not used will be the first to
  479.                  be killed).
  480.  
  481.                  All space is reserved immediately for these accounts.
  482.                  The size of this file can be estimated from the formula:
  483.  
  484.                  # of bytes = LOGSIZE * (82 + MAXROOMS + (6 * MAIL-SLOTS))
  485.  
  486.                  so if you are operating in a restricted environment, plan
  487.                  accordingly.  If you need to, you can expand the size
  488.                  of the log through the use of the DATACHNG utility, but
  489.                  the log cannot be shrunk.  This is a numerical value.
  490.                  Here is an example:
  491.  
  492.      #LOGSIZE 180
  493.  
  494.      Now we discuss where you want the data files to be located on your
  495.      system.  These parameters are all specified in the same way, as a
  496.      string value (which does not obey  formatting directives, naturally)
  497.      that tells Citadel where on your system the given data file or files
  498.      associated with the given parameter is located. Simply use either
  499.      a relative directory specification or a full pathname. So, some sample
  500.      valid specifications would  be "c:", "a:system", b:msgs", and "i:bark".
  501.  
  502.         If CONFG cannot find the directory that you specify, it will
  503.         attempt to create that directory, after asking permission.
  504.  
  505.      #HELPAREA "cit:helps"
  506.  
  507.                  This parameter specifies where all of your Help files
  508.                  will be located.  These files are *.HLP, *.BLB, and *.MNU.
  509.                  Normally, you should create this directory and place the
  510.                  help files in the directory before bringing up Citadel,
  511.                  since help files are usually online at all times.  The
  512.                  Help files are maintained on Test System.  Ask any Citadel
  513.                  System where to find them.  I also have a set on the Amiga
  514.                  Zone.
  515.  
  516.      #LOGAREA "c:system"
  517.  
  518.                  This parameter specifies the location of your CTDLLOG.SYS
  519.                  file (this file is sized by your LOGSIZE parameter).
  520.  
  521.  
  522.      #ROOMAREA "system"
  523.  
  524.                 This parameter specifies the location of CTDLROOM.SYS,
  525.                 CTDLARCH.SYS,  and CTDLDIR.SYS.
  526.  
  527.      #MSGAREA "c:msg"
  528.  
  529.                 This parameter specifies the location of CTDLMSG.SYS.
  530.  
  531.      #FLOORAREA "floors"
  532.  
  533.                 This parameter specifies the location of CTDLFLR.SYS.
  534.  
  535.      #AIDESEEALL
  536.  
  537.                 This parameter is a toggle that gives you some power over
  538.                 the scope of your aides' "vision".  If you set this parameter
  539.                 to 1, then your aides have access to all public AND private
  540.                 rooms (but not invite rooms, unless they have been invited).
  541.                 If this parameter is set to 0, then aides only have access
  542.                 to public rooms, plus those private and invite rooms that
  543.                 they've been invited to.  So, if you want your aides to
  544.                 see all public and private rooms, you would have
  545.  
  546.      #AIDESEEALL 1               -- See all but invite rooms
  547.  
  548.                 if you don't want your aides to be so nosy, then you'd have
  549.  
  550.      #AIDESEEALL 0               -- See only public rooms.
  551.  
  552.      #LOGINOK
  553.  
  554.                 The LOGINOK parameter controls whether your system is an
  555.                 "open" or "closed" system.  If you set LOGINOK to 1, the
  556.                 system will allow anyone to log in as a "new" user; that
  557.                 is, it will ask a caller who uses an unrecognized password
  558.                 if they wish to login as a new user.  If LOGINOK is set
  559.                 to 0, the system will simply tell the caller without a
  560.                 valid password that there is no record of that password,
  561.                 and that they should leave Mail> to the sysop; the only
  562.                 way to enter new users into the system is from the system
  563.                 console. If you want an open system, for example, you
  564.                 would have:
  565.  
  566.      #LOGINOK 1                  -- let the riff-raff in!
  567.  
  568.      #ENTEROK
  569.  
  570.                ENTEROK controls whether a caller who is not logged in can
  571.                enter messages or not.  If ENTEROK is 1, then a caller who
  572.                has not logged in can enter messages; if it is 0, then they
  573.                must log in first, except for Mail to the sysop.  Setting
  574.                ENTEROK to 0 can reduce vandalism; setting it to 1 gives
  575.                your callers the privilege of anonymity.
  576.  
  577.      #ENTEROK  0                 -- log in first, folks!
  578.  
  579.      #READOK
  580.                READOK controls whether an unlogged caller can read messages.
  581.                If READOK is 1, then they may.  If READOK is 0, then an
  582.                unlogged caller can only read the policy statement available
  583.                in the Mail> room (POLICY.HLP), and the help files.  Setting
  584.                READOK to 0 can discourage unwelcome callers from using
  585.                scarce system time.
  586.  
  587.      #READOK 0                   -- gotta login to read these gems...
  588.  
  589.      #ROOMOK
  590.                ROOMOK controls who can create new rooms on your system.
  591.                If ROOMOK is 1, then any logged in user of the system may
  592.                create new rooms.  If ROOMOK is 0, then only aides may create
  593.                new rooms on your system.
  594.  
  595.      #ROOMOK 1                   -- a liberal policy
  596.  
  597.      #ALLMAIL
  598.                ALLMAIL controls who can use the Mail> room.  If ALLMAIL
  599.                is 1, then any user may use Mail> to send private messages
  600.                to any other user on the system.  If ALLMAIL is 0, then
  601.                only Aides may use the Mail> room in a general manner; regular
  602.                folk can only use Mail> for messages to Sysop.  Setting
  603.                ALLMAIL to 0 may be appropriate on tightly focused systems
  604.                operating in a small environment.
  605.  
  606.      #ALLMAIL 1                  -- the normal policy
  607.  
  608.      #SYSBAUD
  609.  
  610.                The SYSBAUD parameter is used to tell Citadel what baud
  611.                rates your hardware will support.  Citadel cannot normally
  612.                be configured to run high baud rates while excluding lower
  613.                baud rates (i.e., operate correctly at 1200 baud but not
  614.                at 300 baud).  A value of 0 indicates that the system is
  615.                a 300 baud system, 1 indicates 300/1200, 2 indicates
  616.                300/1200/2400, 3 indicates 3/12/24/48, and 4 indicates
  617.                3/12/24/48/96.
  618.  
  619.     #SYSBAUD 1                  -- A 3/12 system.
  620.  
  621.      #modemSetup
  622.  
  623.                This parameter is used to initialize your modem.  It is
  624.                a string value parameter that obeys the formatting directives;
  625.                however, you should be warned that Citadel automatically
  626.                appends a "\r" to the end of this string before sending
  627.                it to the modem. And when is modemSetup sent to the modem?
  628.                It is automatically sent twice while Citadel is initializing,
  629.                and it will also be automatically sent to the modem whenever
  630.                the <R>einitialize command is selected from the Sysop Menu (
  631.                i.e. privileged function:).
  632.  
  633.                The value that you use for this string should cause the
  634.                modem to be put into a mode where it will function suitably
  635.                with Citadel.  This includes auto-answer and response to
  636.                DTR, at the very least.  Other options that you may wish
  637.                to consider include turning the modem speaker off (if you
  638.                have one); consult your modem manual for details.  The example
  639.                we have here is biased towards Hayes/compatible modems.
  640.                You may have to do some research if you're using an odd
  641.                modem.  Our example turns auto-answer on and turns off the
  642.                speaker on a Hayes modem; note the lack of "\r".
  643.  
  644.      #modemSetup "AT S0=1 M0"           -- Surely an exercise in aesthetics...
  645.  
  646.      #event <days> <time> <class> <type> <duration> <warning string> <depends>
  647.  
  648.                This is what we're calling a "time-driven event-handler",
  649.                which we're going to define as the ability to cause Citadel
  650.                to do certain things at times that you specify.  So, for
  651.                instance, you can have the system come down at certain times
  652.                of the day to back itself up, or have it go into networking
  653.                mode several times a week -- or several times a day.  Or
  654.                do whatever your imagination suggests.  Any number of these
  655.                #event parameters may appear in your CTDLCNFG.SYS file.
  656.  
  657.                Here is an explanation of each parameter field in the above
  658.                statement.
  659.                <days> can be any of the values "Mon", "Tue", "Wed", "Thu", "
  660.                Fri", "Sat", "Sun", or "All", or any combination of the
  661.                first seven.  If used in combination, separate each with
  662.                a ',', but NO spaces are allowed.  This part of #event is
  663.                used to specify on what days this event is to take place.
  664.                So, if you want something to happen only on Wednesdays and
  665.                Saturdays, then you'd have
  666.  
  667.      #event Wed,Sat ....
  668.  
  669.                The 'All' value means, of course, all days of the week.
  670.  
  671.                <time> is the military specification of what time of day
  672.                this event is supposed to happen (unless the class of this
  673.                event is 'relative' -- see below).  For instance, 11 AM
  674.                would be:
  675.  
  676.      #event .... 11:00 ....
  677.  
  678.                while 11 PM would be:
  679.  
  680.      #event .... 23:00 ....
  681.  
  682.               and 12:30 AM would be:
  683.  
  684.      #event .... 00:30 ....
  685.  
  686.               Only one time can be specified in this field.  If you need
  687.               the same event to happen at multiple times, then use separate #
  688.               event entries.
  689.  
  690.               <class> indicates the class of the event, which is roughly
  691.               what kind of event it will be.  Citadel supports four classes
  692.               of events at this time:
  693.  
  694.               'network' -- this indicates that Citadel should drop into
  695.               networking mode on the day(s) at the time indicated by the
  696.               <days> and <time> fields.
  697.  
  698.               'external' -- this indicates that Citadel should come down
  699.               on the day(s) at the time specified by the <days> and <time>
  700.               fields.  The ERRORLEVEL that Citadel should generate when
  701.               it comes down will be discussed later in the subsection on
  702.               the <depends> field.  This class should be used in conjunction
  703.               with a carefully written batch file.
  704.  
  705.               'relative' -- this indicates that Citadel should come down
  706.               X minutes after it has come up (this is used to replace the
  707.               TIMEOUT and HOUROUT parameters).
  708.  
  709.               The number of minutes should be expressed in the <time> field;
  710.               the <days> field has no meaning (although it must be filled
  711.               in) when class is 'relative'.  The ERRORLEVEL to be generated
  712.               by Citadel when it comes down will be discussed later, but
  713.               for now we'll state that it occupies the <depends> field.
  714.               For instance, if you want your system to come down 6 hours
  715.               after it comes up, do something, and then come back up (at
  716.               which point you should realize it'll come back down again
  717.               6 hours after that, unless another event comes first), you
  718.               would have an event like:
  719.  
  720.      #event Sat 6:00 relative .... 7
  721.  
  722.               in your CTDLCNFG.SYS (note that Sat is meaningless, but some
  723.               valid value for the field has to be there).
  724.  
  725.               'dl-time' -- This indicates that a "download time limit"
  726.               should be activated.  This was a recent addition to the #event
  727.               handler, and is thus a patch rather than a full-scale addition;
  728.               to truly implement a download time limit would probably require
  729.               a Major Release.  When this class of event is active, the
  730.               total amount of time a user may use in downloads during a
  731.               session is limited by the value in the <depends> field, which
  732.               is designated in MINUTES.  This class value should only be
  733.               used with the 'quiet' type (see below).  When this event
  734.               ends, download time limits return to an unlimited status
  735.               automatically.
  736.  
  737.               <type> defines what type of event this will be, which essentially
  738.               means how Citadel reacts when the event time comes around.
  739.               There are two types of events supported at this time:
  740.  
  741.               'preempt' -- this indicates that when it's time for this
  742.               event to occur, the current user (if one is on) will be kicked
  743.               off the system.  A warning will be issued to the user 5 minutes
  744.               before the event is to occur (or if they call in after the
  745.               5 minute mark has passed, they will get the warning immediately).
  746.               This type should be used for events that MUST occur at a
  747.               given time, such as networking.
  748.  
  749.               'non-preempt' -- this indicates that the system is willing
  750.               to wait until the current user is off the system before executing
  751.               the current event.  If the time of the event is passed by,
  752.               the event will still be executed when the caller logs off.
  753.  
  754.               'quiet' -- this indicates that the event should occur with
  755.               no notice given to the user.  Currently, this only makes
  756.               sense with the 'dl-time' parameter, since there is no need
  757.               to bring the system down or drop into network mode to change
  758.               the dl-time limit.
  759.  
  760.               <duration> defines how long the event will last, in minutes.
  761.               If duration is 0, then if you happen to bring the system
  762.               up at the exact time that the event is to take place, the
  763.               event WON'T take place; for all other values of duration,
  764.               the event will take place. Duration should probably be 0
  765.               for external events that you only want to happen once, happen
  766.               quickly, and bring the system right back up, such as a backup
  767.               event in which your script file backs up the system and then
  768.               brings it back up.  This can go so fast that your system
  769.               will be back up in less than 1 minute, so you don't* want
  770.               duration set to 1 -- you want it at 0, otherwise the event
  771.               could be executed more than once.  However, for network events
  772.               you certainly want it set correctly.  A 45 minute network
  773.               event would look like this:
  774.  
  775.      #event ... ... network preempt 45 ....
  776.  
  777.              <warning string> is only valid for 'preempt' events.  It is
  778.              sent to the user for the warning and for the "you've been
  779.              kicked off" messages.  It should be enclosed in quotes.  Here's
  780.              what the messages look like:
  781.  
  782.      "<beep>WARNING: System going down at <time> for <warning string>."
  783.  
  784.      "<beep>Going to <warning string>, bye!"
  785.  
  786.              So, for networking,
  787.  
  788.      #event .... "networking" ...
  789.  
  790.              works just fine.
  791.  
  792.              <depends> is a parameter whose meaning depends on the class
  793.              of the event.  If the class of the event is 'external' or '
  794.              relative', then this value is the ERRORLEVEL that Citadel
  795.              is supposed to generate as it comes down, and should be used
  796.              in Script files for further processing.  The upper effective
  797.              limit on this parameter is whatever AmigaDOS allows in Script
  798.              files.  Before leaping into this, however, please review
  799.              the section on Script files in the Manuals, paying particular
  800.              attention to already-reserved ERRORLEVELS.
  801.  
  802.              If the class of this event is 'network', then <depends> specifies
  803.              what net(s) this network event is going to participate in.
  804.              While we are not going to discuss in detail what Citadel's "
  805.              multinet" capability is, here is a summary: Citadel supports
  806.              handling multiple C86nets.  Each network is identified by
  807.              a number; all of the nodes in your system can be associated
  808.              with 0 or more of these nets.  Thus, using the <depends> field
  809.              can allow you to network with certain systems at one time
  810.              and/or day, and other systems on other times and/or days.
  811.              The <depends> field must have at least one of the nets identified
  812.              here, and may have more if a particular network session is
  813.              servicing more than one network at a time.  If more than one
  814.              net is to be serviced, place a comma, and ONLY a comma, between
  815.              each net identifier. So, if you wanted to specify nets 1,
  816.              6, and 14, you'd have:
  817.  
  818.      #event .... 1,6,14
  819.  
  820.              If the class of the event is 'dl-time', then the depends field
  821.              specifies the maximum number of minutes that may be spent
  822.              in downloading during a single login while this event is in
  823.              effect.
  824.  
  825.              And that's it for the #event parameter(s).  We hope our
  826.              explanation is understandable; we sure had a hard enough time
  827.              writing it!
  828.  
  829.      #sysPassword
  830.  
  831.              This parameter gives you access to the Remote Sysop capabilities
  832.              of Citadel.
  833.  
  834.              A "Remote Sysop" is an Aide, not at the System Console, who
  835.              knows the Remote Sysop Password.  A Remote Sysop's capabilities
  836.              include complete access to the Sysop Menu (yes, including
  837.              such silly things as changing the Baud Rate ) and when editing
  838.              rooms the Remote Sysop can do what a normal Sysop can do.
  839.              A Remote Sysop gains access to the Sysop capabilities in exactly
  840.              the same way as a normal Sysop does, by sending a ^L to the
  841.              system -- but a Remote Sysop has to supply a password.
  842.  
  843.              This parameter, a string value that does not obey formatting
  844.              directives, does NOT (repeat NOT!) specify the Remote Sysop
  845.              Password.  Rather, it specifies the NAME of a file that contains,
  846.              on one line, the Remote Sysop Password (this allows you to
  847.              hide your Remote Sysop Password somewhere on your system).
  848.              This filename may specify any file anywhere on your system,
  849.              including different drives and subdirectories.
  850.  
  851.              The password itself must be at least 15 letters long, and
  852.              is, unlike most passwords, case-sensitive.  WARNING: If you
  853.              change the password in the file, you must run CONFG again (
  854.              CONFG ONLYPARAMS -- see the Section on Command Line parameters).
  855.  
  856.              If this parameter is not specified, or the file is not found,
  857.              then the Remote Sysop facility will not be available.
  858.  
  859.              This password should be protected to the maximum extent possible.
  860.              Major abuse is possible if some juvenile delinquent breaks two
  861.              passwords.
  862.  
  863.              However, if you insist on using this facility, and placed
  864.              your password in a file in a directory on partition G:, in a file
  865.              named PWD in a directory on the root called HIDING, you'd
  866.              have the following in your CTDLCNFG.SYS file.
  867.  
  868.      #sysPassword "g:hiding/pwd"
  869.  
  870.              At this point I would say something about security in general.
  871.              If you leave your system files, ctdlcnfg.sys and other things
  872.              directly available to your users, you run the risk of having
  873.              someone download them and effectivly hacking into your system
  874.              anytime they want.  It would take no longer than the download
  875.              and a run of a utility to know passwords of all your users and
  876.              create havoc on a board.  Please keep the files in a safe place
  877.              that is only accessable by the Sysop locally.  This is the first
  878.              commandment of Security!  Also do not give out AIDE privledges
  879.              lightly.  Make sure you can trust the person!
  880.  
  881.      #AUDITAREA
  882.  
  883.              This parameter is just like the MSGAREA, et al.  It is a string
  884.              value parameter that specifies a drive and directory which
  885.              will hold an audit file.  If this parameter is not present
  886.              in your CTDLCNFG.SYS file, then the audit file will not be
  887.              created or updated by Citadel.
  888.  
  889.              The audit file is known as CALLLOG.SYS.  It is a simple ASCII
  890.              text file that contains notes regarding system usage.  There
  891.              are only two types of notes.  The first lists when the system
  892.              has come up and down.
  893.  
  894.              The second type records who has called, listing login and
  895.              logout times, one line per person, in the following format:
  896.  
  897.      <person>   :   <login time> - <logout time> <baud rate>
  898.  
  899.              Occasionally such a line will have an extra character appended
  900.              onto it, and they have the following significance.
  901.  
  902.              '+'  Means that this user logged in as new.
  903.              '-'  Means that this user used .TS to logout.
  904.              'T'  Means that this user timed out on the system.
  905.              'E'  Means that this user hit the error limit on the system and was
  906.              kicked off.
  907.  
  908.              If you want to have a call log, you would have something like
  909.              this in your CTDLCNFG.SYS file:
  910.  
  911.      #AUDITAREA "audit"         -- This would be a subdirectory
  912.  
  913.      #MIRRORMSG
  914.              The structure of Citadel's message base causes frequent disk
  915.              access.  While this is not particularly deleterious for a
  916.              hard disk, this kind of activity has been known to actually
  917.              destroy floppy drives. Therefore, it makes sense to put the
  918.              message base into a RAM drive. However, this leaves systems
  919.              vulnerable to message base loss due to power failure. Because of
  920.              this, Citadel has the ability to support two identical message
  921.              bases at once.
  922.  
  923.              The first message base functions as the primary; messages
  924.              are written to and read from this base. This message base
  925.              is specified by the MSGAREA parameter.  The second message
  926.              base, however, is subject only to writing, thus saving wear
  927.              and tear on the media involved.  Since the primary message
  928.              base (the one that is both written to and read from) is subject
  929.              to a lot of wear and tear, this message base should be placed
  930.              in a RAM disk. The MSGAREA parameter mentioned earlier specifies
  931.              the area for the primary message base.  It is your responsibility
  932.              to make sure that a copy of CTDLMSG.SYS is in the RAM disk
  933.              when you bring Citadel up; Citadel will not do that for you.
  934.  
  935.              The secondary message base, since it is only written to, should
  936.              reside on permanent media, such as a floppy.  The parameter
  937.              MSG2AREA, a string value that does not respond to formatting
  938.              directives, specifies the area where the secondary message
  939.              base should reside.  Since both message bases are written
  940.              to simultaneously, they should remain identical.
  941.  
  942.              If you wish to use this option, MIRRORMSG should be set to
  943.              1; otherwise, it should be set to 0.  If MIRRORMSG is set
  944.              to 1, then MSG2AREA should specify where the secondary message
  945.              base should reside.  For instance:
  946.  
  947.      #MIRRORMSG 1                -- yeah, why not?
  948.      #MSG2AREA "b:msg"           -- on floppy, of course
  949.  
  950.      #RESULT-300
  951.      #RESULT-1200
  952.      #RESULT-2400
  953.      #RESULT-4800
  954.      #RESULT-9600
  955.      #RING
  956.  
  957.              Citadel has the ability to read the result codes from Hayes
  958.              compatible modems and determine the baud connection of the
  959.              modem from them.
  960.  
  961.              The #RESULT-xxxx parameters and the #RING parameter are string
  962.              values which should contain the result codes your modem will
  963.              return for the respective connections, while #RING is the
  964.              result code for a RING.  Consult your modem for the exact
  965.              values, since they vary from modem to modem.  You are also
  966.              responsible for using the #modemSetup parameter to initialize
  967.              your modem correctly for returning result codes.
  968.  
  969.              When Citadel is trying to use result codes to detect the baud
  970.              rate of a caller, it proceeds by scanning the input for a
  971.              C/R.  Once one is found, then the characters accumulated before
  972.              the C/R are compared to your #RING value.  If they are identical,
  973.              then all the characters are thrown away and Citadel looks
  974.              for more result codes.  If #RING did not match, then the system
  975.              will scan the various #RESULT-xxxx values that you specified,
  976.              again looking for a match.  If one is found, then the respective
  977.              baud rate is set and the system proceeds with login.  If a
  978.              match is not found, then the system begins scanning for user-sent
  979.              C/Rs in an attempt to find the baud rate.
  980.  
  981.              You do not need to specify values for baud rates your modem
  982.              doesn't support, and we recommend that you do not.
  983.  
  984.              If you have your SEARCHBAUD parameter set to 0, then you should
  985.              NOT use this option.
  986.  
  987.              Here is an example for a MultiTech MT224.
  988.  
  989.      #RESULT-300 "1"
  990.      #RESULT-1200 "5"
  991.      #RESULT-2400 "9"
  992.      #RING "2"
  993.  
  994.              Earlier in this document is a copy of a typical RESULTS.SYS file
  995.              which will work for most any Hayes compatible modem.
  996.  
  997.      #HOLDAREA
  998.  
  999.              Citadel has the optional capability to save messages that
  1000.              are inadvertently interrupted during composition by users
  1001.              for later completion.  The reason we say "optional" is that
  1002.              the method used to save such messages is to save them as files
  1003.              on disk, and in a restricted environment such an ability may
  1004.              not be desirable. Thus, this feature is only available on
  1005.              systems in which #HOLDAREA is defined.  #HOLDAREA is another
  1006.              directory specification, exactly like those of Section 1 of
  1007.              CTDLCNFG.SYS.  All messages that are interrupted will be stored
  1008.              there until the next time the user logs in.  These files are
  1009.              currently 7706 bytes long.
  1010.  
  1011.      #HOLDAREA "hold"
  1012.  
  1013.      #sysopName
  1014.  
  1015.              This parameter is used to tell your system who the sysop is.
  1016.              The only real effect of this parameter is that all Mail> to
  1017.              sysop is automatically routed to the account that you specify
  1018.              in this parameter's string value.  (This will also affect
  1019.              net Mail> to sysop.)  If you're not using this parameter,
  1020.              or the account does not exist, then Mail> to sysop will end
  1021.              up in the Aide> room.
  1022.  
  1023.      #sysopName "Me!"
  1024.  
  1025.      #NETWORK
  1026.  
  1027.              This parameter controls whether or not you're in the network
  1028.              at all.  Set it to 1, and you are.  If it is set to 0, then
  1029.              you are not (initial setting for our virgin copy).  If you
  1030.              are planning to participate in the network, then please be
  1031.              sure that you understand the section on the #event parameter,
  1032.              because that is what you use to tell your system when to
  1033.              communicate with other systems on the networks.  Also contact
  1034.              the Sysops of the systems you plan to netword and tell them
  1035.              you NODEID and NODETITLE.  You must also arrange the calling
  1036.              and many other parameters.  The Sysops you contact can help
  1037.              you setup this and get it working.  The Aide room will contain
  1038.              messages telling you of problems with your networking.
  1039.  
  1040.      #NETWORK 1                  -- This system participates.
  1041.  
  1042.      #LONG-HAUL
  1043.  
  1044.              This parameter controls whether or not you'll ever call any
  1045.              systems that are long distance from you.  If 1, then you will
  1046.              (if you have any on your list, natch); if 0, then you won't.
  1047.              Naturally, if you never have any systems that are long distance
  1048.              from you in your node list, your system will never call long
  1049.              distance.
  1050.  
  1051.      #LONG-HAUL 1                -- Sure, what da heck
  1052.  
  1053.      #NewNetPrivs
  1054.  
  1055.              This numerical parameter let's you decide if new users should
  1056.              automatically have net privileges or not.  If 1, then they
  1057.              do; 0, they don't.
  1058.  
  1059.      #NewNetPrivs 0                     -- let's be paranoid!
  1060.  
  1061.      #NETAREA
  1062.  
  1063.              This string parameter specifies where all the net files will
  1064.              be located on your system.  The "net files" are CTDLNET.SYS
  1065.              and various temporary files that have the suffixes ML, RFL,
  1066.              and SFL.  NETAREA is just like LOGAREA, MSGAREA, etc., specifying
  1067.              either a relative path name or full pathname.
  1068.  
  1069.      #NETAREA "netstuff"         -- let's put it in a directory called
  1070.                                  -- netstuff.
  1071.  
  1072.      #SHARED-ROOMS
  1073.  
  1074.              This numeric parameter reserves room in each node record for
  1075.              the number of shared rooms you think you'd like to share.
  1076.              Each takes up 6 bytes, so plan according in view of the number
  1077.              of nodes you'll have on your node list and the number of rooms
  1078.              you might want to share with other systems.  If you think you
  1079.              might add rooms later, make this large enough for your plans.
  1080.  
  1081.  
  1082.      #SHARED-ROOMS 4            -- conservative
  1083.  
  1084.      #NET-ARCH-ROOMS
  1085.  
  1086.              This numeric parameter reserves room in each node record for
  1087.              the number rooms that you think you'd like to archive via
  1088.              the network.  Each takes up 6 bytes, so once again plan
  1089.              accordingly.
  1090.  
  1091.      #NET-ARCH-ROOMS 2          -- it's an odd capability
  1092.  
  1093.      #NET_RECEPT_AREA
  1094.  
  1095.              This parameter specifies a directory on your system that will
  1096.              contain all files that are sent to your system by some other
  1097.              system during networking, using the Send File facility (this
  1098.              is not the same as requesting files over the network).  NET_RECEPT_AREA
  1099.              is a string value that does not obey string formatting directives,
  1100.              of course, and it may specify any directory on your system,
  1101.              not just a subdirectory to your current directory.  So, supposing
  1102.              you wanted to specify  Cit:CITADEL/HOLDING as the directory
  1103.              for incoming files from the net, you'd have in your CTDLCNFG.SYS
  1104.  
  1105.      #NET_RECEPT_AREA "Cit:CITADEL/HOLDING" -- that directory
  1106.  
  1107.      #NET_AREA_SIZE
  1108.      #MAX_NET_FILE
  1109.  
  1110.              These two parameters allow you to control how much space you
  1111.              wish to devote to files coming into your system from the net
  1112.              via the Send File command (i.e., other systems sending you
  1113.              files without you asking).
  1114.  
  1115.              NET_AREA_SIZE allows you to tell Citadel how much space to
  1116.              devote to the directory specified in NET_RECEPT_AREA.  When
  1117.              a system attempts to send you a file, Citadel will get the
  1118.              size of the file, and then check to see how much space is
  1119.              already being taken up by files in NET_RECEPT_AREA.  If the
  1120.              difference of NET_AREA_SIZE and the files already in
  1121.              NET_RECEPT_AREA is less than the size of the incoming file,
  1122.              then your system will not accept the file that is being sent
  1123.              to you.  Make this large enough for expected files, but do not
  1124.              exceed the space on the drive/partition.
  1125.  
  1126.              MAX_NET_FILE allows you to control how big a file you will
  1127.              ever accept.  If the size of the file being sent to you exceeds
  1128.              the value you specify here, then your system will not accept
  1129.              the file being sent.
  1130.  
  1131.              Both of these values are in terms of K.  So, for instance,
  1132.              if you only wanted to allow files of up 24K into your system,
  1133.              and only wished to devote up to 44K to NET_RECEPT_AREA, you'd
  1134.              have:
  1135.  
  1136.      #NET_AREA_SIZE 24
  1137.      #MAX_NET_FILE  44
  1138.  
  1139.      #callOutPrefix
  1140.      #callOutSuffix
  1141.  
  1142.             These two parameters control modem dialing during networking.
  1143.             These are both string value parameters that will obey formatting
  1144.             directives, and should be used to convey commands to the modem.
  1145.             When dialing, Citadel constructs a phone number to send to
  1146.             the phone company, and sends the following to your modem:
  1147.  
  1148.      <callOutPrefix><phone#><callOutSuffix>
  1149.  
  1150.             callOutPrefix should alert the modem to dial, while callOutSuffix
  1151.             should do anything necessary to finish the dialing sequence
  1152.             (usually, just send a C/R to the modem).
  1153.  
  1154.             If you have a Hayes modem, we recommend you use the following
  1155.             values for these two parameters.
  1156.  
  1157.      #callOutPrefix "ATDT"            -- Tells a Hayes modem to dial out using
  1158.                                       -- touch tones
  1159.      #callOutSuffix "\r"              -- puts a carriage return at the end
  1160.  
  1161.      #LOCK-PORT
  1162.  
  1163.             This parameter allows you to lock the computer to modem data
  1164.             rate and have Citadel ignore the results code for user
  1165.             connections.  This is used in conjuction with SERIAL_7WIRE
  1166.             when you have a high speed modem.
  1167.  
  1168.      #SERIAL_7WIRE
  1169.  
  1170.             This is a required parameter if you are using a computer to
  1171.             modem data rate that is greater than the user connect rate.  If
  1172.             for example you have an MNP modem and have the computer locked
  1173.             at 9600 baud(See #LOCK-PORT above, you need that too).  This
  1174.             enables the hardware handshaking CTS/RTS.  If you do not do
  1175.             this, users will overrun the modem buffers at slow rates and
  1176.             see garbage.
  1177.  
  1178.      #SERIALDEVICE
  1179.      #UNITNUMBER
  1180.  
  1181.             These two parameters are of use to those with alternate serial
  1182.             devices, internal modems, third-party serial card.  It allows
  1183.             you to name the device and unit number Citadel should use to
  1184.             communicate with your modem.
  1185.  
  1186.      #alldone
  1187.  
  1188.             This is the last parameter in the ctdlcnfg.sys file.  It tells
  1189.             the CONFG program to finish processing and write the appropriate
  1190.             data files.  When you run a CONFG, the output will echo all your
  1191.             commands and any errors.  Watch it run and answer any questions.
  1192.             After it completes it will write the magic "ctdltabl.sys" file.
  1193.             This file is the controling file of Citadel.  If for some reason
  1194.             it is lost, you will have to run CONFG again.  Now all that remains
  1195.             is to run CTDL in the manner you decide.
  1196.  
  1197.             If CTDL DIDN'T come up, there are a large variety of reasons
  1198.             for the failure.  If your system seemed to make it up but came
  1199.             down relatively gracefully (i.e., left you at the system prompt),
  1200.             check your disks for a file named CRASH. It may give you (or
  1201.             the person you turn to for help!) a hint on what might be wrong.
  1202.             If it seems to think there's an error with a file, perhaps
  1203.             you forgot to configure MS-DOS correctly.  If CTDL itself complains
  1204.             about "no ctdltabl.sys!", then either that file isn't on your
  1205.             default disk when you called CTDL, or CONFG didn't successfully
  1206.             finish.
  1207.  
  1208.             Let's go over exactly what will happen.  When you run CONFG,
  1209.             it should go through CTDLCNFG.SYS.  Once finished, however,
  1210.             it's behavior will differ. It should not ask you if it may
  1211.             create the appropriate directories (since they should already
  1212.             exist), and it should not complain about not being able to
  1213.             find any of your system files (these should still exist, too!).
  1214.             However, it WILL ask you if you wish to erase and initialize
  1215.             your system files.  This time reply N (with vigor!).  CONFG
  1216.             will immediately begin analyzing your data files, and after
  1217.             several minutes, depending on the size of your system, it will
  1218.             produce a CTDLTABL.SYS; your system will be fit to run again.
  1219.  
  1220.      CTDL options
  1221.  
  1222.             The options starting with a "+" are switches that enable/disable
  1223.             some function of citadel.  This is a summary of the supported
  1224.             options:
  1225.  
  1226.             +netlog     -  Citadel will log all network activity in netlog.sys
  1227.             +nochat     -  Citadel will chat with nobody when chat is off.
  1228.             +netdebug   -  Citadel will provide additional info on networking
  1229.             +nomeet     -  Disables the User biographies
  1230.             +noecho     -  Disables the User echo on the console
  1231.             +vortex     -  Enables the vortex detection
  1232.             +vandaloff  -  Disables the checks for unlogged vandals
  1233.             +conpwd     -  Makes you use the sysop password at your console
  1234.             +noconban   -  controls the system banner at login
  1235.  
  1236.  
  1237.             The other options supply a parameter.  The format is
  1238.             option=parameter.  There are no spaces around the "=".
  1239.  
  1240.             kip         -  Not sure what this is for... Have to look????
  1241.             lowfree=    -  Sets the minimum free space on the upload disks
  1242.             lddelay=    -  Sets the connection time Citadel will wait for
  1243.                            a connect on long distance calls.
  1244.             paranoia=   -  specifies the number of messages a user may leave
  1245.                            in a room.  If exceeded the user is dropped.
  1246.             bps=        -  For use for those sysops using the #ISDOOR parameter
  1247.             zmodem=     -  Flag to control fast transfer use of Zmoden
  1248.                            protocol.  The letter that follows is the command
  1249.                            specifier for zmodem.
  1250.  
  1251.   Utilities:
  1252.  
  1253.  
  1254.    The utilities are almost exactly as documented in the Utilities manual
  1255.    for Citadel 86.  I have made the following changes:
  1256.  
  1257.    CLRAY  -  Added a -U switch to give the normal user listing with the
  1258.              account number on the front.  Without the -U, you get a display
  1259.              of the User with a space in the front so that the output could
  1260.              be used in a help file "as is".
  1261.  
  1262.    VERIFY -  This is a command I created to check the Citadel database.  It
  1263.              will issue various error messages if it finds problems with the
  1264.              config and user data.  Eventually, this command will completely
  1265.              validate a Citadel System.  All it does now is report on the
  1266.              User log and display some of the parameters.
  1267.              This could be used to "reverse-engineer" a citadel database.
  1268.