All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Fixed code to intentionally break config.json loading, used to test v4.6.1
- Fixed bug with solved puzzle tracking when config.json cannot be loaded.
- Mothd now correctly handles using the current directory for a path.
For instance,
-puzzles .
- Theme configuration has a new structure: old theme config files need to be modified
- Theme now omits the qix animation in the background if the user has configured the browser to reduce motion. This should help people with vestibular motion disorders, or people who are annoyed by the animation.
- Theme colors are now specified with CSS variables, making the theme (hopefully) easier to re-color.
- Theme: brought back integrated Python IDE, with updated versions of CodeJar and Prism.js. These depend on a CDN, but if it cannot be reached, there is a graceful fallback.
- Theme (nearly) instantly updates the list of open puzzles when a puzzle is solved. Users should no longer need to refresh the index after solving a puzzle.
- Theme fires confetti 🎊 when a puzzle is answered correctly. This requires a CDN; if unreachable, everything still works.
- Theme closes the tab a few seconds after a puzzle is answered correctly.
- Answer hashes are now the first 4 characters of the hex-encoded SHA1 digest
- Reworked the built-in theme
- Devel mode no longer accepts an empty team ID
- messages.html moved into theme
- moth.mjs is now the standard MOTH library for ECMAScript
- Exported state now includes "Enabled" boolean
- New
Extra
field on puzzles will allow arbitrary metadata on puzzles.
- CI/CD now builds tags
enabled
file is no longer usedhours.txt
parsing logs more verbosely- Participant IDs are no longer used anywhere
- A few changes to CI/CD test reporting
- Added a performance optimization for events with a large number of teams backed by NFS
- You can now join with a team ID not appearing in
teamids.txt
, as long as it is registered (in theteams/
directory)
- Initializing an instance now truncates
events.csv
- State is now cached in memory, in an attempt to reduce filesystem metadata operations, which kill NFS.
- Images deploying to docker hub too. We're now at capacity for our Docker Hub team.
- Trying to get CI push of built images. I expect this to fail, too. But in a way that can help me debug the issue.
- Points awarded while scoring is paused are now correctly sorted (#168)
- Writing a new mothball with the same name is now detected and the new mothball loaded (#172)
- Regression test for issue where URL path leading directories were ignored (#144)
- A few other very minor bugs were closed when I couldn't reproduce them or decided they weren't actually bugs.
- Many error messages were changed to start with a lower-case letter, in order to satisfy a new linter check.
- CI/CD moved to our Cyber Fire Gitlab instance
- I attempted to have the build thingy automatically build moth:v4 and moth:v4.3 and moth:v4.3.3 images, but I can't test it without tagging a release. So v4.3.4 might come out very soon after this ;)
debug.notes
front matter field
- Transpiled KSAs no longer dropped
- example/5/draggable.js fix for FireFox to prevent dropping a draggable trying to load a URL
transpile
arguments now work the same way for the transpile binary as they do for mkpuzzletranspile inventory
does what you expect: inventory of current category, not inventory of all categories
- No longer building a
moth-devel
image, this is now handled by the moth-devel repository.
transpile
will now runmkcategory
andmkpuzzle
when invoked without-dir
- ppc64le and i386 builds of github, because ppc64le keep failing mysteriously, and we don't need them anyhow.
transpile
now has amarkdown
command, so you can use the "stock" markdown formatter
- event.log is now events.csv, to make it easier to import to a spreadsheet
- When in devel mode, any team ID may score points. This allows more interaction with the state directory.
- When in devel mode, any team ID may be registered.
It still works the same way if you register a team in
teamids.txt
, but now you can use anything and it will put you on an already existing team named<devel:$ID>
. - switched from
blackfriday
togoldmark
, to support CommonMark puzzle.json
no longer hasPre
andPost
sections
- JavaScript code we didn't write is now pulled from a CDN
- Build multiarch Docker images
- Stop building devel server from this codebase; this is moving to a new repo
- Clear Debug.summary field when making mothballs
- Regulated category/puzzle provider API: now everything returns a JSON dictionary (or octet stream for files)
- More log events
- Log channels document
- More detailed API documntation
- Transpiler warning if
mkpuzzle
exists but is not executable
- Multiple bugs preventing production server from working properly
- CI builds should be working now
- Team registration now correctly writes names to files
- Anonymized team names now only computed once per team
- Don't output "self" team for unauthenticated state exports
- Documented the HTTP API
- Added a drawing of how things fit together
- Major rewrite/refactor of
mothd
- Clear separation of roles: State, Puzzles, and Theme
- Sqlite, Redis, or S3 should fit in easily now
- Will allow "dynamic" puzzles now, we just need a flag to enable it
- Server no longer provides unlocked content
- Puzzle URLs are now just
/content/${cat}/${points}/
- Puzzle URLs are now just
- Changes to
state
directory- Most files now have a bit of (English) documentation at the beginning
state/until
is nowstate/hours
and can specify multiple begin/end hoursstate/disabled
is nowstate/enabled
- Clear separation of roles: State, Puzzles, and Theme
- Mothball structure has changed
- Mothballs no longer contain
map.txt
- Mothballs no longer obfuscate content paths
- Clients now expect unlocked puzzles to just be
map[string][]int
- Mothballs no longer contain
- New
/state
API endpoint- Provides all server state: event log, team mapping, messages, configuration
- New
transpile
CLI command- Provides
mothball
action to create mothballs - Lets you test a few development server things, if you want
- Provides
- Development server is gone now; use
mothd
directly with a flag to transpile on the fly
- Support insta-checking for legacy puzzles
- We are now using SHA256 instead of djb2hash
- URL parameter to points.json to allow returning only the JSON for a single team by its team id (e.g., points.json?id=abc123).
- A CONTRIBUTING.md to describe expectations when contributing to MOTH
- Include basic metadata in mothballs
- add_script_stream convenience function allows easy script addition to puzzle
- Autobuild Docker images to test buildability
- Extract and use X-Forwarded-For headers in mothd logging
- Mothballs can now specify
X-Answer-Pattern
header fields, which allow*
at the beginning, end, or both, of an answer. This isX-
because we are hoping to change how this works in the future.
- Handle cases where non-legacy puzzles don't have an
author
attribute - Handle YAML-formatted file and script lists as expected
- YAML-formatted example puzzle actually works as expected
- points.log will now always be sorted chronologically
- Made top-scoring teams full-width
- Issue with multiple answers in devel server and YAML-format .moth
- Scoreboard was double-counting points
- A changelog
- Support for embedding Python libraries at the category or puzzle level
- Minimal PWA support to permit caching of currently-unlocked content
- Embedded graph in scoreboard
- Optional tracking of participant IDs
- New
notices.html
file for sending broadcast messages to players
- Use native JS URL objects instead of wrangling everything by hand