Go to file
Bryan Ashby 51308a5ad3
Merge branch 'master' of github.com:NuSkooler/enigma-bbs into 459-activitypub-integration
2023-01-16 11:08:11 -07:00
.github Test out code scanning 2022-10-01 18:28:06 +00:00
.husky Added precommit hook and staged checking of linting and formatting 2023-01-13 09:14:00 -06:00
art Add missing WFC help screen 2022-08-04 13:13:37 -06:00
config Door run minutes should not be retroactive 2019-02-10 13:39:27 -07:00
core Merge branch 'master' of github.com:NuSkooler/enigma-bbs into 459-activitypub-integration 2023-01-16 11:08:11 -07:00
docker Update dockerfile to Node 14 2022-05-08 15:56:39 +08:00
docs Merge branch 'master' of github.com:NuSkooler/enigma-bbs into 459-activitypub-integration 2023-01-16 11:08:11 -07:00
gopher Add gopher/README 2020-11-27 01:03:12 -07:00
misc Merge branch 'master' of github.com:NuSkooler/enigma-bbs into 459-activitypub-integration 2023-01-16 11:08:11 -07:00
mods Merge branch 'master' of ssh://numinibsd/git/base/enigma-bbs 2020-06-03 20:53:46 -06:00
util First pass formatting with Prettier 2022-06-05 14:04:25 -06:00
www Additional variables for profile/template 2023-01-01 21:15:43 -07:00
.eslintignore Add .eslintignore, tidy up a bit 2018-06-21 23:35:52 -06:00
.eslintrc.json Added json to list of files to update 2023-01-13 09:23:03 -06:00
.gitattributes Add uppercase extentions, e.g. .ANS 2015-12-12 16:28:40 -07:00
.gitignore Update .gitignore slightly 2019-08-09 23:17:10 -06:00
.lintstagedrc.json Added json to list of files to update 2023-01-13 09:23:03 -06:00
.prettierignore First pass formatting with Prettier 2022-06-05 14:04:25 -06:00
.prettierrc.json First pass formatting with Prettier 2022-06-05 14:04:25 -06:00
CONTRIBUTING.md Additional notes for devs 2023-01-08 13:18:40 -07:00
LICENSE.TXT Update copyrights to 2022 2022-04-05 20:51:03 -06:00
README.md Remove no longer supported CombatNet 2023-01-16 11:04:56 -07:00
TROUBLESHOOTING.md Fix link 2022-08-06 20:48:25 -06:00
UPGRADE.md Bump version to 0.0.14-beta + major web server updates 2022-12-29 00:56:10 -07:00
WHATSNEW.md Merge branch 'master' of github.com:NuSkooler/enigma-bbs into 459-activitypub-integration 2023-01-16 11:08:11 -07:00
main.js First pass formatting with Prettier 2022-06-05 14:04:25 -06:00
mkdocs.yml * Some doc changes 2015-11-20 11:56:57 -07:00
oputil.js * Split out oputil stuff into modules based on <command> 2017-02-15 20:27:16 -07:00
package-lock.json Added json to list of files to update 2023-01-13 09:23:03 -06:00
package.json Added json to list of files to update 2023-01-13 09:23:03 -06:00
yarn.lock Test hook 2023-01-13 09:52:21 -07:00

README.md

ENiGMA½ BBS Software

ENiGMA½ BBS

ENiGMA½ is a modern BBS software with a nostalgic flair!

Features

Below are just some of the features ENiGMA½ supports out of the box:

  • Multi platform — Anywhere Node.js runs likely works (known to work under Linux, FreeBSD, OpenBSD, OS X and Windows)
  • Unlimited multi node support (for all those BBS "callers"!)
  • Highly customizable via HJSON based configuration, menus, and themes in addition to JavaScript based mods
  • MCI support for lightbars, toggles, input areas, and so on plus many other other bells and whistles
  • Telnet, SSH, and both secure and non-secure WebSocket access built in! Additional servers are easy to implement
  • CP437 and UTF-8 output
  • SyncTERM style font and baud emulation support. Display PC/DOS and Amiga style artwork as it's intended! In general, ANSI-BBS / cterm.txt / bansi.txt are followed for expected BBS behavior.
  • Full SAUCE support.
  • Renegade style pipe color codes.
  • SQLite storage of users, message areas, etc.
  • Strong PBKDF2 backed password encryption.
  • Support for 2-Factor Authentication with One-Time-Passwords
  • Door support including common dropfile formats for legacy DOS doors. Built in BBSLink, DoorParty, and Exodus!
  • Structured Bunyan logging!
  • Message networks with FidoNet Type Network (FTN) + BinkleyTerm Style Outbound (BSO) message import/export. Messages Bases can also be exposed via Gopher, or NNTP!
  • Gazelle inspired File Bases including fast fully indexed full text search (FTS), #tags, and HTTP(S) temporary download URLs using a built in web server. Legacy X/Y/Z modem also supported!
  • Upload processor supporting FILE_ID.DIZ and NFO extraction, year estimation, and more!
  • ANSI support in the Full Screen Editor (FSE), file descriptions, etc.
  • Expandable achievement system — BBSing gamified!
  • A remote accessible Waiting For Caller (WFC)!

...and much much more. Please check out the issue tracker and feel free to request features (or contribute!) features!

Documentation

Browse the docs online. Be sure to checkout the /docs/ folder as well for the latest and greatest documentation.

Installation

On most *nix systems simply run the following from your terminal:

curl -o- https://raw.githubusercontent.com/NuSkooler/enigma-bbs/master/misc/install.sh | bash

Please see Installation Methods for Windows, Docker, and so on...

Donating

If you feel the urge to donate, you can do so here

Donate using Liberapay

Support

Terminal Clients

ENiGMA has been tested with many terminals. However, the following are suggested for BBSing:

Some Boards

Special Thanks

(in no particular order)

...and so many others! This project would be nothing without the BBS and artscene communities!

License

Released under the BSD 2-clause license:

Copyright (c) 2015-2022, Bryan D. Ashby All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  • Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  • Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.