Tillbaka till svenska Fidonet
English   Information   Debug  
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12852
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4393
FN_SYSOP   41678
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13599
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16069
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22090
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   926
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   0/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1121
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   3207
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13260
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/340
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4288
WIN95_OLD1   0/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   32712
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2053
DOS_INTERNET   0/196
duplikat   6002
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33888
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   24100
FIDONEWS_OLD1   0/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
Möte FTSC_PUBLIC, 13599 texter
 lista första sista föregående nästa
Text 348, 373 rader
Skriven 2005-05-30 21:40:53 av Michiel Broek (2:280/2802)
Ärende: FSP-1018 rev 2 part 2
=============================
           e.g. M_SKIP "config.sys 125 2476327846"

           Implementation note: when receive M_SKIP mailer should wait
           some time after session end before next poll to that link
           to prevent continuous poll.


  5.6 Example of Frame Exchange in a Simple Binkp Session
  -------------------------------------------------------

   Originating side (1:1/1.1@fidonet) has file1 for answering side
   (2:2/2.2@fidonet) and answering side has file2 for originating side

   +----------------------------------------------------------------+
   | Originating side               | Answering side                |
   |--------------------------------+-------------------------------|
   | M_NUL "SYS ..."                | M_NUL "SYS ..."               |
   | M_NUL "ZYZ ..."                | M_NUL "ZYZ ..."               |
   | M_NUL "LOC ..."                | M_NUL "LOC ..."               |
   | M_NUL "VER ..."                | M_NUL "VER ..."               |
   | M_NUL "OPT ..."                | M_NUL "OPT ..."               |
   | M_ADR "1:1/1.1@fidonet"        | M_ADR "2:2/2.2@fidonet"       |
   | M_PWD "password"               | (waiting for a password from  |
   |                                | remote)                       |
   |--------------------------------+-------------------------------|
   | (waiting for password          | M_OK "secure"                 |
   | acknowledgement)               |                               |
   |--------------------------------+-------------------------------|
   | (got M_OK)                     | M_FILE "file2 200 42342434 0" |
   |--------------------------------+-------------------------------|
   | M_FILE "file1 100 423424244 0" | data                          |
   |--------------------------------+-------------------------------|
   | data                           | data                          |
   |--------------------------------+-------------------------------|
   | data                           | data                          |
   |--------------------------------+-------------------------------|
   | M_EOB                          | (got file1, acknowledging it) |
   |--------------------------------+-------------------------------|
   | (got file2, acknowledging it)  | M_GOT "file1 100 423424244"   |
   |--------------------------------+-------------------------------|
   | M_GOT "file2 200 42342434"     | data                          |
   |--------------------------------+-------------------------------|
   |                                | M_EOB                         |
   +----------------------------------------------------------------+


6. Protocol States
------------------

   The protocol has two major stages: session setup (different for
   originating side and answering side) and file transfer (where state
   machined for both sides are the same). Methods for initiating
   connection as well as numerical values for particular timeouts are
   dependent on the underlying layer's protocol suite and are not
   considered here. Mailer MAY allow configuration of timeouts in
   reasonably wide range to cover all supported transport protocols.

   The Finite State Machine notation is used throughout this section
   as defined by [FTS-0001].

  6.1 Session Setup Stage
  -----------------------

   Originating side should initiate a binkp session according to Table
   1. Answering side should be able to act according to Table 2. Any
   optional extensions of the handshake procedure MUST NOT confuse the
   other side, which may choose at it's discretion to follow this
   minimal implementation. Upon successful handshake, both sides
   follow Table 3 (file transfer stage). That's why terms Answering
   side and Originating side were chosen for this specification
   instead of Client and Server - both sides play the same roles, and
   their state machines differ in session setup stage only.

   Session setup stage has the following roles

     * Authentication (REQUIRED). Answering side, upon reception of a
       password (common secret word) from Originating side, decides
       whether the password really matches the list of presented
       addresses, and either acknowledges it by sending M_OK frame or
       rejects by sending M_ERR frame. This mechanism is called Basic
       Authentication Scheme and MUST be supported by all Mailers.
       Basic Authentication Scheme has the following limitations:
          * If Originating side presented multiple addresses, the
            password for all of the addresses must be the same to
            prevent security bugs. (May be solved by "hide aka
            mechanism" usage, don't described in this text.)
          * Cleartext reusable passwords are passed over a network
            (may be solved by CRAM extension).
          * Verification is made on Answering side only, thus
            Originating side has no way to verify Answering side.
            (May be solved by 'IP address restriction' extension).
     * Indicating protocol options (OPTIONAL). Sides may exchange
       specially formatted M_NUL messages to indicate supported
       extensions. Sides MAY use another technique to indicate
       extensions, but using M_NUL "OPT ..." frame is recommended
       for compatibility.


    6.1.1 Originating Side
    ----------------------

   Originating side sends M_ADR and M_PWD frames, waits for successful
   authentication acknowledgement from the Answering side (M_OK frame)
   and goes to file transfer stage; or receive M_ERR frame and close
   connection. Originating side MUST NOT wait before sending M_ADR
   frame, i.e. this frame should be send just after setting up a
   connection on underlying layer. Originating side MUST NOT wait
   before sending M_PWD except after reception of M_ADR frame. The
   term wait in this paragraph means do not send anything while
   expecting data from remote.

                Table 1: Session setup, originating side
   +-----------------------------------------------------------------+
   | #  | Name       | Predicate(s)    | Action(s)              |Next|
   |----+------------+-----------------+------------------------+----|
   | S0 | ConnInit   |                 | Attempt to             | S1 |
   |    |            |                 | establish              |    |
   |    |            |                 | connection             |    |
   |----+------------+-----------------+------------------------+----|
   | S1 | WaitConn   | Connection      | Send M_NUL frames with | S2 |
   |    |            | established     | system info (optional) |    |
   |    |            |                 |                        |    |
   |    |            |                 | Send M_ADR frame with  |    |
   |    |            |                 | system addresses       |    |
   |    |            |                 |                        |    |
   |    |            |                 | Set Timer              |    |
   |    |            |                 |                        |    |
   |    |            |                 | See if we have         |    |
   |    |            |                 | password for the       |    |
   |    |            |                 | remote                 |    |
   |    |            |-----------------+------------------------+----|
   |    |            | Connection      | Report no              |exit|
   |    |            | refused         | connection             |    |
   |----+------------+-----------------+------------------------+----|
   | S2 | SendPasswd | Yes, we have a  | Send M_PWD "password"  | S3 |
   |    |            | password        | frame                  |    |
   |    |            |                 | Reset Timer            |    |
   |    |            |-----------------+------------------------+----|
   |    |            | No, there's no  | Send M_PWD "-"         | S3 |
   |    |            | password        | frame                  |    |
   |    |            |                 | Reset timer            |    |
   |----+------------+-----------------+------------------------+----|
   | S3 | WaitAddr   | M_ADR frame     | See if answering side  | S4 |
   |    |            | received        | presented the address  |    |
   |    |            |                 | we've called           |    |
   |    |            |-----------------+------------------------+----|
   |    |            | M_BSY frame     | Report remote is busy  |exit|
   |    |            | received        |                        |    |
   |    |            |-----------------+------------------------+----|
   |    |            | M_ERR frame     | Report error           |exit|
   |    |            | received        |                        |    |
   |    |            |-----------------+------------------------+----|
   |    |            | M_NUL frame     | Ignore or parse        | S3 |
   |    |            | received        |                        |    |
   |    |            |-----------------+------------------------+----|
   |    |            | Other known     | Report about unexpected|exit|
   |    |            | frame received  | frame, send M_ERR frame|    |
   |    |            |-----------------+------------------------+----|
   |    |            | Unknown frame   | Ignore                 | S3 |
   |    |            | received        |                        |    |
   |    |            |-----------------+------------------------+----|
   |    |            | Nothing happens | Wait                   | S3 |
   |    |            |-----------------+------------------------+----|
   |    |            | Timer Expired   | Report timeout         |exit|
   |----+------------+-----------------+------------------------+----|
   | S4 | AuthRemote | Yes, the address| See if we've sent a    | S5 |
   |    |            | was presented   | password for this      |    |
   |    |            |                 | address                |    |
   |    |            |-----------------+------------------------+----|
   |    |            | No, the address | Report we call(ed) the |exit|
   |    |            | was not         | wrong system; send     |    |
   |    |            | presented       | M_ERR frame            |    |
   |----+------------+-----------------+------------------------+----|
   | S5 | IfSecure   | Yes, we've sent | Wait for M_OK frame    | S6 |
   |    |            | a M_PWD frame   |                        |    |
   |----+------------+-----------------+------------------------+----|
   | S6 | WaitOk     | M_OK frame      | report secure or       | S7 |
   |    |            | received        | non-secure session     |    |
   |    |            |                 | (depends on sent pwd)  |    |
   |    |            |-----------------+------------------------+----|
   |    |            | M_BSY frame     | Report remote is busy  |exit|
   |    |            | received        | (Anwering side MAY     |    |
   |    |            |                 | report busy after      |    |
   |    |            |                 | reception of caller's  |    |
   |    |            |                 | addess)                |    |
   |    |            |-----------------+------------------------+----|
   |    |            | M_ERR frame     | Report error           |exit|
   |    |            | received        |                        |    |
   |    |            |-----------------+------------------------+----|
   |    |            | M_NUL frame     | Ignore or parse, may   | S6 |
   |    |            | received        | log arguments          |    |
   |    |            |-----------------+------------------------+----|
   |    |            | Other known     | Report unexpected      |exit|
   |    |            | frame received  | frame; send M_ERR frame|    |
   |    |            |-----------------+------------------------+----|
   |    |            | Unknown frame   | Ignore                 | S6 |
   |    |            | received        |                        |    |
   |    |            |-----------------+------------------------+----|
   |    |            | Nothing happens | Wait                   | S6 |
   |    |            |-----------------+------------------------+----|
   |    |            | Timer Expired   | Report timeout         |exit|
   +----+------------+-----------------+------------------------+----|
   | S7 | Opts       | We have more    | Send frames to         | T0 |
   |    |            | protocol        | negotiate protocol     |    |
   |    |            | extensions      | extensions             |    |
   +-----------------------------------------------------------------+

    6.1.2 Answering Side
    --------------------

   Originating side sends M_ADR and waits for M_ADR and M_PWD frames
   from remote. Upon receptions of these frames, it decides whether
   the password really matches the list of presented addresses, and
   either acknowledges it by sending M_OK frame (and goes to file
   transfer stage) or rejects by sending M_ERR frame (and
   disconnects). The term wait in this paragraph means do not send
   anything while expecting data from remote.

                 Table 2: Session setup, answering side
   +-----------------------------------------------------------------+
   | #  | Name     | Predicate(s)        | Action(s)            |Next|
   |----+----------+---------------------+----------------------+----|
   | R0 | WaitConn | Incoming connection | Send M_NUL frames    | R1 |
   |    |          | established         | with system info and |    |
   |    |          |                     | capabilities         |    |
   |    |          |                     | (optional).          |    |
   |    |          |                     | Send M_ADR frame     |    |
   |    |          |                     | with system addresses|    |
   |    |          |                     | Set Timer            |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Nothing happens     | Wait                 | R0 |
   |----+----------+---------------------+----------------------+----|
   | R1 | WaitAddr | M_ADR frame         | See if we have a     | R2 |
   |    |          | received            | password for each    |    |
   |    |          |                     | of the remote        |    |
   |    |          |                     | addresses            |    |
   |    |          |---------------------+----------------------+----|
   |    |          | M_ERR frame         | Report error         |exit|
   |    |          | received            |                      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | M_NUL frame         | Ignore or parse,     | R1 |
   |    |          | received            | optionally log.      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Other known frame   | Report unexpected    |exit|
   |    |          | received            | frame; send M_ERR    |    |
   |    |          |                     | frame                |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Unknown frame       | Ignore               | R1 |
   |    |          | received            |                      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Nothing happens     | Wait                 | R1 |
   |    |          |---------------------+----------------------+----|
   |    |          | Timer expired       | Report timeout       |exit|
   |----+----------+---------------------+----------------------+----|
   | R2 | IsPasswd | Yes, we have a      | Set Timer            | R3 |
   |    |          | password            |                      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Yes, but we have    | Send M_ERR frame     |exit|
   |    |          | several different   | Report               |    |
   |    |          | passwords for       | inconsistent         |    |
   |    |          | different addresses | password settings    |    |
   |    |          | of the remote       |                      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | No, there's no      | Set Timer            | R3 |
   |    |          | password            |                      |    |
   |----+----------+---------------------+----------------------+----|
   | R3 | WaitPwd  | M_PWD frame         | See if the           | R4 |
   |    |          | received            | password matches     |    |
   |    |          |                     | or if no password and|    |
   |    |          |                     | no password received |    |
   |    |          |---------------------+----------------------+----|
   |    |          | M_ERR frame         | Report error         |exit|
   |    |          | received            |                      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | M_NUL frame         | Ignore or parse,     | R1 |
   |    |          | received            | optionally log.      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Other known frame   | Report unexpected    |exit|
   |    |          | received            | frame; send M_ERR    |    |
   |    |          |                     | frame                |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Unknown frame       | Ignore               | R3 |
   |    |          | received            |                      |    |
   |    |          |---------------------+----------------------+----|
   |    |          | Nothing happens     | Wait                 | R3 |
   |    |          |---------------------+----------------------+----|
   |    |          | Timer Expired       | Report timeout       |exit|
   |----+----------+---------------------+----------------------+----|
   | R4 | PwdAck   | Yes, the password   | Send M_OK frame      | R5 |
   |    |          | matches             | Report secure        |    |
   |    |          |                     | session              |    |
   |    |          |---------------------+----------------------+----+
   |    |          | No password and got | Send M_OK frame      | R5 |
   |    |          | M_PWD "-" frame     | Report unsecure      |    |
   |    |          |                     | session              |    |
   |    |          |---------------------+----------------------+----|
   |    |          | No, password does   | Report password error|exit|
   |    |          | not match           | Send M_ERR           |    |
   +-----------------------------------------------------------------+
   | R5 | Opts     | We have more        | Send frames to       | T0 |
   |    |          | protocol extensions | negotiate protocol   |    |
   |    |          |                     | extensions           |    |
   +-----------------------------------------------------------------+


  6.2 File Transfer Stage
  -----------------------

   File transfer stage is based on two major routines. We call them
   Receive Routine and Transmit Routine. These routines perform some
   actions depending on their state variables. State variables are
   RxState for Receive Routine and TxState for Transmit Routine.

   RxState := { RxWaitF | RxAccF | RxReceD | RxWriteD | RxEOB | 
                RxDone } 
   TxState := { TxGNF | TxTryR | TxReadS | TxWLA | TxDone }

                         Table 3: File Transfer
   +-----------------------------------------------------------------+
   | #  | Name         | Predicate(s)        | Action(s)      | Next |
   |----+--------------+---------------------+----------------+------|
   | T0 | InitTransfer | none                | Set Timer      | T1   |
   |    |              |                     | Set RxState to |      |
   |    |              |                     | RxWaitF        |      |
   |    |              |                     | Set TxState to |      |
   |    |              |                     | TxGNF          |      |
   |----+--------------+---------------------+----------------+------|
   | T1 | Switch       | RxState is RxDone   | Report session | exit |
   |    |              | and TxState is      | complete       |      |
   |    |              | TxDone              |                |      |
   |    |              |---------------------+----------------+------|
   |    |              | Data Available in   | call Receive   | T2   |
   |    |              | Input Buffer        | routine        |      |
   |    |              |---------------------+----------------+------|
   |    |              | Free space exists   | call Transmit  | T3   |
   |    |              | in output buffer    | routine        |      |
   |    |              |---------------------+----------------+------|
   |    |              | Nothing happens     | Wait           | T1   |
   |    |              |---------------------+----------------+------|
   |    |              | Timer Expired       | Report Timeout | exit |
   |----+--------------+---------------------+----------------+------|
   | T2 | Receive      | Receive routine     | Set Timer      | T1   |
   |    |              | returned OK         |                |      |
   |    |              |---------------------+----------------+------|
   |    |              | Receive routine     | Close all      | exit |
   |    |              | returned Failure    | opened files   |      |
   |    |              |---------------------+----------------+------|
   |    |              | Receive routine     | Call Receive   | T2   |
   |    |              | returned Continue   | routine again  |      |
   |----+--------------+---------------------+----------------+------|
   | T3 | Transmit     | Transmit routine    | Set Timer      | T1   |
   |    |              | returned OK         |                |      |
   |    |              |---------------------+----------------+------|
   |    |              | Transmit routine    | Close all      | exit |
   |    |              | returned Failure    | opened files   |      |
   |    |              |---------------------+----------------+------|
   |    |              | Transmit routine    | Call Transmit  | T3   |
   |    |              | returned Continue   | routine again  |      |
   +-----------------------------------------------------------------+

   Tables 4-6 are not actually state machines, but routines called
   during file transfer stage


    Greetings, Michiel Broek

Email:   mbse@mbse.dds.nl
Fidonet: Michiel Broek at 2:280/2802

... You're not drunk if you can lie on the floor without hanging on.

--- MBSE BBS v0.71.2 (GNU/Linux-i386)
 * Origin: MBSE Linux BBS. Made in the Netherlands (2:280/2802)