home *** CD-ROM | disk | FTP | other *** search
/ Beijing Paradise BBS Backup / PARADISE.ISO / software / BBSDOORW / CBVW161U.ZIP / CBV160.DOC < prev    next >
Text File  |  1993-03-09  |  46KB  |  1,104 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.                                    C B V
  8.  
  9.  
  10.               ┌──────────────────────────────────────────────┐
  11.               │▐▐▐▐▐▐▐▐▐▐· Call Back Verification ·▌▌▌▌▌▌▌▌▌▌│
  12.               └──────────────────────────────────────────────┘
  13.  
  14.                          ---=== Release 1.60 ===---
  15.  
  16.                       Copyright 1991,1993 Chris Holko.
  17.                        All Rights Reserved Worldwide.
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.  
  25.  (CBV160)
  26.  
  27.                 ┌─────────────────────────────────────────┐
  28.                 │▐▐▐▐▐▐▐▐▐▐· Table of Contents ·▌▌▌▌▌▌▌▌▌▌│
  29.                 └─────────────────────────────────────────┘
  30.  
  31.     WARRANTY                                                              1
  32.  
  33.     ACKNOWLEDGEMENTS                                                      1
  34.  
  35.     SHAREWARE DISTRIBUTION                                                2
  36.  
  37.     DISTRIBUTION FILE CONTENTS                                            3
  38.  
  39.     CBV
  40.      ├ Description                                                        4
  41.      ├─ Requirements                                                      .
  42.      ├── Restrictions                                                     .
  43.      │
  44.      ├ Support Files                                                      5
  45.      │  ├ CBVCFG.DAT                                                      .
  46.      │  ├─ CBVTRASH.DAT                                                   .
  47.      │  ├── CBVAREAC.DAT                                                  6
  48.      │  └─── CBVCALLS.DAT                                                 .
  49.      │
  50.      └ User Message Files                                                 7
  51.         ├ WELCOME.CBV                                                     .
  52.         ├─ PREPARE.CBV                                                    .
  53.         ├── PASSWORD.CBV                                                  .
  54.         ├─── NOLONGD.CBV                                                  .
  55.         ├──── LOCKOUT.CBV                                                 .
  56.         └───── VERIFIED.CBV                                               .
  57.  
  58.     CBV INSTALLATION
  59.      ├─ Files                                                             8
  60.      ├── Command Line                                                     .
  61.      └─── CHAINEDIT                                                       .
  62.  
  63.     CBV CONFIGURATION
  64.      ├ Main Menu                                                          9
  65.      ├─ Security Validation Menu                                         10
  66.      ├── Modified "userrec" Menu                                         11
  67.      ├─── Modem Menu                                                     12
  68.      ├──── Long Distance Menu                                            13
  69.      └───── Miscellaneous Menu                                           14
  70.  
  71.     APPENDICES
  72.      ├ A. Error Messages                                                 16
  73.      ├─ B. Session Control                                               19
  74.      ├── C. Contacting the author                                        20
  75.      ├─── D. User Restrictions                                           21
  76.      └──── E. CBVCFG.DAT layout                                          22
  77.  
  78.  (CBV160)  1
  79.  
  80.  
  81.                      ┌────────────────────────────────┐
  82.                      │▐▐▐▐▐▐▐▐▐▐· WARRANTY ·▌▌▌▌▌▌▌▌▌▌│
  83.                      └────────────────────────────────┘
  84.  
  85.  
  86.     CBV (Call-Back Verification) has NO WARRANTY.  Use of CBV,  and any
  87.     accompanying programs/files IS AT YOUR OWN RISK.  By your use of CBV
  88.     you agree to hold the author and parties directly or indirectly related
  89.     to the author faultless from the non-use,  use,  and/or misuse of CBV.
  90.  
  91.     CBV (CALL-BACK VERIFICATION) IS PROVIDED "AS-IS" AND WITHOUT WARRANTY,
  92.     IMPLIED OR OTHERWISE.
  93.  
  94.  
  95.  
  96.                  ┌────────────────────────────────────────┐
  97.                  │▐▐▐▐▐▐▐▐▐▐· ACKNOWLEDGEMENTS ·▌▌▌▌▌▌▌▌▌▌│
  98.                  └────────────────────────────────────────┘
  99.  
  100.  
  101.     References not otherwise documented.
  102.  
  103.     WWIV                     refers to World War Four Bulletin Board System
  104.     CBV                      refers to Call Back Verification Program
  105.     DOS                      refers to MS-DOS and/or PC-DOS
  106.  
  107.  
  108.     Copyright,  Trademark,  and Servicemark notices.
  109.  
  110.     WWIV                     Copyright (c) 1987-1992 by Wayne Bell.
  111.     Turbo Pascal             Copyright (c) 1982-1992 by Borland Int.
  112.  
  113.  
  114.  
  115.  (CBV160)  2
  116.  
  117.  
  118.               ┌──────────────────────────────────────────────┐
  119.               │▐▐▐▐▐▐▐▐▐▐· SHAREWARE DISTRIBUTION ·▌▌▌▌▌▌▌▌▌▌│
  120.               └──────────────────────────────────────────────┘
  121.  
  122.     Shareware is a unique method for the marketing of computer software.
  123.     Most of all the products are easily obtained from larger Bulletin Board
  124.     Systems worldwide.  The basis behind the workings of the Shareware
  125.     system is the HONOR system.  This means that the end user is free to
  126.     use the product for a limited trial period to see if suits their needs.
  127.     If the user continues to use the product after the trial period it is
  128.     expected of them to register the product with its author with any
  129.     stated fees,  this is to reimburse the author for both his time spent
  130.     in developing the product and to provide incentive to maintain and
  131.     update the product.
  132.  
  133.     You are free to test and use this program,  CBV,  to determine if it
  134.     suits your needs.  If you continue to use this program beyond thirty
  135.     (30) days complete the registration form (REGISTER.TXT) and mail it
  136.     with the registration fee to the address listed on the form.  Upon the
  137.     receipt of the completed registration form and fees you will be kept
  138.     advised on the status and availability of CBV,  granted use of the
  139.     registered version,  get timely support when needed,  and possible use
  140.     of beta and specialized versions of CBV.
  141.  
  142.  (CBV160)  3
  143.  
  144.  
  145.             ┌──────────────────────────────────────────────────┐
  146.             │▐▐▐▐▐▐▐▐▐▐· DISTRIBUTION FILE CONTENTS ·▌▌▌▌▌▌▌▌▌▌│
  147.             └──────────────────────────────────────────────────┘
  148.  
  149.     CBV is distributed as a complete package compressed into one archive
  150.     file.  The archive file of the UNREGISTERED version may be freely
  151.     distributed so long as no charge is required to obtain the package and
  152.     no modification to the distribution package is made.
  153.  
  154.     The naming convention the archive file is
  155.  
  156.     CBV?MMRT.AAA             AAA = Archiving method used.
  157.  
  158.                               MM = Major version number  ie. 14
  159.  
  160.                                R = Revision number       ie.  0
  161.  
  162.                                ? = BBS Package Supported
  163.                                    W = WWIV
  164.                                    R = Renegade
  165.  
  166.                                T = Release Type Specifier
  167.                                    U = UNREGISTERED
  168.                                    R = REGISTERED
  169.  
  170.      DISTRIBUTION OF REGISTERED, ALPHA, OR BETA VERSIONS IS PROHIBITED.
  171.  
  172.  
  173.      Take time to examine the contents of the archive file,  you will find
  174.      the following files with possibly a late text file addition.
  175.  
  176.  
  177.      [     ] CBV     .EXE    - The CBV program executable
  178.      [     ] CBVCFG  .EXE    - The CBVCFG program executable
  179.              CBVCFG  .DAT    - Sample CBV configuration file
  180.              CBVTRASH.DAT    - Sample CBV phone number trash file
  181.              CBVAREAC.DAT    - Sample Local Area Code(s) file
  182.              CBVTOLLS.DAT    - Sample Toll-Call File
  183.              CBVCALLS.DAT    - Sample Call-Only file
  184.  
  185.              CBVMENU .MOD    - Mod to run CBV from Main Menu
  186.  
  187.              AUTOCFG .C      - .C source for users of modified WWIV BBSes
  188.  
  189.              CBV160  .DOC    - This documentation
  190.              HISTORY!.DOC    - List of revisions made to CBV
  191.              READ    .ME     - Last minute updates / notices
  192.  
  193.              WELCOME .CBV    - Sample user welcome message
  194.              LOCKOUT .CBV    - Sample invalid/locked phone number message
  195.              NOLONGD .CBV    - Sample no long distance calls message
  196.              PREPARE .CBV    - Sample prepare for call back message
  197.              PASSWORD.CBV    - Sample enter password message
  198.              VERIFIED.CBV    - Sample account upgraded message
  199.              NOTOLLS .CBV    - Sample no toll calls message
  200.  
  201.              REGISTER.TXT    - REGISTRATION FORM FOR CBV.
  202.  
  203.  (CBV160)  4
  204.  
  205.  
  206.                        ┌───────────────────────────┐
  207.                        │▐▐▐▐▐▐▐▐▐▐· CBV ·▌▌▌▌▌▌▌▌▌▌│
  208.                        └───────────────────────────┘
  209.  
  210.  
  211.     ▐ Description
  212.  
  213.     CBV is a call back verification system designed for use with World War
  214.     Four Bulletin Board Systems.  It is intended to provide an easy way for
  215.     WWIV users to self validate themselves without direct System Operator
  216.     intervention.  CBV also enhances system security by recording the
  217.     complete phone numbers used for verification.  It can also be
  218.     configured to lockout troublesome users,  lockout specific area codes
  219.     and prefixes,  and prevent users from gaining multiple accounts.  CBV
  220.     can also be configured to offer long distance callers a customized
  221.     access level different from local callers.
  222.  
  223.     CBV has its own built in communication routines,  which auto-sense the
  224.     speed of the communication port,  and can be used with high speed
  225.     modems.  CBV also has built in safeguards to prevent accidental
  226.     corruption of system files.  If for any reason CBV should abort because
  227.     of internal errors it will provide and explanation of said reason both
  228.     on the local screen and the system log.  CBV uses direct DTR control to
  229.     disconnect callers and has an optional fall back option to use a modem
  230.     control string.
  231.  
  232.     CBV was coded entirely in Turbo Pascal,  features built in ANSI
  233.     interpetation,  WWIV-ANSI interpetation,  wordwrap,  and a System
  234.     Operator interface based upon WWIV.  CBV is comprised of approximately
  235.     3000 lines of code,  the configuration program about 1000 lines.
  236.  
  237.  
  238.     ▐▐ Requirements
  239.  
  240.     Basically if you can use WWIV on your system the you should be able to
  241.     run CBV.  All support files must be in the same directory with the CBV
  242.     executable.
  243.  
  244.  
  245.     ▐▐▐ Restrictions
  246.  
  247.     CBV can be adapted to any WWIV BBS using WWIV versions 4.10 and above
  248.     provided the following conditions are met.
  249.  
  250.      > The length of the NAME, PASSWORD, and NOTE fields cannot be changed.
  251.      > The size of SL, DSL, and EXEMPT must not be changed.
  252.      > The size of AR, DAR, and RESTRICT must not be changed.
  253.  
  254.     If you are running a modified version of WWIV where you have made
  255.     changes to the structure "userrec" you must compile the enclosed
  256.     source to DISPLAY.C with your modified source.  This will produce a
  257.     program which will display field offsets into your modified "userrec"
  258.     which are needed by the CBVCFG configuration program.
  259.  
  260.  (CBV160)  5
  261.  
  262.  
  263.     ▐▐▐▐ Support Files.
  264.  
  265.     CBV requires the following four data files to be present at all times.
  266.  
  267.     (CBVCFG.DAT)
  268.  
  269.     CBVCFG.DAT is the name of the CBV configuration file.  It is produced
  270.     by the program CBVCFG.EXE .  This file cannot be edited by a word
  271.     processor or standard editor as it is NOT ASCII.  No other program but
  272.     CBVCFG.EXE should be used to modify this file.  The layout of the
  273.     configuration file is detailed in APPENDIX F.
  274.  
  275.     (CBVTRASH.DAT)
  276.  
  277.     This is an ASCII file,  which can be edited using a ASCII file editor.
  278.     If you use a word processor to edit this file make sure it outputs as
  279.     ASCII.  This file contains the list of all INVALID area codes,
  280.     prefixes, arecode-prefixes,  and phone numbers.  CBV can optionally add
  281.     numbers to this file to prevent callers from gaining multiple user ids
  282.     on your system.
  283.  
  284.     Only one entry per line is permitted,  comments may be on the same line
  285.     as any number provided the comment begins with a semi-color ";".  All
  286.     entries must start at column one.
  287.  
  288.     Example CBVTRASH.DAT :
  289.  
  290.              1         2
  291.     123456789012345678901234567890
  292.  
  293.     900             ; We don't want to allow 900 calls
  294.     976             ; Neither do we want 976 calls
  295.     555             ; Directory assistance... NOT!
  296.     911             ; Emergency,  yeah,  like no access
  297.     404-555         ; Lockout of specific areacode-prefix
  298.     404-555-9999    ; Locked out number <- bad user?
  299.  
  300.     ---
  301.  
  302.     Basically there are certain numbers which should not be dialed,  and
  303.     certain numbers which are reserved for specialized purposes.  CBV also
  304.     prevents to the best of its ability users from entering invalid area
  305.     codes and prefixes.  This means no "1"s or "0"s as the first number
  306.     of an area code or prefix,  and only a "1" or "0" as the middle number
  307.     of the area code.  Also,  area codes and prefixes are supposed to
  308.     unique,  however this cannot be guaranteed so CBV will not enforce it.
  309.  
  310.  (CBV160)  6
  311.  
  312.  
  313.     ▐▐▐▐ Support Files  - Continued
  314.  
  315.     (CBVAREAC.DAT)
  316.  
  317.     This file contain a list of the areacodes that are *LOCAL* to your
  318.     BBS.  Only one entry per line is permitted,  and no comments are
  319.     allowed.  You can create or edit this file with an ASCII editor.
  320.     If you have CBV versions 1.40-1.45 installed then the config program
  321.     for CBV 1.50+ will automatically create this file for you.  You should
  322.     still check this file for validity of data.
  323.  
  324.     (CBVCALLS.DAT)
  325.  
  326.     This file contains the list of AREACODE-PREFIXES that you only want
  327.     CBV to call.  This file is only accessed if the CBVCFG.Miscellaneous
  328.     option "(E) - Use CBVCALLS.DAT Call Only File" is set to "YES".  Even
  329.     if set to no this file must exist,  the data contained within will
  330.     simply be ignored.  The file may be edited with an ASCII editor
  331.     following the rules set forth for the file "CBVTRASH.DAT".
  332.  
  333.     (CBVTOLLS.DAT)
  334.  
  335.     This file contains a list of AREACODE-PREFIXES that are toll calls from
  336.     your system.  TOLL calls are treated like other long-distance calls,
  337.     the call-back must be within the long-distance window,  and the CBVCFG
  338.     option "Allow TOLL calls" must be set on.  CBV checks the number entered
  339.     against this file to determine if it is a toll call.  This file follows
  340.     are similar format to "CBVTRASH.DAT",  however the numbers entered are
  341.     numbers known to be TOLL calls from the BBS.  This is mainly used to
  342.     screen in AREACODE toll calls that do not require a long distance access
  343.     code to call.
  344.  
  345.  (CBV160)  7
  346.  
  347.  
  348.     ▐▐▐▐▐ User Message Files.
  349.  
  350.     CBV requires that six message files exist before it will run.  These
  351.     files are displayed to the user as needed.  They are ASCII files and
  352.     rules for editing them are similar to the CBVTRASH.DAT file.  WWIV ANSI
  353.     codes may be used freely within these files,  however pure ANSI should
  354.     be avoided.  A sample of each file has been included with the archive
  355.     package.
  356.  
  357.  
  358.     (WELCOME .CBV)
  359.  
  360.     This file is displayed to the user before he enters any information.
  361.     It purpose is to explain what call back verification is for.  After
  362.     this file is displayed the program will ask the user if they wish to
  363.     continue.
  364.  
  365.     (PREPARE .CBV)
  366.  
  367.     This file is displayed to the user before the actual call back begins.
  368.     This is done immediately after the user has entered a number CBV has
  369.     judged to be valid.
  370.  
  371.     (PASSWORD.CBV)
  372.  
  373.     This file is displayed once CBV has reconnected with the user BUT
  374.     before they have entered their password.
  375.  
  376.     (NOTOLLS .CBV)
  377.  
  378.     This file is displayed if the user has entered a phone number matching one
  379.     listed in "CBVTOLLS.DAT" and the SysOp has configured CBV not to allow
  380.     them,  or if the long distance calling window is closed.
  381.  
  382.     (NOLONGD .CBV)
  383.  
  384.     This file is displayed if the user has entered a long distance phone
  385.     number and the SysOp has not configured CBV to allow them.  It will
  386.     also be displayed if the long distance calling window is closed.
  387.  
  388.     (LOCKOUT .CBV)
  389.  
  390.     This file will be displayed if the user enters a phone number in which
  391.     the area code,  prefix,  or whole number appears in the CBVTRASH.DAT
  392.     file.
  393.  
  394.     (VERIFIED.CBV)
  395.  
  396.     This file is displayed after the user has completed the verification
  397.     process,  just after correctly entering their password.  This is a good
  398.     method of describing what access they have,  and to inform long distance
  399.     callers that they will need to call back again.
  400.  
  401.     (CANTCALL.CBV)
  402.  
  403.     This file will be displayed if the option for "Check Call Only File" is
  404.     set to "Yes" and the user's AREACODE-PREFIX is not found in the
  405.     CBVCALLS.DAT file.
  406.  
  407.  (CBV160)  8
  408.  
  409.  
  410.                  ┌────────────────────────────────────────┐
  411.                  │▐▐▐▐▐▐▐▐▐▐· CBV INSTALLATION ·▌▌▌▌▌▌▌▌▌▌│
  412.                  └────────────────────────────────────────┘
  413.  
  414.  
  415.  
  416.     ▐ Files
  417.  
  418.     Extract all files contained within the archive file into the same
  419.     directory.  It is suggested that CBV be placed in its on sub-directory.
  420.     When running the program make sure to switch to the same directory as
  421.     where these files reside.
  422.  
  423.  
  424.     ▐▐ Command Line
  425.  
  426.     CBV requires the path/filename to the CHAIN.TXT be present on the
  427.     command line.  The path is not needed if the CHAIN.TXT file is in the
  428.     same directory as CBV.  CBV will abort if it cannot find this file or
  429.     if it cannot read it.
  430.  
  431.  
  432.     ▐▐▐ CHAINEDIT
  433.  
  434.     To make the door available to your users,  enter into CHAINEDIT either
  435.     by pressing "C" at the WFC or entering "//CHAINEDIT" at the main menu
  436.     prompt.  It is recommended that CBV be the first entry listed in your
  437.     online programs list.
  438.  
  439.     Example CHAINEDIT entry :
  440.  
  441.  
  442.     Name           : "CALL BACK DOOR"
  443.     FileName       : "CALLBACK.BAT %1"
  444.     SL             : ??
  445.     AR             : ??
  446.     ANSI           : N/A
  447.     300 Baud       : N/A
  448.     Use DOS Intr.  : NO                   <- DOS INTR MUST BE TURNED OFF!
  449.     Shrink         : YES                  <- YOU MUST HAVE SHRINK ON!
  450.     Turn off pause : N/A
  451.  
  452.  
  453.     "N/A" means that they have not effect on the operation of CBV.  If the
  454.     user does not want ANSI displays then CBV will strip ANSI as needed.
  455.     The option for pause is ignored by CBV.
  456.  
  457.     "??" means that these values are strictly your preference.
  458.  
  459.  (CBV160)  9
  460.  
  461.  
  462.                 ┌─────────────────────────────────────────┐
  463.                 │▐▐▐▐▐▐▐▐▐▐· CBV CONFIGURATION ·▌▌▌▌▌▌▌▌▌▌│
  464.                 └─────────────────────────────────────────┘
  465.  
  466.  
  467.  
  468.     You must run the configuration program before using CBV.  There are
  469.     many system dependant values which need to be altered to reflect your
  470.     system's configuration.  CBV has the ability to alter the user's SL,
  471.     DSL,  ARs,  DARs,  Exemptions,  and Restrictions.  Most of the fields
  472.     are self explanatory.  CBV does simple error checking,  and will not
  473.     correct values designed to cause problems.  CBVCFG is divided into five
  474.     sections,  main,  security,  userrec,  modem,  and long distance.
  475.  
  476.     The only difference between UNREGISTERED SHAREWARE versions and REGISTERED
  477.     versions is a 3 second shareware notification message sent to users.
  478.  
  479.     ▐ MAIN MENU
  480.  
  481.  
  482.       (A) `Goto Security Validation Menu         '
  483.       (B) `Goto Modified "userrec" Menu          '
  484.       (C) `Goto Modem Menu                       '
  485.       (D) `Goto Long Distance Menu               '
  486.       (E) `Goto Miscellaneous Menu               '
  487.  
  488.          The above options change to their respective menus.
  489.  
  490.       (F) `BBS Phone Number       (XXX)XXX-XXXX  '    {404-426-6426}
  491.  
  492.          Change this number to reflect your BBSes phone number.  This
  493.          is used only when CBV displays the example phone number entry.
  494.          It is reccommended you enter your BBS phone number into the
  495.          "CBVTRASH.DAT" file too.  (Well,  only other restriction)
  496.  
  497.       (G) `PATH to main BBS directory            '
  498.  
  499.          Enter the <drive\path> to your main BBS directory.  This is the
  500.          same directory where BBS.EXE resides.  If not properly set CBV
  501.          will be unable to locate the file "RESTORE.WWV" and will not be
  502.          able to determine if the BBS is running under SHRINK.
  503.  
  504.       (S) `Save Configuration and Quit           '
  505.  
  506.          Choose this option to save any changes you have made to your
  507.          configuration.  After saving the program will exit to the previous
  508.          task,  usually DOS.
  509.  
  510.       (X) `eXit without saving                   '
  511.  
  512.          Choose this option NOT to save any changes you have made to your
  513.          configuration.  This is good if you forgot something or changed
  514.          something inadvertently.
  515.  
  516.  (CBV160)  10
  517.  
  518.  
  519.     ▐▐ SECURITY
  520.  
  521.  
  522.       (A) `Maximum SL allowed to use CBV         '
  523.  
  524.          This option specifies the highest SL a user can have and still use
  525.          the call back verification program.
  526.  
  527.       (B) `Validated SL                          '    (   0 / 255 )
  528.       (C) `Validated DSL                         '    (   0 / 255 )
  529.  
  530.          These options specify the SL and DSL given to users who
  531.          sucessfully complete the call back verification.
  532.  
  533.       (D) `Validated AR                          '    { }
  534.       (E) `Validated DAR                         '    { }
  535.  
  536.          These options specify the AR and DAR flags given to users who
  537.          sucessfully complete the call back verification.  Press the letter
  538.          of the flag you wish to toggle on or off.  To exit the routine
  539.          without making changes press the Escape key,  otherwise press the
  540.          RETURN key to keep changes.  Valid keys are "ABCDEFGHIJKLMNOP".
  541.  
  542.       (F) `Validated Restrictions                '    { }
  543.  
  544.          This options controls which restrictions are active on callers who
  545.          sucessfully complete the call back verification.  Press the letter
  546.          of the restriction you wish to toggle on or off.  To exit the
  547.          routine without making changes press the Escape key,  otherwise
  548.          press the RETURN key to keep changes.   Valid keys are
  549.          "LCMA*PEVKNU".
  550.  
  551.       (G) `Validate Exemptions                   '    { }
  552.  
  553.          This option controls which exemptions a user gets once they
  554.          sucessfully complete the call back verification.  Press the number
  555.          of the restriction you wish to toggle on or off.  To exit the
  556.          routine without making changes press the Escape key,  otherwise
  557.          press RETURN to keep changes.  Valid keys are "1234".
  558.  
  559.       (H) - (M)  'LD Validated ......            '
  560.  
  561.          These options work identically to their above counterparts but
  562.          are given to callers who sucessfully complete call back
  563.          verification and are long distance from the BBS.  This includes
  564.          both callers long distance within and outside the local calling
  565.          areas.
  566.  
  567.       (Q) `Quit to Main Menu                     '
  568.  
  569.          This option will return you to the main menu.
  570.  
  571.  (CBV160)  11
  572.  
  573.  
  574.     ▐▐▐ USERREC
  575.  
  576.  
  577.     You only need to modify the values given in this section if you have
  578.     made changes to the size or layout of your user file.  CBV uses the
  579.     name and SL fields to make sure that it has the correct user,  it uses
  580.     the length field to see if the user file is of the correct length.  To
  581.     obtain the values necessary for this section you will need to compile
  582.     and run the program "DISPLAY.C" and write down the values it lists.
  583.  
  584.                                                                 [4.22]
  585.       (A) `Length of structure "userrec"        '    [ 700       1024]
  586.  
  587.         Enter the length of the your "userrec" structure.  The default
  588.         value is 700,  which is accurate for stock WWIV boards.
  589.                                                                [4.22]
  590.       (B) `Offset to "userrec.name"             '     [   0 ]  [   0]
  591.       (C) `Offset to "userrec.phone"            '     [  59 ]  [  59]
  592.       (D) `Offset to "userrec.passwd"           '     [  72 ]  [ 165]
  593.       (E) `Offset to "userrec.note"             '     [  99 ]  [ 192]
  594.       (F) `Offset to "userrec.sl"               '     [ 391 ]  [ 584]
  595.       (G) `Offset to "userrec.dsl"              '     [ 392 ]  [ 585]
  596.       (H) `Offset to "userrec.exempt"           '     [ 393 ]  [ 586]
  597.       (I) `Offset to "userrec.ar"               '     [ 444 ]  [ 706]
  598.       (J) `Offset to "userrec.dar"              '     [ 446 ]  [ 708]
  599.       (K) `Offset to "userrec.restrict"         '     [ 448 ]  [ 710]
  600.  
  601.         The above fields are the offsets from the beginning of the
  602.         structure "userrec" to the beginning of the field.  If any of these
  603.         is not correct possible corruption of the user file is possible.
  604.                                                                [4.22]
  605.       (L) `RESTORE.WWV - ACTSL offset           '     [   0 ]  [ 257]
  606.  
  607.         This one is very important.  If you are running WWIV versions 4.20a
  608.         you may have to modify the value here.  For all 4.20 versions the
  609.         value can be left at 0 or 265.  WWIV version 4.21 should be 267.
  610.         You can find out the exact value by examining the source file
  611.         SHRINK.C which comes as part of the WWIV source file.  Check the
  612.         procedure that writes RESTORE.WWV,  and if the variable ACTSL is
  613.         the last variable written leave this setting at 0,  else enter
  614.         its offset from the first value to be written.  Refer to the
  615.         program GETACTSL.EXE and its documentation.
  616.  
  617.       (M) `Configure using AUTOCBV.CFG          '
  618.  
  619.         Choose this option if you have compiled and run AUTOCFG.C.  It will
  620.         auto-enter entries A-K.  If the file is not found it will beep
  621.         when chosen and "(NOT FOUND)" will be displayed next to the entry.
  622.  
  623.       (Q) `Quit to Main Menu                    '
  624.  
  625.          This option will return you to the main menu.
  626.  
  627.  (CBV160)  12
  628.  
  629.  
  630.     ▐▐▐▐ MODEM
  631.  
  632.  
  633.       (A) `Seconds to delay from hangup to callback'    (  1 / 59 )
  634.  
  635.          This is the time CBV will wait from sucessful disconnection before
  636.          attempting to make the call back.  This default value is "3"
  637.          seconds,  and rarely should it ever be increased beyond 10.
  638.  
  639.       (B) `Seconds to keep DTR lowered for hangup  '    (  1 / 59 )
  640.  
  641.          This is the time CBV will keep DTR "Data Transmit Ready" lowered.
  642.          This is the primary method CBV uses to disconnect a caller.  This
  643.          may need adjustment if your modem in unusually slow to react to
  644.          changes in DTR settings.  The default setting is "2" seconds.
  645.  
  646.       (C) `Perform CTS-RTS flow control            '     ( yes / NO )
  647.  
  648.          Set this to "YES" if you are using a high speed modem where you
  649.          have the communications port locked to a specified speed.
  650.          Normally CBV simply uses XON/XOFF checking,  but high speed modems
  651.          normally use this method to control when it is okay to transmit
  652.          characters.
  653.  
  654.       (D) `Command to use for dialing              '     ( ATDT )
  655.  
  656.          Enter the command your modem uses to DIAL.  You may use the tilde
  657.          character "~" for half-second delays.
  658.  
  659.       (E) `Command to use to hangup                '     ( +++~~~ATH0 )
  660.  
  661.          Normally CBV uses direct DTR control to disconnect the user,
  662.          however some modems fail to respond to DTR control.  This option
  663.          allows you to specify the command required to hangup your modem.
  664.          You may use the tilde character "~" for half-second delays.
  665.  
  666.       (Q) `Quit to Main Menu                    '
  667.  
  668.          This option will return you to the main menu.
  669.  
  670.  (CBV160)  13
  671.  
  672.  
  673.     ▐▐▐▐▐ LONG DISTANCE
  674.  
  675.  
  676.       (A) `Perform In-AREAC LD Validation        '    ( yes / {NO} )
  677.  
  678.          Set this option to "YES" if you want CBV to verify callers who are
  679.          long distance from the BBS but within the local area code(s).
  680.          Caller will be disconnected to avoid unnecessary expense.
  681.  
  682.       (B) `Perform Out of AREAC LD Validation    '    ( yes / {NO} )
  683.  
  684.          Set this option to "YES" if you want CBV to verify caller who are
  685.          long distance from the BBS and outside the local area code(s).
  686.          Caller will be disconnected to avoid unnecessary expense.
  687.  
  688.       (C) `LD Validation WINDOW begins at        '    ( 00:00 )
  689.       (D) `LD Validation WINDOW ends at          '    ( 00:00 )
  690.  
  691.          These two options if set control when CBV can make long distance
  692.          call back verifications.  They have no effect if option "A" is set
  693.          to NO.  The values are entered in military format,  "00:00" to
  694.          "24:00".  To leave the value unchanged press the Escape key else
  695.          press ENTER or complete the time field.
  696.  
  697.       (F) `Long Distance ACCESS Code             '    ( "1-" )
  698.  
  699.          Important,  normally most long distance calls are performed by
  700.          prepending a "1-" to the phone number.  There are some types of
  701.          long distance services that require some type of special code to
  702.          use them.  If you belong to one of these services then enter that
  703.          code here else leave it set to "1-".
  704.  
  705.       (Q) `Quit to Main Menu                    '
  706.  
  707.          This option will return you to the main menu.
  708.  
  709.  (CBV160)  14
  710.  
  711.  
  712.     ▐▐▐▐▐▐ MISCELLANEOUS
  713.  
  714.  
  715.       (A) `Using WWIV version 4.20+              '    ( yes or NO )
  716.  
  717.          Set this to "YES" if you are using WWIV versions 4.20 or greater,
  718.          otherwise the user's SL will not be properly updated.
  719.  
  720.       (B) `Compare phone numbers (logon/entry)   '    ( yes or NO )
  721.  
  722.          Set this to "YES" if you want CBV to notify you in the current
  723.          SysOp log if the number used by the user for verification was
  724.          different from the one they entered when initially logging onto
  725.          the BBS.  If also using option C (below) the number placed in
  726.          the note field will be preceeded by "****".  The user will also
  727.          be queried for the reason of the difference.  If you are using
  728.          free-form phone numbers this may not work correctly.
  729.  
  730.       (C) `Place phone numbers in "userrec.note" '    ( yes or NO )
  731.  
  732.          Set this to "YES" if you want CBV to place the verification phone
  733.          number into the user's note field.
  734.  
  735.       (D) `Auto-Update "CBVTRASH.DAT" file.      '    ( yes or {NO} )
  736.  
  737.          Set this to "YES" if you want CBV to place the verification phone
  738.          number into the trash file.  This can be used to automatically
  739.          prevent users from obtaining mulitple accounts via CBV.
  740.  
  741.       (E) `Use "CBVCALLS.DAT" Call Only File     '    ( yes or NO )
  742.  
  743.          Normally CBV determines if a call is long-distance by either
  744.          comparing the areacode entered by the user to the entries in the
  745.          "CBVAREAC.DAT" file or by asking the user.  This helps prevents
  746.          incurring unnecessary expense.  This option is ignored when call
  747.          is determined to be out of areacode long distance.
  748.  
  749.          If this option is also set CBV will check to see if the
  750.          AREACODE-PREFIX combination exist in the Call Only File,  if not
  751.          the user will be shown the "CANTCALL.CBV" message.  This can be
  752.          used to insure that calls are made only to certain AREACODE-PREFIX
  753.          combinations.  Please note,  if the AREACODE-PREFIX combination
  754.          does not exist in the "CBVCALLS.DAT" file and this option is turned
  755.          on only those numbers matching will be called.
  756.  
  757.          If you wish to simply lockout AREACODE-PREFIX combinations then
  758.          make the entry into the "CBVTRASH.DAT" file.
  759.  
  760.  
  761.  (CBV160)  15
  762.  
  763.  
  764.     ▐▐▐▐▐▐ MISCELLANEOUS - Continued
  765.  
  766.  
  767.       (F) `Hangup after ALL verifications        '    ( yes or NO )
  768.  
  769.          If set to YES after any successful verification the caller will be
  770.          disconnected.  You should inform the caller about this in one of
  771.          the user messages,  preferably in "VERIFIED.CBV".
  772.  
  773.  
  774.       (G) `Perform DIRECT Screen Writes          '    ( yes or NO )
  775.  
  776.          Some multi-tasking operating systems lockup when programs write
  777.          directly to the screen,  leaving this option set to "NO" can
  778.          alleviate this problem.  Setting this option to "YES" will however
  779.          greatly increase local screen updates.
  780.  
  781.       (H) `Operate in QUITE mode                 '    ( yes or NO )
  782.  
  783.          If "YES" CBV will not beep on the local console UNLESS there is
  784.          a fatal error or warning.  CBV normally sounds a "bell" whenever
  785.          the user makes invalid character entries,  this option when turned
  786.          on will filter the "bells" from the local console.
  787.  
  788.       (I) `Number of attempts to call back       '    ( { 1 } / 10 )
  789.  
  790.          This setting controls how many times CBV will attempt to call back
  791.          the user in one session.
  792.  
  793.       (J) `Minimum time granted in CBV (min)     '    (  0    / 20 )
  794.  
  795.          This option can be used to make sure a user has a minimum amount
  796.          of time to complete the verification process.  If set to 0 then
  797.          the user will simply have their normal timeleft as defined by
  798.          the BBS,  if set to any other value other than 0 then the users
  799.          time will be increased to that value but never decreased.  Please
  800.          note that when the user exits the verification process that this
  801.          option will not change the BBS defined timeleft.
  802.  
  803.       (K) `Time allowed between keystrokes (sec) '    (  180  / 600 )
  804.  
  805.          This option is used to define the remote/local keyboard timeout.
  806.          The minimum value is 90 seconds.  This can be changed to suit
  807.          the needs of your users.  If a character is not received either
  808.          from the modem or local keyboard within the specified number of
  809.          seconds since the lastone the user will be returned to the BBS.
  810.  
  811.       (Q) `Quit to Main Menu                    '
  812.  
  813.          This option will return you to the main menu.
  814.  
  815.  
  816.  (CBV160)  16
  817.  
  818.  
  819.                     ┌──────────────────────────────────┐
  820.                     │▐▐▐▐▐▐▐▐▐▐· APPENDICES ·▌▌▌▌▌▌▌▌▌▌│
  821.                     └──────────────────────────────────┘
  822.  
  823.  
  824.     ▐ A. ERROR MESSAGES
  825.  
  826.  
  827.     CBV when properly setup should not error.  However not everything goes
  828.     right and CBV was written to take this into account.  There are two
  829.     types of errors,  FATAL and NOTICE.
  830.  
  831.     FATAL errors are just what you expect,  errors that in some way prevent
  832.     CBV from continuing.  Usually these are caused by improper installation
  833.     and/or configuration of the program.
  834.  
  835.     NOTICEs occur when CBV encounters something which the System Operator
  836.     should be made aware of.  These usually involve problems with the user,
  837.     like being locked out or not wishing to use the door.
  838.  
  839.  
  840.     FATAL ERRORS :
  841.  
  842.      1> CHAIN.TXT PATH/FILENAME NOT FOUND ON COMMAND LINE.
  843.  
  844.        a) Verify that the %1 was entered as part of the filename
  845.           specification in CHAINEDIT.
  846.  
  847.        b) If using a batch file to run CBV verify that actual call of CBV
  848.           uses the DOS SUBSITUTION variable %1.
  849.  
  850.      2> UNABLE TO FIND FILE "filename.ext".
  851.  
  852.        a) This error should only occur when CBV is executed from a batch
  853.           file that specifies the path/filename to CHAIN.TXT and that
  854.           specification is incorrect.
  855.  
  856.      3> ERROR READING FILE "filename.ext".
  857.  
  858.        a) Verify that the CHAIN.TXT file is not corrupted,  or that the
  859.           file specified as being CHAIN.TXT really is.
  860.  
  861.      4> CONFIG FILE NOT FOUND.
  862.  
  863.        a) If executing CBV from a batch file make sure that you switch to
  864.           the proper directory.
  865.        b) Run CBVCFG to create the config file.
  866.  
  867.      5> UNABLE TO READ CONFIG FILE.
  868.  
  869.        a) Check to see if the config file is corrupted.  If it is then
  870.           delete it and rerun CBVCFG.
  871.  
  872.  (CBV160)  17
  873.  
  874.  
  875.     ▐ A. ERROR MESSAGES - Continued
  876.  
  877.  
  878.      6> CONFIG FILE NOT CORRECT FOR THIS VERSION.
  879.  
  880.        a) Delete the configuration file and run the configuration program
  881.           included within this package.
  882.  
  883.      7> FAILED TO INITIALIZE COMMUNICATIONS MODULE.
  884.  
  885.        a) Verify that the communications port passed in CHAIN.TXT is
  886.           correct.  If it is and you still receive this error then there is
  887.           a hardware incompatibilty and little can be done.
  888.  
  889.      8> CANNOT FIND FILE *.CBV.  (where * = paticular user message file)
  890.  
  891.        a) If executing CBV from a batch file make sure that you switch to
  892.           the proper directory.
  893.        b) Recreate the proper user message file.
  894.  
  895.      9> CANNOT FIND FILE CBVTRASH.DAT
  896.  
  897.        a) as per error #8
  898.  
  899.     10> COULD NOT OPEN USER FILE.
  900.  
  901.        a) CBV obtains the path/filename for the file USER.LST by reading
  902.           the DATA pathname from CHAIN.TXT.  Check to be sure that the
  903.           value for the data path in CHAIN.TXT is correct.  (Line 17)
  904.  
  905.     11> ERROR IN SIZE OF USER FILE.
  906.  
  907.        a) This will occur if filesize of the file USER.LST is not evenly
  908.           divisable by size of the userrec in the configuration.  If you
  909.           have modified your systems userrec you must compile and run the
  910.           DISPLAY.C program included with the CBV archive file.
  911.  
  912.     12> USER FILE ACCESS FAILED,  USER NAME MISMATCH
  913.        a) This will occur if the value entered for "userrec.name" offset is
  914.           incorrect.  Compile DISPLAY.C with your current source code and
  915.           then run the program and write down the values it lists.  Make
  916.           sure that these are the same as in CBVCFG menu USERREC.
  917.  
  918.     13> USER FILE ACCESS FAILED,  USER SL MISMATCH
  919.        a) Same as #12 but in reference to "userrec.sl".
  920.  
  921.     14> UNABLE TO LOCATE RESTORE.WWV - (MUST USE SHRINK)
  922.  
  923.        a) Make sure your CHAINEDIT has SHRINK set to "YES" or "ON".
  924.        b) Make sure the CBVCFG entry for Main BBS Directory is correct.
  925.  
  926.  (CBV160)  18
  927.  
  928.  
  929.     ▐ A. ERROR MESSAGES - Continued
  930.  
  931.  
  932.     NOTICE ERRORS :
  933.  
  934.      1> CALLER'S SECURITY LEVEL IS TO HIGH TO USE CBV.
  935.  
  936.        a) Simple,  The caller's SL is higher than the CBVCFG option for
  937.           maximum SL allowed to use program.
  938.  
  939.      2> COULD NOT RECONNECT,  CBV FAILED.
  940.  
  941.        a) This is reported whenever CBV attempts call back and cannot
  942.           reestablish the link.
  943.  
  944.     There are other notices that CBV will output,  most of all will appear
  945.     in the current SysOp log.  Most of these notices are just for
  946.     informational purposes,  there is usually no corrective action needed.
  947.  
  948.  (CBV160)  19
  949.  
  950.  
  951.     ▐▐ B. SESSION CONTROL
  952.  
  953.  
  954.     CBV has a SysOp interface loosely based upon WWIV SysOp controls.
  955.     They are available through all parts of CBV EXCEPT during the actual
  956.     call back attempt.  During that time CBV will not update the status
  957.     line nor will it respond to local key presses.
  958.  
  959.     The status line appears at the bottom of the local display,  it is
  960.     routinely updated throughout the duration of the session.  It is
  961.     divided into five sections.   The first part displays the user's user
  962.     number on the system,  the second part displays their name.  Section
  963.     three displays the current communication parameters to include the
  964.     current communications port and whether or not flow control is being
  965.     used.  The last to sections display time used and time left.
  966.  
  967.     The following keyboard commands are available during the session.
  968.  
  969.     F5 = Hangup.        - disconnects user from BBS
  970.     F7 = Decrease Time  - lowers timeleft by 180 seconds
  971.     F8 = Increase Time  - raises timeleft by 180 seconds
  972.  
  973.  (CBV160)  20
  974.  
  975.  
  976.     ▐▐▐ C. CONTACTING THE AUTHOR
  977.  
  978.  
  979.     Comments,  suggestions,  questions,  and problems can be sent to the
  980.     author using the following methods.
  981.  
  982.     U.S. Mail        (the slowest)
  983.  
  984.     Mr. Chris Holko
  985.     1029 Franklin Road Suite 4C
  986.     Marietta, GA 30067
  987.  
  988.  
  989.     WWIVNet
  990.  
  991.     E-Mail #3@4401 from any WWIVNet BBS.
  992.               (14401 - link)
  993.               (4401  - Ice)
  994.  
  995.     BBS
  996.  
  997.     Iconian Gateway WWIV  (Reg #11238)
  998.     (404)426-6426
  999.     PcPursuit via GAATL
  1000.     300-14400/MNP5        (v32/v32bis/CSP)
  1001.     670 MB Online Storage / and soon a CDROM
  1002.  
  1003.     E-Mail #3 "Chris"
  1004.  
  1005.  
  1006.     REGISTRATION forms must be sent via U.S. Mail.
  1007.  
  1008.  
  1009.  (CBV160)  21
  1010.  
  1011.  
  1012.     ▐▐▐▐ D. USER RESTRICTIONS
  1013.  
  1014.  
  1015.     The following is a list of restrictions that can be placed on users of
  1016.     WWIV BBSes.  This is provided so that you may accurately alter values
  1017.     entered in the CBVCFG Security Validation Menu.
  1018.  
  1019.     Restriction         - Description
  1020.  
  1021.     A - Automessage     The caller cannot change the automessage.
  1022.     C - Chat            Caller won't be able to request chats with you.
  1023.     E - E-Mail          The caller cannot send e-mail.
  1024.     L - Logons          Limits the caller to 1 logon per day.
  1025.     N - WWIVnet         The caller cannot use WWIVnet on your board.
  1026.     P - Posts           The caller cannot post messages.
  1027.     V - Voting          The caller is not permitted to vote.
  1028.     * - Anonymous       The caller cannot post anonymously.
  1029.     M - Messages        Posts by the caller will not be accessible by your
  1030.                          other callers until either yourself or a co-sysop
  1031.                          have read and approved the message for public
  1032.                          viewing.
  1033.  
  1034.  
  1035.     Exemption           - Description
  1036.  
  1037.       1                 Exempt from file ratio
  1038.       2                 Exempt from time  (not sure)
  1039.       3                 Exempt from all   (unknown)
  1040.       4                 Exempt from post/call ratio
  1041.  
  1042.  (CBV160)  22
  1043.  
  1044.  
  1045.     ▐▐▐▐▐ E. CBVCFG.DAT LAYOUT
  1046.  
  1047.  
  1048.     This structure of CBVCFG.DAT is provided for informational purposes
  1049.     only,  it should not be modified except by the CBVCFG program.
  1050.  
  1051.     ConfigRec           = RECORD
  1052.       header            : STRING[15];
  1053.       use_note_field,                  (* place number in note field      *)
  1054.       compare_fons,                    (* compare userrec.phone 2 entry?? *)
  1055.       update_trash,                    (* auto-update trash file          *)
  1056.       allow_ld,                        (* allow in-areac ld calls         *)
  1057.       allow_out_ld,                    (* allow out of areac ld calls     *)
  1058.       CTS_RTS,                         (* perform CTS/RTS checking        *)
  1059.       hangup_after,                    (* hangup after all verifications  *)
  1060.       wwiv_421,                        (* using wwiv 4.20a and above      *)
  1061.       use_callfile,                    (* CANCALL.DAT - ac-pr to only call*)
  1062.       direct_write,                    (* perform non-bios screen updates *)
  1063.       tbool1,tbool2     : BOOLEAN;
  1064.       retry_attempts,                  (* call back attempts per session  *)
  1065.       delay_time,                      (* delay between hangup/callback   *)
  1066.       drop_delay,                      (* delay to keep DTR lowered       *)
  1067.       min_time,                        (* min time granted for door use   *)
  1068.       hang_time,                       (* no entry hangup time            *)
  1069.       max_SL,                          (* max sl to use door              *)
  1070.       LC_SL,                           (* New SL when validated           *)
  1071.       LC_DSL,                          (* New DSL when validated          *)
  1072.       LC_exempt,                       (* New Exempt when validated       *)
  1073.       LD_SL,                           (* New SL when Long-Dist validated *)
  1074.       LD_DSL,                          (* New DSL when Long-Dist validated*)
  1075.       LD_exempt        : BYTE;         (* New Exempt when LD validated    *)
  1076.       IRQLevel,                        (* not used                        *)
  1077.       LC_AR,                           (* ARs when validated              *)
  1078.       LC_DAR,                          (* DARs when validated             *)
  1079.       LC_REST,                         (* Restrictions when validated     *)
  1080.       LD_AR,                           (* LD ARs when validated           *)
  1081.       LD_DAR,                          (* LD DARs when validated          *)
  1082.       LD_REST          : WORD;         (* LD Restrictions when validated  *)
  1083.       bbs_areac,bbs_prefix,
  1084.       bbs_suffix       : STRING[4];    (* BBS phone number                *)
  1085.       LD_PREFIX        : STRING[20];   (* 1- or whatever                  *)
  1086.       dialcommand,                     (* command to dial on modem        *)
  1087.       hangupcmd        : STRING[30];   (* command to hangup the modem     *)
  1088.       bbsdirectory     : STRING[60];   (* path to main BBS directory      *)
  1089.       loc_actsl,                       (* byte location in restore.wwv    *)
  1090.       userreclen,                      (* lenght of structure userrec     *)
  1091.       offset_name,                     (* offset for name field           *)
  1092.       offset_phone,offset_passwd,
  1093.       offset_note,offset_sl,
  1094.       offset_dsl,offset_exempt,
  1095.       offset_ar,offset_dar,
  1096.       offset_rest      : WORD;
  1097.       version1,version2,               (* version checking - 2 flags      *)
  1098.       LastDate,                        (* NOT USED                        *)
  1099.       LD_WIN_START,                    (* seconds since midnight timing   *)
  1100.       LD_WIN_STOP      : LONGINT;      (* for ld window                   *)
  1101.     END;
  1102.  
  1103.  
  1104.