Synchronet v3.21e-Win32 (install) has been released (Mar-2026).

You can donate to the Synchronet project using PayPal.

File Options

The global configuration settings for file transfers are set in SCFG->File Options.

╔════════════════════════════════════════════════════════════════════════╗
║                             File Options                               ║
╠════════════════════════════════════════════════════════════════════════╣
║ │Minimum Free Disk Space          1G bytes                             ║
║ │Max Files in Batch UL Queue      25                                   ║
║ │Max Files in Batch DL Queue      100                                  ║
║ │Max Users in User Transfers      5                                    ║
║ │Default Credit on Upload         100%                                 ║
║ │Default Credit on Download       90%                                  ║
║ │Leech Protocol Detection         <disabled>                           ║
║ │Allowed Filename Length          64 characters                        ║
║ │Allowed Filename Characters      Most ASCII, Including Spaces         ║
║ │Supported Archive Formats        zip, 7z, tgz                         ║
║ │Viewable Files...                                                     ║
║ │Testable Files...                                                     ║
║ │Download Events...                                                    ║
║ │Extractable Files...                                                  ║
║ │Compressible Files...                                                 ║
║ │Transfer Protocols...                                                 ║
╚════════════════════════════════════════════════════════════════════════╝
Option Name Description
Minimum Free Disk Space Minimum free space in a file directory required to allow user uploads (e.g. 1G, 100M).
Max Files in Batch UL Queue Maximum number of files that can be placed in the batch upload queue.
Max Files in Batch DL Queue Maximum number of files that can be placed in the batch download queue.
Max Users in User Transfers Maximum number of destination users in user-to-user file uploads.
Default Credit on Upload Default percentage of credits given to uploaders, used as the default for newly created file directories.
Default Credit on Download Default percentage of credits given to the original uploader when their file is downloaded by another user, used as the default for newly created file directories.
Leech Protocol Detection If enabled, determines sensitivity to counting/logging potential leech downloads (see below).
Allowed Filename Length Maximum uploaded filename length allowed (in characters).

Only 64 characters of filenames are indexed (searchable) and sometimes (depending on the terminal) only 64 or fewer characters of a filename may be displayed to a user. For these reasons, 64 characters is a reasonable maximum filename length to enforce (and thus, the default).

The absolute maximum filename length supported is 65535 characters.
Allowed Filename Characters Allowed Characters in Uploaded Filenames:
- Safest Subset Only (A-Z, a-z, 0-9, -, _, and .)
- Most ASCII Characters, Excluding Spaces
- Most ASCII Characters, Including Spaces
- Most CP437 Characters, Excluding Spaces
- Most CP437 Characters, Including Spaces
Supported Archive Formats List of archive file types (extensions/suffixes, without the leading .) that libarchive should use when creating QWK/REP packets and temporary archives of files for users to download.

Default: zip, 7z, tgz.

This list has no impact on the file types allowed to be uploaded into file areas, or on the ability to view, test, or extract archives of any other type.
Viewable Files... Sub-menu — see Viewable File Types.
Testable Files... Sub-menu — see Testable File Types.
Download Events... Sub-menu — see Download Events.
Extractable Files... Sub-menu — see Extractable File Types.
Compressible Files... Sub-menu — see Compressible File Types.
Transfer Protocols... Sub-menu — see File Transfer Protocols.

Leech Protocol Detection

This value is the sensitivity of the leech protocol detection feature of Synchronet. If the transfer is apparently unsuccessful, but the transfer time was at least this percentage of the estimated transfer time (based on the estimated CPS of the connection result code), then a leech protocol error is issued and the user's leech download counter is incremented. Setting this value to 0 disables leech protocol detection. This option also allows you to set the minimum amount of elapsed transfer time (in seconds) to be considered for a possible leech download.

Leech protocol programs are file transfer programs (usually using Zmodem technology) that attempt to “fool” the BBS into thinking the file was not successfully transferred, when in reality it was. This is accomplished by the transfer program requesting a reposition (ZRPOS) after the last successful block and then aborting (ZCAN). A file transferred in this manner will not be considered a successful transfer by Synchronet, but will be caught as a possible leech download and notify the sysop (if this option is used).

This feature is also useful for detecting the partial download of image (GIF) files. If you charge your users credits for downloads, this can be a very useful feature in detecting dishonest users. If the user accumulates a large number of leeches (as displayed in User Edit) and the user never successfully downloads a file previously logged as a possible leech download, the user is probably trying to get something for nothing, though this is hard to prove without actually watching the file transfer in progress.

Viewable File Types

A list of file types (extensions) that have content information that can be viewed on the Terminal Server through the execution of an external program or script.

╔══════════════════════════════════════════════════╗
║                Viewable File Types               ║
╠══════════════════════════════════════════════════╣
║ │.zip      ?archive list %f                      ║
║ │.gif      ?gifinfo %f                           ║
║ │.txt      list %f                               ║
║ │                                                ║
╚══════════════════════════════════════════════════╝
  • File extensions are case-insensitive and may contain * / ? wildcards. An extension of * matches all files.
  • If the same extension is listed more than once, each command line will be executed.
  • Use %f or %s on the command line for the path to the file being viewed.

Viewable File Type

╔══════════════════════════════════════════════════════════╗
║                  Viewable File Type                      ║
╠══════════════════════════════════════════════════════════╣
║ │File Extension          .zip                            ║
║ │Command Line            ?archive list %f                ║
║ │Native Executable       Yes                             ║
║ │Access Requirements                                     ║
╚══════════════════════════════════════════════════════════╝
Option Name Description
File Extension Suffix to match (with leading ., e.g. .zip). Wildcards * / ? are allowed; * alone matches all files.
Command Line The command line to execute. Use %f or %s for the file's path. Standard prefixes apply (? for exec JS, * for Baja, etc.).
Native Executable Yes for native binaries; No for DOS programs.
Access Requirements An ARS expression — only users matching it will see this view option for matching files.

Testable File Types

A list of file types whose upload triggers a sysop-configured test command. The test must return error code 0 to mean “passed” — non-zero rejects the upload. Use this for virus scanning, archive integrity checks, or any sysop-side processing.

╔══════════════════════════════════════════════════╗
║                Testable File Types               ║
╠══════════════════════════════════════════════════╣
║ │.zip      ?archive test %f                      ║
║ │.7z       ?archive test %f                      ║
║ │*         ?virusscan %f                         ║
║ │                                                ║
╚══════════════════════════════════════════════════╝
  • Same matching rules as Viewable File Types. Multiple test commands per extension are run in sequence.
  • The test command can also modify the upload: it may rewrite sbbsfile.nam (filename) or sbbsfile.des (description) in the node directory before Synchronet finalizes the upload.
  • Also known as an upload processing event.

Testable File Type

╔══════════════════════════════════════════════════════════╗
║                   Testable File Type                     ║
╠══════════════════════════════════════════════════════════╣
║ │File Extension          .zip                            ║
║ │Command Line            ?archive test %f                ║
║ │Native Executable       Yes                             ║
║ │Working String          Testing archive integrity...    ║
║ │Access Requirements                                     ║
╚══════════════════════════════════════════════════════════╝

Same fields as Viewable File Type, plus:

Option Name Description
Working String Optional message displayed to the user while the test command runs (e.g. “Testing archive integrity...”). Leave blank for silent operation.
Command Line Use %f for the path to the uploaded file, %s for the path to the sbbsfile.des file (file description).

Download Events

A list of file types that trigger a command line on download. Same matching/return-code semantics as Testable File Types. Use this for download notifications, statistics tracking, or post-download archive maintenance.

╔══════════════════════════════════════════════════╗
║                 Download Events                  ║
╠══════════════════════════════════════════════════╣
║ │.zip      ?dlevent %f                           ║
║ │                                                ║
╚══════════════════════════════════════════════════╝

Download Event

╔══════════════════════════════════════════════════════════╗
║                    Download Event                        ║
╠══════════════════════════════════════════════════════════╣
║ │File Extension          .zip                            ║
║ │Command Line            ?dlevent %f                     ║
║ │Native Executable       Yes                             ║
║ │Working String                                          ║
║ │Access Requirements                                     ║
╚══════════════════════════════════════════════════════════╝

Same fields as Testable File Type.

Extractable File Types

External extraction methods, by file type. Synchronet has built-in support for zip, 7z, tar.gz, and a few other common archive formats — these need no entry here. Use this section to add support for archive types Synchronet doesn't natively decompress.

╔══════════════════════════════════════════════════╗
║              Extractable File Types              ║
╠══════════════════════════════════════════════════╣
║ │.rar      unrar x %f                            ║
║ │.arj      unarj e %f                            ║
║ │                                                ║
╚══════════════════════════════════════════════════╝

Extractable File Type

╔══════════════════════════════════════════════════════════╗
║                  Extractable File Type                   ║
╠══════════════════════════════════════════════════════════╣
║ │File Extension          .rar                            ║
║ │Command Line            unrar x %f                      ║
║ │Native Executable       Yes                             ║
║ │Access Requirements                                     ║
╚══════════════════════════════════════════════════════════╝

Same fields as Viewable File Type.

Compressible File Types

External compression/archive methods, by file type. Like Extractable, this extends Synchronet's built-in support for common formats — add an entry only when sysop-supplied compression is required.

╔══════════════════════════════════════════════════╗
║              Compressible File Types             ║
╠══════════════════════════════════════════════════╣
║ │.rar      rar a %f *                            ║
║ │                                                ║
╚══════════════════════════════════════════════════╝

Compressible File Type

╔══════════════════════════════════════════════════════════╗
║                  Compressible File Type                  ║
╠══════════════════════════════════════════════════════════╣
║ │File Extension          .rar                            ║
║ │Command Line            rar a %f *                      ║
║ │Native Executable       Yes                             ║
║ │Access Requirements                                     ║
╚══════════════════════════════════════════════════════════╝

Same fields as Viewable File Type.

File Transfer Protocols

A list of file transfer protocols available to users for upload and download. Synchronet ships with built-in Zmodem (single-file and batch) and X/Y-modem support — additional or replacement protocols can be configured here.

For each protocol, you specify the command-key mnemonic, separate command lines for upload / download / batch upload / batch download, and a few flags. Leave a command line blank to disable that mode.

╔══════════════════════════════════╗
║      File Transfer Protocols     ║
╠══════════════════════════════════╣
║ │Z  Zmodem                       ║
║ │Y  Ymodem                       ║
║ │X  Xmodem                       ║
║ │                                ║
╚══════════════════════════════════╝

File Transfer Protocol

╔══════════════════════════════════════════════════════════════════════╗
║                       File Transfer Protocol                         ║
╠══════════════════════════════════════════════════════════════════════╣
║ │Mnemonic (Command Key)        Z                                     ║
║ │Protocol Name                 Zmodem                                ║
║ │Access Requirements                                                 ║
║ │Upload Command Line           *zmodemrcv                            ║
║ │Download Command Line         *zmodemsnd %f                         ║
║ │Batch Upload Command Line     *zmodemrcv                            ║
║ │Batch Download Command Line   *zmodemsnd @%f                        ║
║ │Native Executable             Yes                                   ║
║ │Supports DSZLOG               Yes                                   ║
║ │Socket I/O                    No                                    ║
╚══════════════════════════════════════════════════════════════════════╝
Option Name Description
Mnemonic (Command Key) The single keystroke users press at the protocol-selection prompt to pick this protocol (e.g. Z for Zmodem). Must be unique across all configured protocols.
Protocol Name Display name shown in the protocol-selection menu.
Access Requirements An ARS expression — only users matching it will see this protocol as an option.
Upload Command Line Command line for single-file uploads. Leave blank if the protocol can't upload.
Download Command Line Command line for single-file downloads. %f = path to the file.
Batch Upload Command Line Command line for batch (multi-file) uploads. Leave blank if the protocol doesn't support batch uploads.
Batch Download Command Line Command line for batch downloads. @%f refers to a list-file (one path per line) Synchronet writes.
Native Executable Yes for native binaries; No for DOS programs.
Supports DSZLOG If Yes, the program writes a DSZ-style log (DSZLOG env-var) that Synchronet reads to verify completion and CPS. Most modern Zmodem implementations support this.
Socket I/O (*nix only) If Yes, the protocol communicates over the BBS's TCP socket directly rather than via stdin/stdout. Required for protocols that do their own I/O multiplexing.

See Also