diff --git a/admin/administration.html b/admin/administration.html index 8a0b73b5..dd3b0f62 100644 --- a/admin/administration.html +++ b/admin/administration.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Administration","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/admin/administration.html"},"url":"/enigma-bbs/admin/administration.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Administration","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/admin/oputil.html b/admin/oputil.html index 2160201a..c4940664 100644 --- a/admin/oputil.html +++ b/admin/oputil.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The oputil CLI ENiGMA½ comes with oputil.js henceforth known as oputil, a command line interface (CLI) tool for sysops to perform general system and user administration. You likely used oputil to do the initial ENiGMA configuration.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/admin/oputil.html"},"url":"/enigma-bbs/admin/oputil.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"oputil","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/admin/updating.html b/admin/updating.html index fdd94296..aafe3e95 100644 --- a/admin/updating.html +++ b/admin/updating.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Updating Keeping your system up to date ensures you have the latest fixes, features, and general improvements. Updating ENiGMA½ can be a bit of a learning curve compared to traditional binary-release systems you may be used to, especially when running from Git cloned source.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/admin/updating.html"},"url":"/enigma-bbs/admin/updating.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Updating","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/general.html b/art/general.html index af4fdf65..84b23158 100644 --- a/art/general.html +++ b/art/general.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"General Art Information One of the most basic elements of BBS customization is through it’s artwork. ENiGMA½ supports a variety of ways to select, display, and manage art.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/general.html"},"url":"/enigma-bbs/art/general.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"General Art Information","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/mci.html b/art/mci.html index 9f24aea7..3af4dab4 100644 --- a/art/mci.html +++ b/art/mci.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"MCI Codes ENiGMA½ supports a variety of MCI codes. Some predefined codes produce information about the current user, system, or other statistics while others are used to instantiate a View.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/mci.html"},"url":"/enigma-bbs/art/mci.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"MCI Codes","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/themes.html b/art/themes.html index b5915825..bb4205b8 100644 --- a/art/themes.html +++ b/art/themes.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Themes ENiGMA½ comes with an advanced theming system allowing system operators to highly customize the look and feel of their boards. A given installation can have as many themes as you like for your users to choose from.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/themes.html"},"url":"/enigma-bbs/art/themes.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Themes","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/button_view.html b/art/views/button_view.html index d6163ad5..0d4ceef1 100644 --- a/art/views/button_view.html +++ b/art/views/button_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Button View A button view supports displaying a button on a screen.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/button_view.html"},"url":"/enigma-bbs/art/views/button_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Button View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/edit_text_view.html b/art/views/edit_text_view.html index b7a8e91c..eac7eb0d 100644 --- a/art/views/edit_text_view.html +++ b/art/views/edit_text_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Edit Text View An edit text view supports editing form values on a screen. This can be for new entry as well as editing existing values defined by the module.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/edit_text_view.html"},"url":"/enigma-bbs/art/views/edit_text_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Edit Text View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/full_menu_view.html b/art/views/full_menu_view.html index 03ee0449..5986f1d2 100644 --- a/art/views/full_menu_view.html +++ b/art/views/full_menu_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Full Menu View A full menu view supports displaying a list of times on a screen in a very configurable manner. A full menu view supports either a single row or column of values, similar to Horizontal Menu (HM) and Vertical Menu (VM), or in multiple columns.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/full_menu_view.html"},"url":"/enigma-bbs/art/views/full_menu_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Full Menu View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/horizontal_menu_view.html b/art/views/horizontal_menu_view.html index 47c55abd..d870b71b 100644 --- a/art/views/horizontal_menu_view.html +++ b/art/views/horizontal_menu_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Horizontal Menu View A horizontal menu view supports displaying a list of times on a screen horizontally (side to side, in a single row) similar to a lightbox.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/horizontal_menu_view.html"},"url":"/enigma-bbs/art/views/horizontal_menu_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Horizontal Menu View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/mask_edit_text_view.html b/art/views/mask_edit_text_view.html index 015e36e3..4c678500 100644 --- a/art/views/mask_edit_text_view.html +++ b/art/views/mask_edit_text_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Mask Edit Text View A mask edit text view supports editing form values on a screen. This can be for new entry as well as editing existing values. Unlike a edit text view, the mask edit text view uses a mask pattern to specify what format the values should be entered in.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/mask_edit_text_view.html"},"url":"/enigma-bbs/art/views/mask_edit_text_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Mask Edit Text View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/multi_line_edit_text_view.html b/art/views/multi_line_edit_text_view.html index c1cf6040..c138abe0 100644 --- a/art/views/multi_line_edit_text_view.html +++ b/art/views/multi_line_edit_text_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Multi Line Edit Text View A text display / editor designed to edit or display a message.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/multi_line_edit_text_view.html"},"url":"/enigma-bbs/art/views/multi_line_edit_text_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Multi Line Edit Text View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/predefined_label_view.html b/art/views/predefined_label_view.html index a08187ef..ce3d3b1e 100644 --- a/art/views/predefined_label_view.html +++ b/art/views/predefined_label_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Predefined Label View A predefined label view supports displaying a predefined MCI label on a screen.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/predefined_label_view.html"},"url":"/enigma-bbs/art/views/predefined_label_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Predefined Label View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/spinner_menu_view.html b/art/views/spinner_menu_view.html index a21a33f3..af7aa72d 100644 --- a/art/views/spinner_menu_view.html +++ b/art/views/spinner_menu_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Spinner Menu View A spinner menu view supports displaying a set of times on a screen as a list, with one item displayed at a time. This is generally used to pick one option from a list. Some examples could include selecting from a list of states, themes, etc.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/spinner_menu_view.html"},"url":"/enigma-bbs/art/views/spinner_menu_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Spinner Menu View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/text_view.html b/art/views/text_view.html index 60dbe5d0..3b16204a 100644 --- a/art/views/text_view.html +++ b/art/views/text_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Text View A text label view supports displaying simple text on a screen.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/text_view.html"},"url":"/enigma-bbs/art/views/text_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Text View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/toggle_menu_view.html b/art/views/toggle_menu_view.html index 79c5b092..041e758b 100644 --- a/art/views/toggle_menu_view.html +++ b/art/views/toggle_menu_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Toggle Menu View A toggle menu view supports displaying a list of options on a screen horizontally (side to side, in a single row) similar to a Horizontal Menu. It is designed to present one of two choices easily.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/toggle_menu_view.html"},"url":"/enigma-bbs/art/views/toggle_menu_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Toggle Menu View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/art/views/vertical_menu_view.html b/art/views/vertical_menu_view.html index 0739ad28..4eb1fd8b 100644 --- a/art/views/vertical_menu_view.html +++ b/art/views/vertical_menu_view.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Vertical Menu View A vertical menu view supports displaying a list of times on a screen vertically in a single column, similar to a lightbar. This type of control is often useful for lists of items or menu controls.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/art/views/vertical_menu_view.html"},"url":"/enigma-bbs/art/views/vertical_menu_view.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Vertical Menu View","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/acs.html b/configuration/acs.html index 654f6d31..ec6f13cc 100644 --- a/configuration/acs.html +++ b/configuration/acs.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Access Condition System (ACS) ENiGMA½ uses an Access Condition System (ACS) that is both familiar to oldschool BBS operators and has it’s own style. With ACS, SysOp’s are able to control access to various areas of the system based on various conditions such as group membership, connection type, etc. Various touch points in the system are configured to allow for acs checks. In some cases ACS is a simple boolean check while others (via ACS blocks) allow to define what conditions must be true for certain rights such as read and write (though others exist as well).","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/acs.html"},"url":"/enigma-bbs/configuration/acs.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Access Condition System (ACS)","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/archivers.html b/configuration/archivers.html index 8773bd8d..6718f2ed 100644 --- a/configuration/archivers.html +++ b/configuration/archivers.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Archivers ENiGMA½ can detect and process various archive formats such as zip and arj for a variety of tasks from file upload processing to EchoMail bundle compress/decompression. The archives section of config.hjson is used to override defaults, add new handlers, and so on.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/archivers.html"},"url":"/enigma-bbs/configuration/archivers.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Archivers","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/colour-codes.html b/configuration/colour-codes.html index d1ff7729..f36ad722 100644 --- a/configuration/colour-codes.html +++ b/configuration/colour-codes.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"ENiGMA½ supports Renegade-style pipe colour codes for formatting strings. You’ll see them used throughout your configuration, and can also be used in places like onelinerz, rumourz, full screen editor etc.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/colour-codes.html"},"url":"/enigma-bbs/configuration/colour-codes.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Colour Codes","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/config-files.html b/configuration/config-files.html index 3d796041..d83facd6 100644 --- a/configuration/config-files.html +++ b/configuration/config-files.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"General Information ENiGMA½ configuration files such as the system config, menus and themes are formatted in the HJSON format.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/config-files.html"},"url":"/enigma-bbs/configuration/config-files.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Configuration Files","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/config-hjson.html b/configuration/config-hjson.html index 97753b4f..04a3c3d3 100644 --- a/configuration/config-hjson.html +++ b/configuration/config-hjson.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"System Configuration The main system configuration file, config.hjson both overrides defaults and provides additional configuration such as message areas. Defaults lived in core/config_default.js.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/config-hjson.html"},"url":"/enigma-bbs/configuration/config-hjson.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"System Configuration","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/creating-config.html b/configuration/creating-config.html index 3f9f3325..1689744d 100644 --- a/configuration/creating-config.html +++ b/configuration/creating-config.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Configuration files in ENiGMA½ are simple UTF-8 encoded HJSON files. HJSON is just like JSON but simplified and much more resilient to human error.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/creating-config.html"},"url":"/enigma-bbs/configuration/creating-config.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Creating Initial Config Files","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/directory-structure.html b/configuration/directory-structure.html index 65accb1b..e5632a6d 100644 --- a/configuration/directory-structure.html +++ b/configuration/directory-structure.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"All paths mentioned here are relative to the ENiGMA½ checkout directory.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/directory-structure.html"},"url":"/enigma-bbs/configuration/directory-structure.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Directory Structure","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/email.html b/configuration/email.html index f53f4e82..243c92c2 100644 --- a/configuration/email.html +++ b/configuration/email.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Email Support ENiGMA½ uses email to send password reset information to users. For it to work, you need to provide valid Nodemailer compatible email block in your config.hjson. Nodemailer supports SMTP in addition to many pre-defined services for ease of use. The transport block within email must be Nodemailer compatible.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/email.html"},"url":"/enigma-bbs/configuration/email.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Email","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/event-scheduler.html b/configuration/event-scheduler.html index c8d6b740..8e53afab 100644 --- a/configuration/event-scheduler.html +++ b/configuration/event-scheduler.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Event Scheduler The ENiGMA½ scheduler allows system operators to configure arbitrary events that can can fire based on date and/or time, or by watching for changes in a file. Events can kick off internal handlers, custom modules, or binaries & scripts.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/event-scheduler.html"},"url":"/enigma-bbs/configuration/event-scheduler.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Event Scheduler","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/external-binaries.html b/configuration/external-binaries.html index 6ff68f53..9379108a 100644 --- a/configuration/external-binaries.html +++ b/configuration/external-binaries.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"External Support Binaries ENiGMA½ relies on various external binaries in order to perform common tasks such as processing file archives and extracting information from uploads/file imports, some legacy transfer protocols, etc.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/external-binaries.html"},"url":"/enigma-bbs/configuration/external-binaries.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"External Support Binaries","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/file-transfer-protocols.html b/configuration/file-transfer-protocols.html index 5095fa7e..ea2cca49 100644 --- a/configuration/file-transfer-protocols.html +++ b/configuration/file-transfer-protocols.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"ENiGMA½ currently relies on external executable binaries for “legacy” file transfer protocols such as X, Y, and ZModem. Remember that ENiGMA½ also support modern web (HTTP/HTTPS) downloads!","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/file-transfer-protocols.html"},"url":"/enigma-bbs/configuration/file-transfer-protocols.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"File Transfer Protocols","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/hjson.html b/configuration/hjson.html index 22054beb..a278fc96 100644 --- a/configuration/hjson.html +++ b/configuration/hjson.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"JSON for Humans! HJSON is the configuration file format used by ENiGMA½ for System Configuration, Menus, etc. HJSON is is JSON for humans!","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/hjson.html"},"url":"/enigma-bbs/configuration/hjson.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"HJSON Config Files","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/menu-hjson.html b/configuration/menu-hjson.html index eb55f499..7022875e 100644 --- a/configuration/menu-hjson.html +++ b/configuration/menu-hjson.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Menu HJSON The core of a ENiGMA½ based BBS is it’s menus driven by what will be referred to as menu.hjson. Throughout ENiGMA½ documentation, when menu.hjson is referenced, we’re actually talking about config/menus/yourboardname-*.hjson. These files determine the menus (or screens) a user can see, the order they come in, how they interact with each other, ACS configuration, and so on. Like all configuration within ENiGMA½, menu configuration is done in HJSON format.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/menu-hjson.html"},"url":"/enigma-bbs/configuration/menu-hjson.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Menu HSJON","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/security.html b/configuration/security.html index 6f1cdca8..1985b488 100644 --- a/configuration/security.html +++ b/configuration/security.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Security Unlike in the golden era of BBSing, modern Internet-connected systems are prone to hacking attempts, eavesdropping, etc. While plain-text passwords, insecure data over Plain Old Telephone Service (POTS), and so on was good enough then, modern systems must employ protections against attacks. ENiGMA½ comes with many security features that help keep the system and your users secure — not limited to: Passwords are never stored in plain-text, but instead are stored using Password-Based Key Derivation Function 2 (PBKDF2). Even the system operator can never know your password! Alternatives to insecure Telnet logins are built in: SSH and secure WebSockets for example. A built in web server with TLS support (aka HTTPS). Optional Two-Factor Authentication (2FA) via One-Time-Password (OTP) for users, supporting Google Authenticator, Time-Based One-Time Password Algorithm (TOTP, RFC-6238), and HMAC-Based One-Time Password Algorithm (HOTP, RFC-4266).","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/security.html"},"url":"/enigma-bbs/configuration/security.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Security","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/configuration/sysop-setup.html b/configuration/sysop-setup.html index 8f80016a..7a03bbab 100644 --- a/configuration/sysop-setup.html +++ b/configuration/sysop-setup.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"SySop privileges will be granted to the first user to log into a fresh ENiGMA½ installation. +ops belong to the sysop user group by default.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/configuration/sysop-setup.html"},"url":"/enigma-bbs/configuration/sysop-setup.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"SysOp Setup","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/acs.html b/filebase/acs.html index 12467424..6d1d448c 100644 --- a/filebase/acs.html +++ b/filebase/acs.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"File Base ACS ACS Codes may be used to control access to File Base areas by specifying an acs string in a file area’s definition. If no acs is supplied in a file area definition, the following defaults apply to an area: read : GM[users]: List/view the area and it’s contents. write : GM[sysops]: Upload. download : GM[users]: Download.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/acs.html"},"url":"/enigma-bbs/filebase/acs.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"ACS","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/first-file-area.html b/filebase/first-file-area.html index b6831dcc..e9f3e467 100644 --- a/filebase/first-file-area.html +++ b/filebase/first-file-area.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Configuring a File Base ENiGMA½ offers a powerful and flexible file base. Configuration of file the file base and areas is handled via the fileBase section of config.hjson.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/first-file-area.html"},"url":"/enigma-bbs/filebase/first-file-area.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Configuring a File Base","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/index.html b/filebase/index.html index 22af7f8d..6d61e838 100644 --- a/filebase/index.html +++ b/filebase/index.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"About File Areas","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/"},"url":"/enigma-bbs/filebase/","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"About File Areas","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/network-mounts-and-symlinks.html b/filebase/network-mounts-and-symlinks.html index cc3e2fe0..dad5bd64 100644 --- a/filebase/network-mounts-and-symlinks.html +++ b/filebase/network-mounts-and-symlinks.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Network Mounts & Symlinks With many Bulletin Board Systems running on small headless boxes such as Raspberry Pis, it may not be practical to have all files you would like to make available in your file base. One solution to this is to utilize network mounts. Add in symbolic links to make things even easier!","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/network-mounts-and-symlinks.html"},"url":"/enigma-bbs/filebase/network-mounts-and-symlinks.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Network Mounts & Symlinks","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/tic-support.html b/filebase/tic-support.html index c713c18a..d2fcb17e 100644 --- a/filebase/tic-support.html +++ b/filebase/tic-support.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"TIC Support ENiGMA½ supports FidoNet-Style TIC file attachments by mapping TIC areas to local file areas.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/tic-support.html"},"url":"/enigma-bbs/filebase/tic-support.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"TIC Support","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/uploads.html b/filebase/uploads.html index 2b76ef18..0ddc93f6 100644 --- a/filebase/uploads.html +++ b/filebase/uploads.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Uploads The default ACS for file areas in ENiGMA½ is to allow regular users ‘read’ and sysops ‘read/write’. Read ACS includes listing and downloading while write allows for uploading. See File Base ACS for more information.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/uploads.html"},"url":"/enigma-bbs/filebase/uploads.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Uploads","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/filebase/web-access.html b/filebase/web-access.html index 205c8008..8cde5fc6 100644 --- a/filebase/web-access.html +++ b/filebase/web-access.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Temporary web HTTP(S) URLs can be used to download files using the built in web server. Temporary links expire after fileBase::web::expireMinutes (default 24 hours). The full URL given to users is built using contentServers::web::domain and will default to HTTPS (https://) if enabled with a fallback to HTTP. The end result is users are given a temporary web link that may look something like this: https://xibalba.l33t.codes:44512/f/h7JK","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/filebase/web-access.html"},"url":"/enigma-bbs/filebase/web-access.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Web Access","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/docker.html b/installation/docker.html index b6e8d87a..d3044dbc 100644 --- a/installation/docker.html +++ b/installation/docker.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":":warning: You’ll need Docker installed before going any further. How to do so are out of scope of these docs, but you can find full instructions for every operating system on the Docker website.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/docker.html"},"url":"/enigma-bbs/installation/docker.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Docker","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/hardware/rpi.html b/installation/hardware/rpi.html index d0e41892..1989131e 100644 --- a/installation/hardware/rpi.html +++ b/installation/hardware/rpi.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"All Raspberry Pi models work great with ENiGMA½! Keep in mind compiling the dependencies with npm install will take some time and may appear to hang. It’s still working - just be patient and let it complete.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/hardware/rpi.html"},"url":"/enigma-bbs/installation/hardware/rpi.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Raspberry Pi","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/hardware/windows.html b/installation/hardware/windows.html index 4465f21c..15607d8d 100644 --- a/installation/hardware/windows.html +++ b/installation/hardware/windows.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Installation Under Windows","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/hardware/windows.html"},"url":"/enigma-bbs/installation/hardware/windows.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Installation Under Windows","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/install-script.html b/installation/install-script.html index b0b0d413..9510d9ad 100644 --- a/installation/install-script.html +++ b/installation/install-script.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Install Script Under most Linux/UNIX like environments (Linux, BSD, OS X, …) new users can simply execute the install.sh script to get everything up and running. Cut + paste the following into your terminal:","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/install-script.html"},"url":"/enigma-bbs/installation/install-script.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Install Script","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/installation-methods.html b/installation/installation-methods.html index 2fd688ac..d96ef42d 100644 --- a/installation/installation-methods.html +++ b/installation/installation-methods.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Installation Methods There are multiple ways of installing ENiGMA BBS, depending on your level of experience and desire to do things manually versus have it automated for you.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/installation-methods.html"},"url":"/enigma-bbs/installation/installation-methods.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Installation Methods","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/manual.html b/installation/manual.html index 5c2615cd..1d7b4da0 100644 --- a/installation/manual.html +++ b/installation/manual.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"For Linux environments it’s recommended you run the install script. If you like to do things manually, read on…","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/manual.html"},"url":"/enigma-bbs/installation/manual.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Manual Installation","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/network.html b/installation/network.html index 063a482d..2ea6b299 100644 --- a/installation/network.html +++ b/installation/network.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Hosting an ENiGMA instance from your Home Network","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/network.html"},"url":"/enigma-bbs/installation/network.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Network Setup","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/production.html b/installation/production.html index a21944dc..067510ae 100644 --- a/installation/production.html +++ b/installation/production.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"If you’ve become convinced you would like a “production” BBS running ENiGMA½ a more advanced installation may be in order.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/production.html"},"url":"/enigma-bbs/installation/production.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Production Installation","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/installation/testing.html b/installation/testing.html index 3b35ecf5..c2350400 100644 --- a/installation/testing.html +++ b/installation/testing.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Once you’ve completed your chosen installation method, it’s time to test!","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/installation/testing.html"},"url":"/enigma-bbs/installation/testing.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Testing Your Installation","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/messageareas/bso-import-export.html b/messageareas/bso-import-export.html index 09412386..ad0ff85c 100644 --- a/messageareas/bso-import-export.html +++ b/messageareas/bso-import-export.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"BSO Import / Export The scanner/tosser module ftn_bso provides Binkley Style Outbound (BSO) import/toss and scan/export of messages EchoMail and NetMail messages. Configuration is supplied in config.hjson under scannerTossers.ftn_bso.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/messageareas/bso-import-export.html"},"url":"/enigma-bbs/messageareas/bso-import-export.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"BSO Import / Export","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/messageareas/configuring-a-message-area.html b/messageareas/configuring-a-message-area.html index 0fe493fd..280f17d2 100644 --- a/messageareas/configuring-a-message-area.html +++ b/messageareas/configuring-a-message-area.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"General Information In ENiGMA½, a message base is divided into two logical grouping components: Message Conferences and Areas. Message conferences are top level containers while areas are for a specific topic. Messages are always stored internally with a area tag.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/messageareas/configuring-a-message-area.html"},"url":"/enigma-bbs/messageareas/configuring-a-message-area.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Message Base","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/messageareas/ftn.html b/messageareas/ftn.html index 0cca2a82..4b679f98 100644 --- a/messageareas/ftn.html +++ b/messageareas/ftn.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"FidoNet-Style Networks (FTN) FidoNet proper and other FidoNet-Style networks are supported by ENiGMA½. A bit of configuration and you’ll be up and running in no time!","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/messageareas/ftn.html"},"url":"/enigma-bbs/messageareas/ftn.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"FidoNet-Style Networks (FTN)","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/messageareas/message-networks.html b/messageareas/message-networks.html index 170d14f9..fc7c6acf 100644 --- a/messageareas/message-networks.html +++ b/messageareas/message-networks.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Message Networks ENiGMA½ supports external networks such as FidoNet-Style (FTN) and QWK by the way of importing and exporting to/from it’s own internal format. This allows for a very flexible system that can easily be extended by creating new network modules.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/messageareas/message-networks.html"},"url":"/enigma-bbs/messageareas/message-networks.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Message Networks","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/messageareas/netmail.html b/messageareas/netmail.html index 343d801f..6b37e985 100644 --- a/messageareas/netmail.html +++ b/messageareas/netmail.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"ENiGMA support import and export of Netmail from the Private Mail area. RiPuk @ 21:1/136 and RiPuk <21:1/136> ‘To’ address formats are supported.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/messageareas/netmail.html"},"url":"/enigma-bbs/messageareas/netmail.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Netmail","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/messageareas/qwk.html b/messageareas/qwk.html index 1eb10db3..e142857c 100644 --- a/messageareas/qwk.html +++ b/messageareas/qwk.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"QWK and QWK-Net Style Networks As like all other networks such as FidoNet-Style (FTN) networks, ENiGMA½ considers QWK external to the system but can import and export the format.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/messageareas/qwk.html"},"url":"/enigma-bbs/messageareas/qwk.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"QWK Support","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/misc/user-interrupt.html b/misc/user-interrupt.html index a551fa8f..e0b5be88 100644 --- a/misc/user-interrupt.html +++ b/misc/user-interrupt.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"User Interruptions ENiGMA½ provides functionality to “interrupt” a user for various purposes such as a node-to-node message. User interruptions can be queued and displayed at the next opportune time such as when switching to a new menu, or realtime if appropriate.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/misc/user-interrupt.html"},"url":"/enigma-bbs/misc/user-interrupt.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"User Interruptions","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/autosig-edit.html b/modding/autosig-edit.html index 80dd7ba5..8406992f 100644 --- a/modding/autosig-edit.html +++ b/modding/autosig-edit.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The Auto Signature Editor The built in autosig_edit module allows users to edit their auto signatures (AKA “autosig”).","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/autosig-edit.html"},"url":"/enigma-bbs/modding/autosig-edit.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Auto Signature Editor","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/bbs-list.html b/modding/bbs-list.html index 152c779d..3b113839 100644 --- a/modding/bbs-list.html +++ b/modding/bbs-list.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The BBS List Module The built in bbs_list module provides the ability for users to manage entries to other Bulletin Board Systems.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/bbs-list.html"},"url":"/enigma-bbs/modding/bbs-list.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"BBS List","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/door-servers.html b/modding/door-servers.html index a9ab0ba3..f6c502d7 100644 --- a/modding/door-servers.html +++ b/modding/door-servers.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The bbs_link Module Native support for BBSLink doors is provided via the bbs_link module.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/door-servers.html"},"url":"/enigma-bbs/modding/door-servers.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Door Servers","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/existing-mods.html b/modding/existing-mods.html index be6a28ae..9d7f8c55 100644 --- a/modding/existing-mods.html +++ b/modding/existing-mods.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Many “addon” modules exist and have been released. Below are a few:","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/existing-mods.html"},"url":"/enigma-bbs/modding/existing-mods.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Existing Mods","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/file-area-list.html b/modding/file-area-list.html index feb209c0..7bedca5b 100644 --- a/modding/file-area-list.html +++ b/modding/file-area-list.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The File Area List Module The built in file_area_list module provides a very flexible file listing UI.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/file-area-list.html"},"url":"/enigma-bbs/modding/file-area-list.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"File Area List","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/file-base-download-manager.html b/modding/file-base-download-manager.html index afe36727..cadb1611 100644 --- a/modding/file-base-download-manager.html +++ b/modding/file-base-download-manager.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"File Base Download Manager Module The file_base_download_manager module provides a download queue manager for “legacy” (X/Y/Z-Modem, etc.) downloads. Web (HTTP/HTTPS) download functionality can be optionally available when the web content server is enabled.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/file-base-download-manager.html"},"url":"/enigma-bbs/modding/file-base-download-manager.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"File Base Download Manager","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/file-base-web-download-manager.html b/modding/file-base-web-download-manager.html index 3e17f93b..caff6231 100644 --- a/modding/file-base-web-download-manager.html +++ b/modding/file-base-web-download-manager.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"File Base Web Download Manager Module The file_base_web_download_manager module provides a download queue manager for web (HTTP/HTTPS) based downloads. This module relies on having the web server enabled at a minimum.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/file-base-web-download-manager.html"},"url":"/enigma-bbs/modding/file-base-web-download-manager.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"File Base Web Download Manager","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/file-transfer-protocol-select.html b/modding/file-transfer-protocol-select.html index f4fb7889..3c0c8027 100644 --- a/modding/file-transfer-protocol-select.html +++ b/modding/file-transfer-protocol-select.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The Rumorz Module The built in file_transfer_protocol_select module provides a way to select a legacy file transfer protocol (X/Y/Z-Modem, etc.) for upload/downloads.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/file-transfer-protocol-select.html"},"url":"/enigma-bbs/modding/file-transfer-protocol-select.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"File Transfer Protocol Select","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/last-callers.html b/modding/last-callers.html index a3406cb1..38bef848 100644 --- a/modding/last-callers.html +++ b/modding/last-callers.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"The Last Callers Module The built in last_callers module provides flexible retro last callers mod.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/last-callers.html"},"url":"/enigma-bbs/modding/last-callers.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Last Callers","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/local-doors.html b/modding/local-doors.html index 51540d98..9a1365b0 100644 --- a/modding/local-doors.html +++ b/modding/local-doors.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Local Doors ENiGMA½ has many ways to add doors to your system. In addition to the many built in door server modules, local doors are of course also supported using the ! The abracadabra module!","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/local-doors.html"},"url":"/enigma-bbs/modding/local-doors.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Local Doors","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} diff --git a/modding/menu-modules.html b/modding/menu-modules.html index a3c59494..76e2e2c9 100644 --- a/modding/menu-modules.html +++ b/modding/menu-modules.html @@ -17,11 +17,11 @@ - + +{"datePublished":"2022-10-01T17:44:20+00:00","description":"Menu Modules From initial connection to the screens and mods your users interact with, the entire experience is made up of menu entries — And all menu entries found within menu.hjson are backed by Menu Modules. For basic menus, a standard handler is implemented requiring no code. However, if you would like to create a menu that has custom handling, you will very likely be inheriting from from MenuModule. More on this below.","mainEntityOfPage":{"@type":"WebPage","@id":"/enigma-bbs/modding/menu-modules.html"},"url":"/enigma-bbs/modding/menu-modules.html","@type":"BlogPosting","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/enigma-bbs/assets/images/enigma-logo.png"}},"headline":"Menu Modules","dateModified":"2022-10-01T17:44:20+00:00","@context":"https://schema.org"} @@ -2449,6 +2449,17 @@
Methods indicated above with ()
in their name such as enter()
are overridable when inheriting form MenuModule
.
enter()
is the first to be called. There is no callback. The default implementation is to simply call this.initSequence()
.displayQueuedInterruptions(callback)
is called, and if interruptions are allowed for this menu, any that may be queued will be displayed first.beforeArt(callback)
is called before any art is displayed. The default implementation will set emulated baud rate, and clear the screen if either are requested by the menu’s config
block.mciReady(mciData, callback)
is called when art is loaded and MCI codes are initialized. The default implementation of a custom MenuModule
simply continues. See also standardMCIReadyHandler.Many helper methods exist and are available to code inheriting from MenuModule
. Below are some examples. Poke around at menu_module.js to discover more!
promptForInput()
standardMCIReadyHandler()
: This is a standard and commonly used mciReady()
implementation:
standardMCIReadyHandler(mciData, callback)
:This is a standard and commonly used mciReady()
implementation:
mciReady(mciData, cb) {
return this.standardMCIReadyHandler(mciData, cb);
@@ -2535,7 +2548,11 @@
Most mods will also derive from MenuModule
. Some things to be aware of:
- Custom mods that bring in their own dependencies must also include their own
package.json
and other Node requirements
- - Be sure to use
packageName
and getModDatabasePath()
for any peristence needs.
+ - Be sure to use
packageName
and getModDatabasePath()
for any (database) peristence needs.
+ - Custom mods in
mods/the_mod_name/
and the MenuModule
entry point must be within a file of the same name: mods/the_mod_name/the_mod_name.js
+
+ - To import ENiGMA modules
require()
from ../../core/
+