v0.21
Welcome, one and all! It's time for Pepperminty Wiki v0.21! πππ In ~5 months and 24 days, 138 commits and 3 hotfixes(!) have been made to bring you v0.21 - with lots of new features to check out. This is another huge release. Check out the feature summary:
- π Watchlists: Get an email when a page is updated (assuming you have email setup in your PHP installation)
- π± Improved mobile support: There's still a ways to go, but it's much better than it was. Open an issue if you've got any suggestions for improvement, no matter how small
- π· Autocomplete tags: Tags now autocomplete when editing pages
- π A command-line interface: Pepperminty Wiki now has a command-line interface, where you can do things like update the search index. Check out the docs for more info
- π₯ Added markdown support to media captions: Fancy media captions are now at your fingertips! Just add markdown to the alt portion of the image tag (#184)
Lots of other gems can be found in the full changelog below, so take a look :D
Also, Pepperminty Wiki now has a website! I built it with Eleventy.
A few things to note for admins:
- The CLI will never be required to do things. Its goal is to provide an alternative interface (particularly for larger wikis and those who want to automate stuff via shell scripting).
- A working PHP email setup is required for the watchlist to work
- A new button has been added to the
nav_links_extra
mega menu. You'll need to delete thenav_links_extra
entry from yourpeppermint.json
in order for this to show up. - Search index performance has been improved. Again :D This requires regenerating the search index after updating.
- Email address verification: Enabled by default. Users will now need to verify their email addresses. An easy fix is to edit your profile re-enter your email address to receive the verification email
Wow, that's a lot! The full changelog can be found below as usual. Before I end this message though, I just want to ask:
Please help test this release.
I mean it. This release comes with a number of huge fundamental changes (large and small), some of which are incremental in a series across the last few releases. Particularly of note is the command-line interface - that required massive backend changes.
Help would be really appreciated to find issues before the big main stable release in about a week's time (unless issues are found). While hotfixes are fun, I'd prefer to keep them to a minimum :P
Even if you just want to share an "implementation report" (a short summary of your experience upgrading), I'd really appreciate the feedback :-)
--Starbeamrainbowlabs
Have you updated to this release? Click this link to say hi!
Updating
You can update to this release simply by grabbing an updated copy of index.php
and replacing the version in your current wiki (don't forget to take backups! I make every effort to squash as many bugs as possible, but you can never be too certain). You can get an updated copy of index.php
in a number of ways:
- By downloading the
index.php
file attached to this release - Using the online downloader (always has the latest stable version)
- Using the online downloader offline
- Building your own from source
For more information on the last 2 methods, please see the documentation for more information.
Since v0.21-beta1
Fixed
- Make
PEPPERMINT_THEME
environment variable work again when compiling on the command line - Fixed invalid HTML that was causing layout issues on the master settings page
Since v0.20.4-hotfix4
Added
- Watchlists! A new addition has been added to the more menu to add the current page to your personal watchlist
- An email will be sent to all users watching a page when an edit is saved to it (uses the PHP
mail()
function internally, via theemail_user()
internal Pepperminty Wiki utility function)
- An email will be sent to all users watching a page when an edit is saved to it (uses the PHP
- Email address verification
- Enabled by default. In order to receive emails users now need to verify their email address
- This is done via a verification email that's sent when you change your email address (even if your email address is the same when you change your preferences and you haven't yet verified it)
- A new
email_verify_addresses
setting has been added to control the functionality
- Added dark theme to the downloader (will be updated at the next stable release)
- Added initial mobile theme support to the default theme
- There's still a bunch of work to do in this department, but it's a bit of a challenge to do so without breaking desktop support
- Added autocomplete for tags when editing pages, powered by Awesomplete
- The new
editing_tags_autocomplete
setting - enabled by default - toggles it, but why would you want to turn it off? :P - It should be reasonably accessible, judging from all the aria tags I'm seeing
- Get in touch if you experience performance issues with fetching tag lists from your wiki
- The new
- A command-line interface!
- Wiki administrators with terminal/console access can now make use of a brand-new CLI by executing
php ./index.php
(warning: strange things will happen if the current working directory is not the directory that contains index.php and peppermint.json)
- Wiki administrators with terminal/console access can now make use of a brand-new CLI by executing
- Added new
anoncomments
setting to control whether anonymous users are allowed to make comments (disabled by default) - thanks to @SeanFromIT for suggesting it in #181 - Added markdown support for media captions (#184)
- Finally: Experimental didyoumean support. Ever made a typo in a search query? The new didyoumean engine can correct query terms that are up to 2 characters out!
- It's disabled by default (check out the new
search_didyoumean_enabled
setting), as it enabling it comes with a significant performance impact when typos are corrected (~0.8s-ish / typo is currently observed) - Uses the words in the search index as a base for corrections (so if you have a typo on a page, then it will correct it to the typo)
- The index does not currently update when you edit a page - this feature is still very experimental (please report any issues)
- A typo is a search query term that is both not a stop word and not found in the search index
- It's disabled by default (check out the new
Fixed
-
Fixed weighted word support on search query analysis debug page
-
Added missing apostrophes to stop words in search system. Regenerating your search index will now yield a slightly smaller index
-
Fixed link loop when logging in for crawlers
-
[security] Bugfix: Don't leak the PHP version in emails when expose_php is turned off
-
Fixed handling of Unicode characters when emailing users - added new
email_subject_utf8
andemail_body_utf8
settings to control the new behaviour -
Add new
email_debug_dontsend
setting for debugging emails sent by Pepperminty Wiki -
Fixed pressing alt + enter to open a search in a new tab - it should no longer fail and briefly prompt to allow pop-ups
-
Squashed a bug in the new upgraded get/set_array_simple search optimisation
-
Updated Parsedown to squash warning in PHP 7.4+
-
Trailing commas in the tags box will no longer result in empty tags being added to pages.
-
Minor UI fixes
- Multiple tags in search results and on page lists now have a margin between them
-
Newline characters (
\r
and\n
) are now replaced with spaces in internal links (#186, thanks @SeanFromIT!) -
Inbuilt help documentation corrections (#185, thanks @SeanFromIT!)
-
Fixed a warning message when a file fails to upload (thanks for the test file, @SeanFromIT)
-
Really fix the dot problem from v0.20.3-hotfix3 that @SeanFromIT reported
-
Make
PEPPERMINT_THEME
environment variable work again when compiling on the command line -
Fixed invalid HTML that was causing layout issues on the master settings page
Changed
- Improved the search indexing system performance - again
- Another search index rebuild is required
- Optimisation: Don't generate the list of pages for the datalist if it isn't going to be displayed (especially noticeable on wikis with lots of pages)
- Optimisation: Don't load the statistics index if it's not needed (also esp. noticeable on wikis with lots of pages)
- Optimisation: Refactor
stas_split()
to be faster (informal testing shows ~18% faster β 4% total time) - [Module Api] Optimisation: Remove
search::transliterate
because it has a huge overhead. Usesearch::$literator->transliterate()
instead. - [Module Api] Add new
absolute
andhtml
optional boolean arguments torender_timestamp()
- [Module Api]
search::extract_context()
andsearch::highlight_context()
now take in a parsed query (withsearch::stas_parse()
), not a raw string
Known bugs
- Wow, a new section! Haven't seen one of these before. Hopefully we don't see it too often.....
- The didyoumean search query typo correction engine does not currently update it's index when you save an edit to a page (the typo correction engine is still under development).