This is an old revision of the document!
Table of Contents
SBBSecho
Synchronet's FidoNet EchoMail Program
Introduction
SBBSecho is an FTN echomail program (tosser/scanner) for Synchronet BBS version 2.0 and higher. SBBSecho is not a FidoNet mailer (you'll still need one of those, e.g. BinkIT).
As of SBBSecho v2.30 (Nov-2015), SBBSecho will also export FTN NetMail from the Synchronet mail base (data/mail
message base) to FTS-1 (*.msg
) files.
- This feature allows the gating of SMTP (Internet e-mail) to FTN netmail by sending email to “name@p<point>.f<node>.n<net>.z<zone>.fidonet” or “name@f<node>.n<net>.z<zone>.fidonet”. The Synchronet Mail Server rev 1.588 (Nov-24-2015) or later will accept email addressed in this manner and save the messages in the mail base as FidoNet netmail, when addressed to a local BBS user name or alias.
- This feature allows FidoNet netmail to be sent using JavaScript methods (e.g. via the Synchronet Web Server) as well as smbutil and postmsg.
In 2016, SBBSecho was overhauled and christened version 3. The documentation here is in the process of being updated to reflect all the changes in SBBSecho version 3. For more details about SBBSecho version 3, see Version 3.
Terminology
The terminology used with FidoNet networking technology can be as confusing as it is particular. In our FidoNet Glossary we attempt to define some terms we will be using through-out this article to describe the features and functions of SBBSecho. If you come across a term you aren't familiar with, please check the FidoNet Glossary.
Install
SBBSecho and its configuration program, EchoCfg, come with Synchronet BBS software (i.e. their executables can be found in your Synchronet exec
directory). So the program itself usually requires no special installation steps of its own.
Things you should have before you proceed:
- Your hub/uplink's FidoNet address
- Your hub/uplink's Internet hostname or IP address
- Your own FidoNet address (use
<zone>:<net>/9999
if you have not yet been assigned a FidoNet address) - Your hub-agreed-upon BinkP session password
- Your hub-agreed-upon packet password (optional)
- Your hub-agreed-upon AreaFix password (optional)
- An EchoList file for the network (e.g.
BACKBONE.NA
)
Message Group
Create a message group called “FidoNet” (or whatever is most appropriate for the network) in SCFG->Message Areas:
╔══════════════════════════════════════════════════════════╗ ║ FidoNet Group ║ ╠══════════════════════════════════════════════════════════╣ ║ │Long Name FidoNet ║ ║ │Short Name FidoNet ║ ║ │Internal Code Prefix FIDONET_ ║ ║ │Access Requirements ║ ║ │Sort Group by Sub-board Index Position ║ ║ │Clone Options ║ ║ │Export Areas... ║ ║ │Import Areas... ║ ║ │Message Sub-boards... ║ ╚══════════════════════════════════════════════════════════╝
EchoList
Now, import a list of the public message areas (“echoes”) from the network's standard EchoList (e.g. FidoNet's BACKBONE.NA
file) into your new message group using the Message Group “Import Areas...” option in SCFG:
╔═════════════════════════════════════════╗ ║ Import Area File Format ║ ╠═════════════════════════════════════════╣ ║ │subs.txt Synchronet Sub-boards ║ ║ │control.dat QWK Conference List ║ ║ │areas.bbs Generic Area File ║ ║ │areas.bbs SBBSecho Area File ║ ->│backbone.na FidoNet EchoList <- ║ │badareas.lst SBBSecho Bad Area List ║ ╚═════════════════════════════════════════╝
Area File
By default, SBBSecho will try to open an Area File (by default, data/areas.bbs
). The Area File can be used to associate FidoNet EchoTags with sub-boards configured in SCFGG. You can also specify downlinks and pass-through areas in an Area File, if need be. The Area File is optional, not strictly needed, when you have the “Automatically Add New Subs to Area List” option enabled and set to “List Only” in EchoCfg->EchoMail Settings.
To successfully operate without an Area File, you must have your hub configured in EchoCfg->Linked Nodes with its “Uplink for Message Groups” setting set to the short name of the message group you created in SCFG->Message Areas for this network.
You will need an Area File if you are to have any downlinks (nodes for which you are their hub to the network).
SCFG can also export a group of message areas (sub-boards) to an SBBSecho-compatible Area File using the Message Group “Export Areas...” option:
╔═══════════════════════════════════════╗ ║ Export Area File Format ║ ╠═══════════════════════════════════════╣ ║ │subs.txt Synchronet Sub-boards ║ ->│areas.bbs SBBSecho Area File <- ║ │backbone.na FidoNet EchoList ║ ╚═══════════════════════════════════════╝
If the AutoAddSubs
feature is enabled, sub-boards configured in SCFG->Message Areas may be automatically added to your Area File when the network hub (your uplink) has be configured in EchoCfg->Linked Nodes and the “Group Hub” setting for that link set to the name of the corresponding message group in SCFG->Message Areas. This Auto-Add procedure happens during SBBSecho initialization and is not dependent upon receiving any echomail messages for the configured message areas.
Format
Each line of the SBBSecho Area File (e.g. areas.bbs
) represents an EchoMail message area in the following format:
CODE TAG LINK [LINK] [...]
Where each field is separated by white-space (space or tab characters) and the fields are:
CODE
The CODE
field is the internal code of the sub-board.
Internal codes consist of a combination of the Message Group's “code prefix” and the Sub-board's “code suffix”. The full internal code may be as long as 16 characters and may not contain white-space or any invalid filename characters.
Pass-through Areas
Any unrecognized internal codes are considered pass-through (not imported into your BBS's message areas). Using “P
” for the internal code of pass-through areas will prevent warnings from being logged about the internal code not being found in your BBS's message base configuration (i.e. in SCFG
->Message Areas).
TAG
The TAG
field is the FTN area tag (or echo tag) as shown in your FTN network's agreed upon echo list file (e.g. BACKBONE.NA
for the FidoNet North American backbone). Area tags may not contain white-space characters.
Long Tags
Although standard FidoNet echo tags (AKA “area tag”) may be as long as 35 characters, Synchronet's Sub-board short names are limited to a length of 25 characters. As of July 28, 2018, Synchronet v3.17a will import (e.g. from a BACKBONE.NA
file) echo tags longer than 25 characters into the “Newsgroup” name of the sub-board. Each sub-board's “Newsgroup” name can accommodate a length of up to 63 characters (no spaces). Likewise, when exporting message areas from SCFG or SBBSecho (e.g. to an areas.bbs
file), if a “Newsgroup” name is defined for a message area, it will be used for the exported echo tag of that exported area.
Bad Echo Area
If an area's TAG
field value is a *
(asterisk), then the area will be considered a “bad echo” area and will receive all messages for areas not otherwise specified in this file (sort of a 'catch-all' bin for 'unknown' areas). You can have only one “bad echo” area configured in your Area File. To re-toss (move) messages from the “bad echo” area into newly added or linked sub-boards, run SBBSecho with the -r
command-line option.
LINK
Each LINK
field is an FTN address which you wish to import mail from and export mail to. At the very least, your uplink's (hub's) address should be listed here. Your address should NOT be listed here. If multiple link fields are specified, you should specify the full 3D or 4D address for each. Links can be remotely added or removed from the Area File by authenticated Nodes using AreaFix.
Lines beginning with a semicolon (;) are considered comments, and are ignored.
Example
FIDO_SBBS SYNCHRONET 1:3615/50 FIDO_SYNCDATA SYNCDATA 1:3615/50 FIDO_SYNC_SYS SYNC_SYSOPS 1:3615/50
The amount of spacing (white-space characters including horizontal tabs and spaces) between each element in the line is not important. Each line may be up to 1024 characters in length.
Configure
In order to set up SBBSecho for your system you must:
- Configure your fundamental FTN settings (e.g. system address) in SCFG
SCFG
The fundamental FTN-related system settings are configured via SCFG->Networks->FidoNet EchoMail and NetMail:
╔══════════════════════════════════════════════════════════╗ ║ FidoNet EchoMail and NetMail ║ ╠══════════════════════════════════════════════════════════╣ ║ │System Addresses ║ ║ │Default Origin Line ║ ║ │NetMail Semaphore %jfidoout.now ║ ║ │EchoMail Semaphore %jfidoout.now ║ ║ │NetMail Directory ../fido/netmail/ ║ ║ │Allow Sending of NetMail Yes ║ ║ │Allow File Attachments No ║ ║ │Send NetMail Using Alias No ║ ║ │NetMail Defaults to Crash No ║ ║ │NetMail Defaults to Direct No ║ ║ │NetMail Defaults to Hold No ║ ║ │Kill NetMail After Sent Yes ║ ║ │Cost to Send NetMail 0 ║ ╚══════════════════════════════════════════════════════════╝
The settings from this SCFG menu used by SBBSecho include:
- System Addresses (Main and AKAs)
- NetMail Directory
- Default Origin Line
At the minimum, you will need to configure your Main FTN System Address here.
System Addresses
Set your main/primary FidoNet address and AKAs (secondary/othernet FTN addresses) here. If you only have a temporary address, set your Main address to that value.
Only 3D (zone:net/node) and 4D (zone:net/node.point) addresses are supported in this setting.
NetMail Directory
This is the path to a directory on your local system where both inbound and outbound FTN NetMail will be stored. The only files placed in this directory should be FTN Stored Messages (*.msg
format).
Synchronet can create *.msg
files in this directory when sending NetMail from the terminal server.
SBBSecho will create *.msg
files in this directory when creating NetMail messages (e.g. auto-responding to PING
or AreaFix
requests, notices to the Area Manager, or exporting NetMail from the “mail” msgbase) or unpacking NetMail from inbound Packets. SBBSecho will discover *.msg
files in this directory when Packing outbound NetMail, importing into the “mail” msgbase, or handling AreaFix and PING requests.
The other NetMail-related settings on this SCFG menu affect only FidoNet NetMail messages created by users of the Synchronet Terminal Server; they are not used by SBBSecho.
Default Origin Line
Standard FTN EchoMail messages contain a terminating * Origin
line. The default Origin Line, or at least the portion between the * Origin
prefix and your system's address in parenthesis, is configured here. You do not have to enter an Origin Line here, but it is customary to enter the name, hostname or IP address and/or phone number of your BBS here. SBBSecho will use the text in this setting as the default Origin Line to append to outbound EchoMail messages (posted locally or gated from other network technologies).
It is possible to over-ride this default Origin Line for specific message areas (sub-boards), if so desired by the sysop.
Inbound File Directory
Older versions of SCFG (e.g. v3.16) contained this FidoNet setting which was used to specify the directory where non-secure inbound FidoNet files would be received by your FTN mailer. SBBSecho v2 used this setting, however Synchronet itself did not, so it was deprecated with SBBSecho v3 (replaced with the Non-secure Inbound Directory
setting in EchoCfg/sbbsecho.ini
and removed from future versions of SCFG.
EchoCfg
The SBBSecho Config program (echocfg
) is the program used to configure all the SBBSecho-specific settings saved exclusively in the SBBSecho configuration file (sbbsecho.ini
).
Command-line Syntax
Multiple configuration files can be used (but isn't usually required) for
multi-mailer systems. The default SBBSecho configuration filename is sbbsecho.ini
and located in your Synchronet ctrl
directory. You can override this default by specifying
the name and location of the configuration file on the sbbsecho
and echocfg
command lines if desired.
If you do not specify a configuration file, echocfg
and sbbsecho
will use ctrl/sbbsecho.ini
by default (the ctrl
directory being read from the SBBSCTRL
system environment variable).
usage: echocfg [path/to/sbbsecho.ini] [options] options: -c = force color mode -m = force monochrome mode -e# = set escape delay to #msec -iX = set interface mode to X (default=auto) where X is one of: W = Win32 native mode A = ANSI mode D = standard input/output/door mode -v# = set video mode to # (default=auto) -l# = set screen lines to # (default=auto-detect)
Upon running echocfg
you will be brought to the main menu of the configuration
program. The path and filename of the configuration file being modified will
appear at the top of the menu. Following are screen captures of available menus
within the configuration program and an explanation of the options contained on
each of them. Using the Help option of the program (e.g. hitting the F1 key)
can provide helpful context-sensitive text to the user (you).
╔═════════════════════════╗ ║ Configure FidoNet ║ ╠═════════════════════════╣ ║ │Global Settings... ║ ║ │Linked Nodes... ║ ║ │Archive Types... ║ ║ │NetMail Settings... ║ ║ │EchoMail Settings... ║ ║ │Paths and Filenames... ║ ║ │Domains... ║ ║ │EchoLists... ║ ╚═════════════════════════╝
Saving Changes
When any unsaved changes have been made to the configuration, an additional option appears allowing you to save the changes to the configuration file:
║ │Save Changes to sbbsecho.ini ║ ╚═══════════════════════════════╝
Additionally, when exiting (via ESC key or mouse-click on the close glyph), SBBSecho will prompt you if you wish to save the unsaved changes to the configuration file:
╔══════════════════╗ ║ Save Config File ║ ╠══════════════════╣ ║ │Yes ║ ║ │No ║ ╚══════════════════╝
EchoCfg will normally automatically make a backup of an existing configuration file before over-writing it. For example, ctrl/sbbsecho.0.ini
will be the most recently backed-up version of sbbsecho.ini
. This feature can be disabled if so desired by setting Config File Backups
to 0
.
Global Settings
╔═══════════════════════════════════════════════════╗ ║ Global Settings ║ ╠═══════════════════════════════════════════════════╣ ║ │Mailer Type Binkley/FLO ║ ║ │Log Level Debugging ║ ║ │Log Timestamp Format %m/%d/%y %H:%M:%S ║ ║ │Strict Packet Passwords Enabled ║ ║ │Config File Backups 10 ║ ║ │Minimum Free Disk Space 10G bytes ║ ║ │Strip Incoming Soft CRs No ║ ║ │Strip Outgoing Line Feeds No ║ ║ │Use Outboxes for Mail Files Yes ║ ║ │BSY Mutex File Timeout 12 hours ║ ║ │BSO Lock Attempt Delay 10 seconds ║ ║ │BSO Lock Attempt Limit 60 ║ ║ │BinkP Capabilities ║ ║ │BinkP Sysop Name Your Name ║ ║ │BinkP Authentication Plain or CRAM-MD5 ║ ║ │BinkP Encryption Supported ║ ╚═══════════════════════════════════════════════════╝
Mailer Type
Mailer Type should normally be set to Binkley/FLO
to enable SBBSecho's
“Binkley-Style Outbound” operating mode (a.k.a. BSO or FLO mode).
If you are using an Attach, ArcMail, or FrontDoor style FidoNet
mailer, then set this setting to ArcMail/Attach, but know that most
modern FidoNet mailers are Binkley-Style and therefore that mode of
operation in SBBSecho is more widely tested and supported.
Selecting this menu item will toggle between the mailer types supported by SBBSecho, either ArcMail/Attach-style mailers or (the preferred) Binkley/FLO-style mailers. Choose the one that matches your FTN mailer type (e.g. BinkIT is a Binkley/FLO-style mailer).
Log Level
The Log Level menu option will allow you to determine the minimum severity of log entries that will be written to your SBBSecho log file (e.g. data/sbbsecho.log
):
╔════════════════╗ ║ Log Level ║ ╠════════════════╣ ║ │Emergency ║ ║ │Alert ║ ║ │Critical ║ ║ │Error ║ ║ │Warning ║ ║ │Notice ║ ║ │Informational ║ ║ │Debugging ║ ╚════════════════╝
Log Level should normally be set to Informational
but if you're
experiencing problems with SBBSecho and would like more verbose log
output, set this to Debugging
. If you want less verbose logging,
set to higher-severity levels to reduce the number of log messages.
Log Timestamp Format
Log Timestmap Format defines the format of the date/time-stamps added
along with each log message to the log file (e.g. sbbsecho.log
).
The timestamp format is defined using standard C strftime
notation.
The default format is: %Y-%m-%d %H:%M:%S
.
For SBBSecho v2 timestamp format, use %m/%d/%y %H:%M:%S
.
Strict Packet Passwords
Strict Packet Passwords, when enabled, requires that Packet Passwords must match the password for the linked-node from which the packet was received, even if that linked-node has no password configured. If you wish to revert to the SBBSecho v2 behavior with less strict enforcement of matching packet passwords, disable this option. Default: Enabled
BSY Mutex File Timeout
BSY Mutex File Timeout determines the maximum age of an existing mutex file (*.bsy) before SBBSecho will act as though the mutex file was not present. This setting applies to the global sbbsecho.bsy file as well as the BSO lock (*.bsy) files for individual nodes. Default: 12 hours
BSO Lock Attempt Delay
BSO Lock Attempt Delay determines the amount of time between BSO node lock attempts (via *.bsy files in the relevant outbound directory). Default: 10 seconds
BSO Lock Attempt Limit
BSO Lock Attempt Limit determines the maximum number of BSO node lock attempts before SBBSecho will give-up and move on to another node to process mail. This value multiplied by the BSO Lock Attempt Delay should be much less than the BSY Mutex File Timeout value. Default: 60 attempts
Config File Backups
Config File Backups determines the number of automatic backups of your
SBBSecho configuration file (e.g. sbbsecho.ini
) that will be
maintained by SBBSecho Config and SBBSecho AreaFix.
BinkP Capabilities
Set this value if you need to override the the text in the BinkP M_NUL NDL
line, from the default of “115200,TCP,BINKP”.
BinkP Sysop Name
Set this value if you'd like to over-ride the BinkP Sysop Name (ZYZ
) value (e.g. to send the sysop's real name, rather than alias).
Linked Nodes
This menu item allows you to add, remove, and configure nodes that you will be sending mail to and accepting mail from. Selecting this option will bring you to a sub-menu which will look similar to the following:
╔══════════════╗ ║ Linked Nodes ║ ╠══════════════╣ ║ │ ║ ╚══════════════╝
At the Linked Nodes...
sub-menu, pressing the INSert key will allow you to
add a new node, pressing the DELete key will remove the currently
highlighted node. A Node here does not necessarily identify a single FidoNet node, but can also be used to identify a group of nodes by using the ALL
wildcard (indicating that a node configuration will be used for *all* nodes with a specific zone or zone:net).
Note:
The hexadecimal numbers in parentheses are provided as an aide when correlating FidoNet files and BSO directories with node numbers.
╔══════════════════════════════════════════════════╗ ║ Linked Nodes ║ ╠══════════════════════════════════════════════════╣ ║ │ALL Everyone ║ ║ │21:ALL (.015) fsxNet ║ ║ │1:218/700 (00da02bc) Kurt Weiske ║ ║ │3:712/848 (02c80350) Scott Little ║ ║ │2:280/464 (011801d0) Wilfred van Velzen ║ ║ │1:124/5016 (007c1398) Nigel Reed ║ ║ │1:153/757 (009902f5) Al ║ ║ │1:320/219 (014000db) ║ ║ │1:320/119 (01400077) ║ ║ │21:1/100 (00010064) Paul Hayton (Avon) ║ ║ │ ║ ╚══════════════════════════════════════════════════╝
Pressing ENTER on a currently highlighted node will allow you to edit the settings for that particular node from a menu like the following (note that the node number you are editing appears at the top of the window):
╔═════════════════════════════════════════════╗ ║ Linked Node - 1:218/700 ║ ╠═════════════════════════════════════════════╣ ║ │Address 1:218/700 ║ ║ │Domain fidonet ║ ║ │Name Kurt Weiske ║ ║ │Comment ║ ║ │Archive Type ZIP ║ ║ │Packet Type 2+ ║ ║ │Packet Password ║ ║ │Session Password ║ ║ │TIC File Password ║ ║ │AreaFix Support Yes ║ ║ │AreaFix Password ║ ║ │EchoList Keys ║ ║ │Status Normal ║ ║ │Direct No ║ ║ │Passive No ║ ║ │Send Notify List No ║ ║ │Uplink for Message Groups FidoNet ║ ║ │Local Address (AKA) Best Match ║ ║ │Route To Disabled ║ ║ │Inbox Directory ║ ║ │Outbox Directory ║ ║ │BinkP Settings... ║ ╚═════════════════════════════════════════════╝
Address
This is the address of the node you are editing, selecting it
will allow you to change this to a different address. Using
the “ALL” wildcard in place of one of the address components
will allow you to configure settings for all nodes that meet
that specification (e.g. all nodes in zone 1 can be specified
as 1:ALL
or all nodes in zone 1, net 103 can be specified
as 1:103/ALL
).
Comment
Comment is a note to yourself about this node. Setting this to the user or sysop name corresponding with the configured node can be a helpful reminder to yourself later.
Archive Type
Archive Type is the name of an archive type corresponding with one of your configured archive types or 'None'. This archive type will be used when creating EchoMail bundles or if None, raw/uncompressed EchoMail packets will be sent to this node.
This setting may be managed by the node using AreaFix requests.
Selecting this option will allow you to choose from a menu of currently configured archive types, like the following:
╔══════════════╗ ║ Archive Type ║ ╠══════════════╣ ║ │ZIP ║ ║ │ARC ║ ║ │LZH ║ ║ │ARJ ║ ║ │PAK ║ ║ │SQZ ║ ║ │ZOO ║ ║ │None ║ ╚══════════════╝
Selecting “None” will specify that this node is to receive uncompressed/raw packets (no bundles).
Note about Archive Software:
Command-line versions of common archive programs can be found at Digital Distortions along with setup instructions here. One thing to note is that the latest release of ARJ is v3.20 and it complains about being outdated. An open source version is available here. It's been tested at Split Infinity and appears to be a seamless fit.
Packet Type
This is the type of fidonet packets that will be used when creating mail
packets for this node. The default packet type used by SBBSecho
is 2+. If you are a “point” address (e.g. 1:100/100.1
) you
should use either a type 2+, 2e, or 2.2 packet since type 2 packets
do not support point numbers. Selecting this option will allow
you to choose from a menu of currently supported packet types:
╔═════════════╗ ║ Packet Type ║ ╠═════════════╣ ║ │2+ ║ ║ │2e ║ ║ │2.2 ║ ║ │2 ║ ╚═════════════╝
Packet Password
Packet Password is an optional password that may be added to outbound
packets for this node. Incoming packet passwords are compared with
this password value. If this password is blank/empty and Strict
Packet Passwords
are enabled, then incoming packets from this node
must also have no password. Packet passwords are case insensitive.
This setting may be managed by the node using AreaFix requests.
Session Password
When using BinkIT as your mailer, this setting will determine the BinkP session password used when communicating with this linked node.
TIC File Password
TIC File Password is an optional password that may be configured here (and in your sbbsecho.ini file) for use by ticket.js when creating or authenticating .TIC files. This setting may be managed by the node using AreaFix requests.
AreaFix Support
Remote area management (via AreaFix requests from this linked node) may be enabled (set to Yes) or disabled (set to No) using this menu option.
AreaFix Password
AreaFix passwords are required to be included in the Subject line of received AreaFix requests (NetMail messages). AreaFix Passwords are case insensitive. This setting may be managed by the node using AreaFix requests.
EchoList Keys
When echo lists have been defined (from the 'EchoLists...' sub-menu) these keys determine which EchoLists can be used by this node when processing Area Manager add requests.
Status
This option determines the netmail status that will be set when SBBSecho sends out an areafix message or a file attach. Selecting this option toggles between None, Crash, and Hold status.
Direct
When set to Yes
this option will add a Direct kludge line
to messages that SBBSecho sends out (or create DLO/DUT files
for FLO mailers).
Passive
Setting this option to 'Yes' will prevent messages from being sent to this node without the need for altering the Area File. This is useful for temporarily shutting off the messages to this node. This option can be toggled on and off remotely via an area manager request.
Send Notify List
This determines whether or not this node is sent a Notify List when using that command line option in SBBSecho. A Notify List is a netmail sent to the system operator of the node showing options set for the node as well as connected areas.
Uplink for Message Groups
Uplink for Message Groups is an optional list of Message Groups (short names) for which this node is a hub/uplink for your system. This setting is used in combination with the Auto Add Sub-boards feature to auto-link hubs with the newly added areas in your Area File.
Route To
When configured for Binkley/FLO-style mailers, this option allows any mail sent to nodes matching this node entry's address (including the ALL
wildcard matches), to be routed to a different address (e.g. your uplink/hub's address). This option is particularly useful for routed NetMail.
Attach-style mailers have their own routing configuration and that is why this option is not available in echocfg
when configured for FrontDoor/Attach-style mailers.
Inbox Directory
Inbox Directory is only used in BSO operating mode and is an optional
alternate directory to search for incoming files from this node
(e.g. used in combination with BinkD's ibox
setting).
Note: BinkIT does not support inboxes at this time.
Outbox Directory
Outbox Directory is only used in BSO operating mode and is an optional
alternate directory to place outbound files for this node (e.g. used
in combination with BinkD's obox
setting).
Note: BinkIT has experimental support for outboxes at this time.
BinkP Settings
BinkP Settings are settings specific to BinkP/BinkIT mailer operation.
╔═════════════════════════════════════╗ ║ 1:218/700 BinkP Settings ║ ╠═════════════════════════════════════╣ ║ │Host ║ ║ │Port 24554 ║ ║ │Poll Yes ║ ║ │Authentication CRAM-MD5 Only ║ ║ │Encryption Supported ║ ║ │Source Address ║ ╚═════════════════════════════════════╝
Host defines the TCP/IP address or host name with which to connect for sessions with this linked node. If the host is not set, then a DNS-based look-up will be attempted (e.g. the IP address for 1:103/705 would be looked-up via host name f705.n103.z1.binkp.net). Nodelist-based look-ups are also supported.
Port defines the TCP port used by this linked node for BinkP sessions. The default BinkP TCP port is 24554.
Poll defines whether or not to periodically poll this linked node.
Authentication determines what types of authentication will be supported during both inbound and outbound sessions with this linked node. The supported BinkP-auth methods are Plain-Password and CRAM-MD5.
Encryption determines whether unencrypted data transfers will be supported or required when communicating with this linked node. With this setting set to Required
, only BinkD-style-encrypted BinkP sessions will be supported. CRAM-MD5 authentication must be used when encrypting BinkP sessions.
Source Address allows you to override the source FTN address used with outgoing BinkP mailer sessions with this linked node. Normally, this setting is left blank (not set).
Archive Types
This option allows you to add or remove archive programs from SBBSecho. Selecting this option will bring you to the following menu:
╔═══════════════╗ ║ Archive Types ║ ╠═══════════════╣ ║ │ZIP ║ ║ │ARC ║ ║ │LZH ║ ║ │ARJ ║ ║ │PAK ║ ║ │SQZ ║ ║ │ZOO ║ ║ │ ║ ╚═══════════════╝
At the Archive Programs... sub-menu, pressing the INSert key will allow you to add a new archive program. Pressing the DELete key will remove the currently highlighted archive program. And pressing ENTER on the currently highlighted archive program will allow you to edit the options for that particular program from a menu like the following (note that the name of the archive program you are editing appears at the top of the window):
╔═══════════════════════════════════════════════════════╗ ║ Archive Type - ZIP ║ ╠═══════════════════════════════════════════════════════╣ ║ │Archive Type ZIP ║ ║ │Signature 504B ║ ║ │Signature Offset 0 ║ ║ │Pack Command Line %@zip -jD %f %s ║ ║ │Unpack Command Line %@unzip -ojC %f -d %s ║ ╚═══════════════════════════════════════════════════════╝
Archive Type
This is the identifying name of the archive file type. Usually this name corresponds with the common file extension or suffix denoting this type of archive file (e.g. zip, arc, etc.).
This is the name that will be used to reference this particular archiving program. This is also the name that should be used by nodes using areamanger to change their compression type remotely.
Signature
This is the identifying signature of the archive file format (in hexadecimal notation). This signature is used in combination with the Archive Signature Offset for the automatic detection of proper archive program to extract (unarchive) inbound EchoMail bundle files.
Signature Offset
This is the byte-offset of the identifying signature of the archive file format. This offset is used in combination with the Archive Signature for the automatic detection of proper archive program to extract (unarchive) inbound EchoMail bundle files.
Pack Command Line
This is the command-line to execute to create an archive file of the selected type. The following command-line specifiers may be used for dynamic variable replacement:
Specifier | Description |
---|---|
%f | The path/filename of the archive file to be created |
%s | The path/filename of the file(s) to be added to the archive |
%! | The Synchronet exec directory |
%@ | The Synchronet exec directory only for non-Unix systems |
%. | Blank for Unix systems, '.exe' otherwise |
%? | The current platform description (e.g. 'linux', 'win32') |
%j | The Synchronet data directory |
%k | The Synchronet ctrl directory |
%o | The configured system operator name |
%q | The configured system QWK-ID |
%g | The configured temporary file directory |
Unpack Command Line
This is the command-line to execute to extract an archive file of the
selected type.
The %f
command line specifier will
expand to the name of the archive file, the '%s' command
line specifier will expand to the path where the file is to
be extracted to.
NetMail Settings
╔════════════════════════════════════════════════╗ ║ NetMail Settings ║ ╠════════════════════════════════════════════════╣ ║ │Sysop Aliases SYSOP ║ ║ │Default Recipient ║ ║ │Fuzzy Zone Operation No ║ ║ │Kill/Ignore Empty NetMail Messages No ║ ║ │Delete Processed NetMail Yes ║ ║ │Ignore NetMail Destination Address No ║ ║ │Ignore NetMail 'Sent' Attribute No ║ ║ │Ignore NetMail 'KillSent' Attribute No ║ ║ │Ignore NetMail 'Received' Attribute No ║ ║ │Ignore NetMail 'Local' Attribute No ║ ║ │Maximum Age of Imported NetMail None ║ ╚════════════════════════════════════════════════╝
Fuzzy Zone Operation
Some mail programs do not create netmail messages with zone information (INTL kludge line) or may only do so when sending between zones. This is a problem for systems that receive netmail for multiple addresses with different zones (AKAs with different zone numbers). Setting this option to “Yes” allows SBBSecho to guess what the correct originating and destination zone is based on the net and node portions of the destination address in netmail message.
EchoMail Settings
╔═════════════════════════════════════════════════════════╗ ║ EchoMail Settings ║ ╠═════════════════════════════════════════════════════════╣ ║ │Area Manager SYSOP ║ ║ │Maximum Packet Size 292K ║ ║ │Maximum Bundle Size 292K ║ ║ │Secure Operation Yes ║ ║ │Notify Users of Received EchoMail Yes ║ ║ │Convert Existing Tear Lines No ║ ║ │Automatically Add New Subs to Area List List/File ║ ║ │Allow Nodes to Add Areas from Area File Yes ║ ║ │Maximum Backups to Maintain of Area File 100 ║ ║ │Circular Path Detection Enabled ║ ║ │Relay Filtered Messages No ║ ║ │Outbound Bundle Attachments Delete ║ ║ │Zone Blind SEEN-BY and PATH Lines Zones 1-4 ║ ║ │Maximum Age of Imported EchoMail 60 days ║ ╚═════════════════════════════════════════════════════════╝
Area Manager
This is the name or alias of the BBS user where notification of AreaFix
failures should be sent (default: SYSOP
). AreaFix failures include nodes sending AreaFix requests which are not
configured for AreaFix operation, nodes using incorrect AreaFix passwords, and
the like. Setting this option to a blank string will disable the notification feature.
Maximum Packet Size
This menu item allows you to set the maximum size of each outgoing echomail packet.
Maximum Bundle Size
Mail packets are normally packed into what are called “bundles” (unless a node is set up to receive uncompressed mail packets). This menu item allows you to specify the maximum size of each outgoing mail bundle.
Secure Operation
Secure Operation tells SBBSecho to check the Area File (e.g. areas.bbs
) to insure that the packet origin (FTN address) of each inbound EchoMail message is already linked to the EchoMail area where the message was posted. Messages denied import due to this setting are logged as a Security violation
. This setting defaults to No
.
Allow Nodes to Add Areas from Area File
When set to Yes
, SBBSecho will allow nodes to add areas
(via area manager) which are listed in your Area File.
When set to No
, SBBSecho will only allow nodes to add areas
from any additionally configured EchoLists which they have
access to.
Paths and Filenames
This menu item allows you to configure the paths and filenames which are used by SBBSecho. Selecting this option will bring you to the following sub-menu:
╔═══════════════════════════════════════════════════════╗ ║ Paths and Filenames ║ ╠═══════════════════════════════════════════════════════╣ ║ │Non-secure Inbound Directory ../fido/nonsecure ║ ║ │Secure Inbound Directory ../fido/inbound ║ ║ │Outbound Directory ../fido/outbound/ ║ ║ │Area File ../data/areas.bbs ║ ║ │Bad Area File ../data/badareas.lst ║ ║ │Log File ../data/sbbsecho.log ║ ║ │Echo Statistics File ../data/echostats.ini ║ ║ │Temporary File Directory ../temp/sbbsecho ║ ║ │Outgoing Semaphore File ../data/binkout.now ║ ╚═══════════════════════════════════════════════════════╝
Non-secure Inbound Directory
This is the path where your FTN mailer stores, and where SBBSecho will look for, incoming files (potentially including message bundles and packets) from unauthenticated (non-secure) mailer sessions.
Default value is ../fido/nonsecure
.
Secure Inbound Directory
This is the path where your FTN mailer stores, and where SBBSecho will look for, incoming message bundles and packets for Secure (password protected) sessions.
Default value is ../fido/inbound
.
Outbound Directory
This is the path where your FTN mailer will look for, and where SBBSecho will place, outgoing message bundles and packets.
In Binkley-Style Outbound mode, this serves as the base directory name for special foreign zone and point destination nodes as well.
Default value is ../fido/outbound
.
Area File
This is the path and filename of the file that SBBSecho will
use as it's EchoMail Message Area File. By default SBBSecho looks for
the file areas.bbs
in the data directory defined in SCFG.
Bad Area File
This is the path of the file SBBSecho will use to record the names
(echo tags) and descriptions of FTN message areas (echoes) that your
system has received EchoMail for, but does not carry locally. The
default path/filename is data/badareas.lst
.
Notes:
- The descriptions of the areas will only be included if the corresponding echo tags can be located in one of your configured EchoLists.
- The format of the file is the same as BACKBONE.NA and suitable for importing into a Synchronet Message Group using SCFG.
- SBBSecho will automatically sort and maintain this list, removing areas if they are added to your configuration (SCFG->Message Areas) and your Area File.
Log File
This is the path of the file SBBSecho will use to log information each
time it is run (default is ../data/sbbsecho.log
).
Echo Statistics File
This is the path of the file SBBSecho will use to track statistics for
EchoMail message areas (default is ../data/echostats.ini
).
Temporary File Directory
This is the directory where SBBSecho will store temporary files that
it creates and uses during its run-time (default is ../temp/sbbsecho
).
Outgoing Semaphore File
This is an optional file to create/touch whenever there are new outbound
files created or updated by SBBSecho. If you're using BinkIt as your mailer, then this should normally be set to ../data/binkout.now
.
Domains
Here you can configure the so-called “5th dimension” of FidoNet addresses, “domains”, here.
These are the domain->zone mapping that used to be configured via the file: ftn_domains.ini
(but is now configured in sbbsecho.ini
and this utility).
╔══════════════════════╗ ║ Domains ║ ╠══════════════════════╣ ║ │fidonet binkp.net ║ ║ │fsxnet ║ ║ │ ║ ╚══════════════════════╝
Selecting a node to configure will display a dialog like the following:
╔══════════════════════════════════════════════════════╗ ║ Domain - fidonet ║ ╠══════════════════════════════════════════════════════╣ ║ │Name fidonet ║ ║ │Zones 1,2,3,4,5,6 ║ ║ │DNS Suffix binkp.net ║ ║ │Outbound Root ../fido/outbound/ ║ ║ │NodeList ║ ╚══════════════════════════════════════════════════════╝
EchoLists
This menu item allows you to add and remove additional echo lists which can be used by SBBSecho for area manager add requests. Normally these will be used in addition to your AREAS.BBS file. If you have the toggle option 'Allow Nodes to Add Areas from Area File' set to 'No', you MUST create at least one additional echo list if you wish to allow other nodes to add areas via area manager requests.
Selecting this item will bring you to a sub-menu listing any additional echo lists you currently have defined:
╔═══════════════════════╗ ║ EchoLists ║ ╠═══════════════════════╣ ║ │c:\binkd\backbone.na ║ ║ │ ║ ╚═══════════════════════╝
Pressing the INSert key will allow you to add a new echo list, pressing the DELete key will remove the currently highlighted echo list, and pressing ENTER on the currently highlighted echo list will allow you to edit information about that list:
╔══════════════════════════════════════════════════════╗ ║ EchoList - backbone.na ║ ╠══════════════════════════════════════════════════════╣ ║ │EchoList Path/Name c:\binkd\backbone.na ║ ║ │Hub Address None ║ ║ │Forward Password None ║ ║ │Forward Requests No ║ ║ │AreaFix Keys ║ ╚══════════════════════════════════════════════════════╝
EchoList Path/Name
This is the full path and filename of the echo list you are defining. This list should contain the areatag names of areas, one per line, with any comments separated from the areatag by at least one space.
Hub Address
This is the address of the hub of the conferences contained in this list. If an area is remotely added from this list (using Areafix) this address is automatically added to the Area File.
Forward Password
This is the area manager password to use when forwarding requests.
Forward Requests
Setting this option to 'Yes' will cause SBBSecho to send a request to the Hub Address specified to turn on an area from this list. This happens when users remotely add areas using AreaFix and is not necessary if you are already receiving the conferences in this list.
AreaFix Keys
These are the keys required for a node to be able to gain access to this particular echo list. These flags are defined for each node from the 'Linked Nodes...' sub-menu. Selecting this option will bring you to a sub-menu where you may add and remove keys for this EchoList.
Running SBBSecho
SBBSecho is designed to run only when needed (e.g. when there are new inbound or outbound messages to process). It should normally be able to perform its duties and exit without error in a matter of seconds (or possibly minutes if there is a lot of mail to process).
Environment Variable
SBBSecho requires that the system SBBSCTRL
environment variable be set correctly before it may be executed. When SBBSecho is executed from the Synchronet Terminal Server's Event Thread (e.g. due to FIDOIN
or FIDOOUT
timed events), this environment variable will always be set correctly, automatically.
Instances
SBBSecho is designed to run only one instance at a time. A mutual-exclusion file (ctrl/sbbsecho.bsy
) is used to insure that multiple instances of SBBSecho are not allowed to execute concurrently. If SBBSecho crashes or is externally-killed without being able clean up after itself, it's possible this mutex file will be left behind and prevent SBBSecho from running normally for quite some time (depending on the configuration value of BSY Mutex File Timeout
).
If you get the following error message (on the console and/or the log file) and you can confirm that SBBSecho is not actually running, you can safely delete the mutex file to allow SBBSecho to again run normally:
Mutex file exists (/sbbs/ctrl/sbbsecho.bsy): SBBSecho appears to be already running
Errorlevel
When SBBSecho executes without error, it returns an errorlevel of 0
to the calling process. A non-zero errorlevel indicates a severe error condition and the SBBSecho log file (e.g. data/sbbsecho.log
) should be consulted for further details about the error. The only possible errorlevels returned by SBBSecho are 0 (no error) and 1 (some severe error).
Console Output
While SBBSecho will send text to the local console when run, it may spew a lot of text at a rapid pace and then exit faster than a human can reasonably interpret was happened and what was displayed to them. For this reason, it is best to monitor the SBBSecho log file (e.g. data/sbbsecho.log
) instead, using tail -f
or something similar.
All of the important console messages go to the log file as well.
SBBSecho v3 does not monitor the local keyboard for input, a Ctrl-C/Break handler is installed so that it should exit gracefully if someone were to hit a local Ctrl-C/Break key combination.
Command Line
Although you can just run SBBSecho (e.g. sbbsecho.exe
) with no command-line options, each and every time, and it'll probably do what you need it to do... for optimal performance, we suggest you use the following command lines (e.g. configured in SCFG->External Programs->Timed Events) to limit SBBSecho to performing only the tasks it needs to do based on the type of event that has been triggered:
For importing netmail and echomail (e.g. FIDOIN
timed event):
sbbsecho -ce
For exporting netmail and echomail (e.g. FIDOOUT
timed event):
sbbsecho -ni
Command Line Syntax
usage: sbbsecho [cfg_file] [-options] [sub_code] [address] where: cfg_file is the filename of config file (default is ctrl/sbbsecho.ini) sub_code is the internal code for a sub-board (default is ALL subs) address is the FTN node/link to export for (default is ALL links) sbbsecho, by default, will: * Process packets (*.pkt) from all inbound directories (-p to disable) * Process netmail (*.msg) files and import netmail messages (-n to disable) * Delete netmail messages/files after importing them (-d to disable) * Import and forward packetized echomail messages (-i to disable) * Export local netmail messages from SMB to *.msg (-c to disable) * Export echomail messages from selected and linked sub(s) (-e to disable) * Load echomail export pointers before exporting (-m to disable) * Store echomail export pointers after exporting (-t to disable) * Packetize outbound netmail as req'd for BSO/FLO operation (-q to disable) sbbsecho, by default, will NOT: * Export echomail previously imported from FTN (-h to enable) * Update echomail export pointers without exporting messages (-u to enable) * Import echomail (re-toss) from the 'bad echo' sub-board (-r to enable) * Generate AreaFix netmail reports/notifications for links (-g to enable) * Display the parsed area file (e.g. AREAS.BBS) for debugging (-a to enable) * Prompt for key-press upon exit (-@ to enable) * Prompt for key-press upon abnormal exit (-w to enable)
NOTE:
The command-line options changed considerably between SBBSecho version 2 and version 3.
Some of the removed options became settings in the sbbsecho.ini
file while others
were just removed for lack of need. To be sure to not break compatibility with existing
Synchronet/SBBSecho configurations (e.g. FIDOIN
and FIDOOUT
timed event command-lines),
the removed legacy command-line options are just silently ignored by SBBSecho v3.
Area Manager Commands
Remote area manager, or AreaFix, commands are used by linked nodes in order to
turn echo areas off and on, list currently connected areas, and more.
The following text is from the file areangr.hlp
which, after installation of
SBBSecho, should be located in your Synchronet exec
directory. This file lists the
area manager commands available to the linked nodes which have been configured using
the echocfg
program:
Address all requests to 'SBBSecho' or 'AreaFix' (without quotes). Your Area Manager password goes on the subject line. In the body of the message to Area Manager: [+]<areaname> Connect an area -<areaname> Disconnect an area %HELP Request this message %LIST Request a list of areas available to you %QUERY Request a list of areas to which you are connected %UNLINKED Request a list of areas to which you are not connected %COMPRESSION <type> Change the compression type (e.g. ARC/ARJ/LZH/PAK/SQZ/ZIP/ZOO) %PASSWORD <password> Change your Area Manager password %PKTPWD <password> Set or change your Packet password %TICPWD <password> Set or change your TIC File password %RESCAN Request a rescan of all connected areas %RESCAN <areaname> Request a rescan of a single connected area %ACTIVE Reconnect (resume) all temporarily disconnected areas %PASSIVE Temporarily disconnect (pause) all connected areas %FROM <address> Remote/proxy Area Management, must be the first command %+ALL Connect all available areas %-ALL Disconnect all areas [---] Everything below the tear line is ignored NOTE: A compression type of NONE is also supported for uncompressed packets.
Version 3
SBBSecho version 3 development began in 2016 using SBBSecho version 2 (originally written by King Drafus and maintained/updated by Digital Man) as a starting point. Although not a complete rewrite, it contains enough substantial/fundamental changes and backward-incompatibilities and enhancements that a new major version number (3) was justified.
Changes in Version 3
For a detailed list of changes and code differences introduced in v3.0, see This page in CVS.
The most major changes introduced in v3.0 are:
- New configuration file format (
sbbsecho.cfg
replaced withsbbsecho.ini
) - Support for FileBoxes (BinkD-style inbox and outbox, configured per linked-node)
- Much better organized and user-friendly
echocfg
(e.g. lots of context-sensitive help available) - Attach/ArcMail style mailer support has been deprecated (untested, unlikely to work) in favor of Binkley/FLO type mailers
- “Additional EchoList” 4-char “flags” are now 25-char “keys” and much easier to deal with
- Far fewer command-line options, more settings in EchoCfg
- Multiple sysop aliases supported (for receiving netmail)
- Mutual-exclusion-lock file (ctrl/sbbsecho.bsy) to prevent accidental concurrent invocations of SBBSecho
- Maximum msg age configurable for NetMail and EchoMail (separately)
- Better security for inbound packets (strict packet password enforcement, enabled by default)
- All temporary files (e.g. packets in process) are created in an SBBSecho-specific temporary file directory
- More comprehensive log output; the log file output is more of a priority than the console output now
- Packet Type-2e (FSC-39.4) support
- Bad message area file (e.g.
data/badareas.lst
) creation and maintenance - Echo Statistics files (e.g.
data/echostats.ini
) creation and maintenance - Auto-backups of Area File and configuration (
sbbsecho.ini
) file upon any changes made by EchoCfg or SBBSecho AreaFix - Automatic addition of newly added Sub-boards (in specific message groups) to the Area File
- Optional re-toss of
bad echo
mail into newly linked Sub-boards
Upgrading to Version 3
To upgrade a Synchronet system that was using SBBSecho v2 to now use SBBSecho v3, all you should need to do is run jsexec sbbsecho_upgrade.js
in your Synchronet exec
directory. This will handle the conversion of your existing sbbsecho.cfg
file to the new sbbsecho.ini
file. If for some reason you want to revert to using SBBSecho v2 again, you should be able to just rename sbbsecho.cfg.old
to sbbsecho.cfg
and run v2 of sbbsecho
and echocfg
again.
Version 2 sbbsecho.cfg
options which are not automatically migrated for v3 sbbsecho.ini
:
- NOTIFY
- LOG
- NOCIRCULARFWD
Note:
If you want to retain the old (less secure) v2 packet password policy, then set StrictPacketPasswords = false
in your sbbsecho.ini
file.
Note:
In SBBSecho v2, if you did not have an INBOUND
directory specified in your sbbsecho.cfg
file (specifying a location for non-secured inbound files), SBBSecho v2 would use the path specified in SCFG->Networks->FidoNet->Inbound File Directory. That configuration setting (stored in the file ctrl/msgs.cnf
) was not used by Synchronet for any other purpose and has now been removed from SCFG (v3.17). When sbbsecho_upgrade.js
converts your sbbsecho.cfg
file to sbbsecho.ini
, if you don't have an INBOUND
directory specified, it will need to make a best guess as to the proper non-secure inbound directory and that's what will be saved in your new ctrl/sbbsecho.ini
file. You may want to double-check that this setting is correct.
Note:
If you have multiple SBBSecho v2 configuration file(s) (e.g. othernet.cfg
), you can upgrade them to the new v3 .ini
format by passing the old and new filenames on the sbbsecho_upgrade.js
command-line, e.g. jsexec sbbsecho_upgrade.js othernet.cfg othernet.ini
.
Migrating Command-lines to Version 3
Although the old import and export SBBSecho command-lines (e.g. pre-configured for the FIDOIN
and FIDOOUT
timed events in SCFG->External Programs->Timed Events) will continue to work, some of the old command-line options are now ignored or serve a different purpose in version 3:
Option | Version 2 | Version 3 |
---|---|---|
-l | enable logging to disk | logging is now always enabled |
-f | packetize netmail | default behavior; use the new -q option to disable |
-j | ignore received bit on netmail | enabled via sbbsecho.ini -> IgnoreNetmailRecvAttr |
-a | export ASCII characters only | use the sub-board toggle option in SCFG |
-y | import netmail for unknown users to sysop | configured via sbbsecho.ini -> DefaultRecipient |
-o | import netmail regardless of destination address | configured via sbbsecho.ini -> IgnoreNetmailDestAddr |
-s | import private echomail (strip private status) | deprecated |
-! | notify users of received echomail | configured via sbbsecho.ini -> EchomailNotify |
-x | do not delete packets after import | configured via sbbsecho.ini -> DeletePackets |
-r | create report of import totals | re-toss bad echo area into newly linked sub-boards |
-b | import locally created netmail too | configured via sbbsecho.ini -> IgnoreNetmailLocalAttr |
-= | change existing tear lines to === | configured via sbbsecho.ini -> ConvertTearLines |
The command-line options that actually changed meaning in version 3 are:
-a
which is now used to log the parsed Area File (e.g. AREAS.BBS) for debugging purposes-r
which is now used to re-toss the bad echo area into newly linked sub-boards
Run sbbsecho -?
to get a list of the current set of supported command-line options and their meaning.
Log Output Changes in Version 3
The log file (default: data/sbbsecho.log
) is now created/updated always whereas in version 2, the log file was only written if the -l
option (now deprecated) was passed to SBBSecho. As in version 2, the log filename can be configured (now in sbbsecho.ini->LogFile
).
In version 2, the logging of specific SBBSecho operations could be enabled/disabled via sbbsecho.cfg
->LOG
or echofg
->Log Options. In version 3, the sysop only has control over the logging verbosity/severity (via sbbsecho.ini
->LogLevel
). For example, to log only errors, set the LogLevel to “Errors”.
Version 3 Time-stamp Format
The log file time-stamp format changed in Version 3 to YYYY-MM-DD HH:MM:SS
. If you wish to use the version 2 time-stamp format, set
sbbsecho.ini
-> LogTimeFormat
to “%m/%d/%y %H:%M:%S”
.
See Also
- sbbsecho.ini file
- areas.bbs file
- SCFG utility