Synchronet v3.19b-Win32 (install) has been released (Jan-2022).

You can donate to the Synchronet project using PayPal.

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
custom:atcodes [2020/10/14 21:02]
digital man [User Information] Add BIRTH @-code and aliases: BIRTHFMT and BIRTH:fmt
custom:atcodes [2022/02/26 12:35]
digital man [System Information] Add BUILD_DATE and BUILD_TIME
Line 1: Line 1:
 ====== Message Variables (@-codes) ====== ====== Message Variables (@-codes) ======
  
-Synchronet sysop-posted messages, text and menu files, and some lines in the ''​[[dir:​ctrl]]/​[[text.dat]]''​ file may contain special //Message Variables//,​ also called //@-codes// ("at codes",​ some BBS authors and sysops refer to these types of codes as "@ Macros"​ or  "MCI codes"​((and not because of the defunct phone company))). @-codes may also be displayed using the ''​bbs.atcode()''​ JavaScript method.+Synchronet sysop-posted messages, text and menu files, and some lines in the ''​[[dir:​ctrl]]/​[[text.dat]]''​ file may contain special //Message Variables//,​ also called //@-codes// ("at codes",​ some BBS authors and sysops refer to these types of codes as "@ Macros"​ or "@ Variables"​ or "MCI codes"​((and not because of the defunct phone company))). @-codes may also be displayed using the ''​bbs.atcode()'' ​[[JavaScript]] method.
  
 @-codes are called such because they begin and end with the ''​@''​ (ASCII 64) ("​at"​) character. The code names themselves (sandwiched between the @'s) must be entered using only ''​UPPERCASE''​ letters. Some additional symbols and numbers may also be included in the @-code, but never a space. @-codes are called such because they begin and end with the ''​@''​ (ASCII 64) ("​at"​) character. The code names themselves (sandwiched between the @'s) must be entered using only ''​UPPERCASE''​ letters. Some additional symbols and numbers may also be included in the @-code, but never a space.
Line 62: Line 62:
 |AUTODEL ​       |                |Maximum days of user inactivity before auto-deletion or "​unlimited"​ | |AUTODEL ​       |                |Maximum days of user inactivity before auto-deletion or "​unlimited"​ |
 |BBS            |BOARDNAME ​      |Name of BBS |  |BBS            |BOARDNAME ​      |Name of BBS |
 +|BUILD_DATE ​    ​| ​               |Date of Synchronet build |
 +|BUILD_TIME ​    ​| ​               |Time of Synchronet build |
 |COMPILER ​      ​| ​               |Compiler used to build Synchronet| |COMPILER ​      ​| ​               |Compiler used to build Synchronet|
 |CONF           ​| ​               |Name of current Group and Sub-board| |CONF           ​| ​               |Name of current Group and Sub-board|
Line 97: Line 99:
 |FREESPACEK ​    ​| ​               |Free disk space available for uploads (in kibibytes) | |FREESPACEK ​    ​| ​               |Free disk space available for uploads (in kibibytes) |
 |FULL_VER ​      ​| ​               |Synchronet full version number (e.g. "​3.15a"​)| |FULL_VER ​      ​| ​               |Synchronet full version number (e.g. "​3.15a"​)|
 +|GIT_BRANCH ​    ​| ​               |Synchronet Git repository branch name (e.g. "​master"​)|
 +|GIT_HASH ​      ​| ​               |Synchronet Git repository commit hash (most significant Git-SHA hex-digits)|
 |GRP            |                |Current message group short description | |GRP            |                |Current message group short description |
 |GRPL           ​| ​               |Current message group long description | |GRPL           ​| ​               |Current message group long description |
Line 176: Line 180:
 |MSG_UPVOTED ​   |                |Current user up-voted status for current message (checkmark) | |MSG_UPVOTED ​   |                |Current user up-voted status for current message (checkmark) |
 |MSG_DOWNVOTED ​ |                |Current user down-voted status for current message (checkmark) | |MSG_DOWNVOTED ​ |                |Current user down-voted status for current message (checkmark) |
 +|MSG_THREAD_ID ​ |                |Current message thread'​s thread-id (message number) |
 +|MSG_THREAD_NEXT| ​               |Current message thread'​s next message number |
 +|MSG_THREAD_BACK| ​               |Current message thread'​s previous message number |
 +|MSG_THREAD_FIRST| ​              ​|Current message'​s first reply message number |
 |FILE_AREA ​     |                |Current file area (lib and directory) names | |FILE_AREA ​     |                |Current file area (lib and directory) names |
 |FILE_AREA_DESC |                |Current file area (lib and directory) descriptions | |FILE_AREA_DESC |                |Current file area (lib and directory) descriptions |
Line 216: Line 224:
 |SYSOP ​         |                |Name of System Operator | |SYSOP ​         |                |Name of System Operator |
 |SYSAVAIL ​      ​| ​               |Sysop availability for chat (e.g. "​Available"​ or "Not Available"​)| |SYSAVAIL ​      ​| ​               |Sysop availability for chat (e.g. "​Available"​ or "Not Available"​)|
 +|SYSAVAILYN ​    ​| ​               |Sysop availability for chat (e.g. "​Yes"​ or "​No"​)|
 |TFILE ​         |                |Total number of files on system | |TFILE ​         |                |Total number of files on system |
 |TIME           ​|SYSTIME ​        ​|Current system time | |TIME           ​|SYSTIME ​        ​|Current system time |
Line 280: Line 289:
 |KBLEFT ​        ​| ​               |User'​s total credits (in kibibytes) ​            | |KBLEFT ​        ​| ​               |User'​s total credits (in kibibytes) ​            |
 |KBLIMIT ​       |DLKLIMIT, MAXDK |User'​s free credits per day (in kibibytes) ​     | |KBLIMIT ​       |DLKLIMIT, MAXDK |User'​s free credits per day (in kibibytes) ​     |
-|MAILW        ​| ​               |Number of mail messages waiting for current user (includes SPAM)| +|MAILR        ​| ​                 |Number ​of read mail messages waiting for current user| 
-|MAILW://​x// ​ |MAILW#//​x// ​        ​|Number ​of mail messages waiting for current ​user number //x// (x=0 for all users)| +|MAILR://​x// ​ |MAILR#//​x// ​      ​|Number of read mail messages waiting for user number //x// (x=0 for all users)| 
-|MAILP ​       |                |Number of pending mail messages sent by current user| +|MAILU ​       |                  |Number of unread mail messages waiting for current user| 
-|MAILP://​x// ​ |MAILP#//​x// ​        ​|Number of pending mail messages sent by current ​user number //x// |+|MAILU://​x// ​ |MAILU#//​x// ​      ​|Number of unread mail messages waiting for user number //x// (x=0 for all users)| 
 +|MAILW ​       |                  |Total number ​of mail messages waiting for current user (includes SPAM)| 
 +|MAILW://​x// ​ |MAILW#//​x// ​      ​|Total number ​of mail messages waiting for user number //x// (x=0 for all users)| 
 +|MAILP ​       |                  |Number of pending mail messages sent by current user| 
 +|MAILP://​x// ​ |MAILP#//​x// ​      ​|Number of pending mail messages sent by user number //x// |
 |MAXCALLS ​    ​| ​               |Maximum number of calls/​logons per day allowed per user's security level | |MAXCALLS ​    ​| ​               |Maximum number of calls/​logons per day allowed per user's security level |
 |MAXLINES ​    ​| ​               |Maximum number of lines per message allowed per user's security level | |MAXLINES ​    ​| ​               |Maximum number of lines per message allowed per user's security level |
Line 300: Line 313:
 |NOTE         ​|MEMO1 ​          ​|User'​s note (new in v3.18c) | |NOTE         ​|MEMO1 ​          ​|User'​s note (new in v3.18c) |
 |PAGER ​       |                |Chat pager enabled status (e.g. "​On"​ or "​Off"​)| |PAGER ​       |                |Chat pager enabled status (e.g. "​On"​ or "​Off"​)|
-|PCR          |                |User'​s post/call ratio (0-100) | +|PCR          |                |User'​s post/call ratio, as a percentage ​(not capped at 100) | 
-|PHONE ​       |HOMEPHONE, DATA, DATAPHONE |Users's phone number |+|PHONE ​       |HOMEPHONE, DATA, DATAPHONE |User's phone number |
 |PTODAY ​      ​| ​               |Number of messages posted by user today | |PTODAY ​      ​| ​               |Number of messages posted by user today |
 |PWAGE ​       |                |Age (in days) of the current user's password | |PWAGE ​       |                |Age (in days) of the current user's password |
Line 324: Line 337:
 |TTOTAL ​      ​| ​        ​|Total time used by user for all previous calls/​logons (in "​HH:​MM"​ format) | |TTOTAL ​      ​| ​        ​|Total time used by user for all previous calls/​logons (in "​HH:​MM"​ format) |
 |TUSED ​       |         |Time used this call (in "​H:​MM:​SS"​ format) |  |TUSED ​       |         |Time used this call (in "​H:​MM:​SS"​ format) |
 +|UDR          |         ​|User'​s upload/​download byte ratio, as a percentage (not capped at 100) |
 +|UDFR         ​| ​        ​|User'​s upload/​download file ratio, as a percentage (not capped at 100) |
 |UPBYTES ​     |         ​|Total bytes uploaded by user | |UPBYTES ​     |         ​|Total bytes uploaded by user |
 |UPFILES ​     |UPS      |Total files uploaded by user |  |UPFILES ​     |UPS      |Total files uploaded by user |
Line 362: Line 377:
 |QUITCHAR ​       |        |Print the character that corresponds with a "​quit"​ command key (e.g. ''​Q''​) | |QUITCHAR ​       |        |Print the character that corresponds with a "​quit"​ command key (e.g. ''​Q''​) |
 |EOF             ​| ​       |End-of-file (stop parsing/​displaying) | |EOF             ​| ​       |End-of-file (stop parsing/​displaying) |
-|PAUSE ​          ​|MORE ​   |Force a screen pause (hit a keyprompt|+|PAUSE ​          ​|MORE ​   |Force a screen pause and a ''​[Hit ​a key]'' ​prompt, if '​N'​ or '​Q'​ are typed, the displayed message/​file is aborted ​|
 |PON             ​|AUTOMORE|Toggle automatic screen pause on | |PON             ​|AUTOMORE|Toggle automatic screen pause on |
 |POFF            |NOPAUSE |Toggle automatic screen pause off | |POFF            |NOPAUSE |Toggle automatic screen pause off |
 |RESETPAUSE ​     |        |Reset the automatic screen pause line counter | |RESETPAUSE ​     |        |Reset the automatic screen pause line counter |
-|DELAY://​n// ​        ​|        |Wait //n// 10ths of a second before continuing | +|GETKEY ​         |        |Wait indefinitely for any key press before continuing | 
-|UP://​n// ​           |        |Move cursor up //n// rows                   | +|CONTINUE ​       |        |Wait indefinitely for any key press before continuing and abort the message/​file display if '​N'​ or '​Q'​ are typed |  
-|DOWN://​n// ​         |        |Move cursor down //n// rows                 | +|WAIT://​n// ​     |        |Wait up to //n// 10ths of a second for a key press before continuing | 
-|RIGHT://​n// ​        ​|        |Move cursor right //n// columns ​            | +|DELAY://​n// ​    ​|        |Wait //n// 10ths of a second before continuing | 
-|LEFT://​n// ​         |        |Move cursor left //n// columns ​             |+|UP://​n// ​       |        |Move cursor up //n// rows                   | 
 +|DOWN://​n// ​     |        |Move cursor down //n// rows                 | 
 +|RIGHT://​n// ​    ​|        |Move cursor right //n// columns ​            | 
 +|LEFT://​n// ​     |        |Move cursor left //n// columns ​             |
 |GOTOXY://​x,​y// ​ |        |Move cursor to //x/////y// coordinate (1-based) | |GOTOXY://​x,​y// ​ |        |Move cursor to //x/////y// coordinate (1-based) |
 |POS://​x// ​      ​| ​       |Move cursor to column //x// (1-based) | |POS://​x// ​      ​| ​       |Move cursor to column //x// (1-based) |
Line 388: Line 406:
 |CENTER ​         |        |Middle-align the remaining text on the line | |CENTER ​         |        |Middle-align the remaining text on the line |
 |SYSONLY ​        ​| ​       |Toggle off/on visibility for non-sysops | |SYSONLY ​        ​| ​       |Toggle off/on visibility for non-sysops |
 +|SHOW://​ars// ​   |        |Turn off the display of the following text for users not meeting the specified [[access:​requirements|Access Requirements String]] (without spaces). |
 +|SHOW            |        |Turn on the display of following text for all users |
 |FILL://​ctext// ​ |        |Repeat the specified //ctext// (may contain C-escape sequences), filling the current line (to terminal columns - 1)  | |FILL://​ctext// ​ |        |Repeat the specified //ctext// (may contain C-escape sequences), filling the current line (to terminal columns - 1)  |
 |WIDE://​text// ​  ​| ​       |Display specified //text// double-wide,​ using Unicode "​fullwidth"​ characters if possible | |WIDE://​text// ​  ​| ​       |Display specified //text// double-wide,​ using Unicode "​fullwidth"​ characters if possible |
Line 394: Line 414:
 |U+//​code//,//​char//​ |        | Send a Unicode character code point, specifying fallback character value in hexadecimal (or ''​0''​ for //none//) | |U+//​code//,//​char//​ |        | Send a Unicode character code point, specifying fallback character value in hexadecimal (or ''​0''​ for //none//) |
 |U+//​code//​!//​char//​ |        | Send a Unicode character code point, specifying fallback character only to used when no automatic fallback is available | |U+//​code//​!//​char//​ |        | Send a Unicode character code point, specifying fallback character only to used when no automatic fallback is available |
 +|!//x// |                     | Execute the terminal/​attribute control sequences for one or more [[Ctrl-A Codes]] (operands) represented by //x//|
 ==== C-Text ==== ==== C-Text ====
  
Line 445: Line 465:
  
 ^Code             ​^Description ^ ^Code             ​^Description ^
-|MENU:​filename ​   |Display a menu file from the ''​[[dir:​text]]/​menu''​ directory| +|MENU://filename//    ​|Display a menu file from the ''​[[dir:​text]]/​menu''​ directory| 
-|CONDMENU:​filename|Display a menu file from the ''​[[dir:​text]]/​menu''​ directory, only if it exists (conditionally)| +|CONDMENU://filename//|Display a menu file from the ''​[[dir:​text]]/​menu''​ directory, only if it exists (conditionally)| 
-|TYPE:​filename ​   |Display a specific filename (may include [[:​config:​cmdline#​specifiers]]) | +|TYPE://filename//    ​|Display a specific filename (may include [[:​config:​cmdline#​specifiers]]) | 
-|INCLUDE:​filename |Display a specific filename (may include [[:​config:​cmdline#​specifiers]]) without a trailing CR/LF pair | +|INCLUDE://filename// |Display a specific filename (may include [[:​config:​cmdline#​specifiers]]) without a trailing CR/LF pair | 
-|EXEC:​module ​     |Execute an in-process module (Baja or JavaScript) from the ''​[[dir:​exec]]''​ directory| +|EXEC://module//      ​|Execute an in-process module (Baja or JavaScript) from the ''​[[dir:​exec]]''​ directory| 
-|EXEC_XTRN:​code ​  ​|Execute an external online program (e.g. door) by specifying the internal code| +|EXEC_XTRN://code//   |Execute an external online program (e.g. door) by specifying the internal code| 
-|SETSTR:​str ​      |Sets the current Baja/PCMS command string to //str//|+|SETSTR://str//       |Sets the current Baja/PCMS command string to //str//|
 |STR              |Display the current Baja/PCMS command string value |\ |STR              |Display the current Baja/PCMS command string value |\
-|STRVAR:​name ​     |Display the contents of a Baja/PCMS command shell string variable, specify //name// in ALL-CAPS unless ''​baja -c''​ was used((this feature only works for variables defined in command shells)) | +|STRVAR://name//      ​|Display the contents of a Baja/PCMS command shell string variable, specify //name// in ALL-CAPS unless ''​baja -c''​ was used((this feature only works for variables defined in command shells)) | 
-|JS:​name ​         |Display the value of a named JavaScript property | +|JS://name//          ​|Display the value of a named JavaScript property | 
 +|TEXT://​number// ​     |Display the specified string number from the ''​[[dir:​ctrl]]/​[[custom:​text.dat]]''​ file.|
 ===== See Also ===== ===== See Also =====
   * [[custom:​menu_files|Menu Files]]   * [[custom:​menu_files|Menu Files]]

In Other Languages