Note
While we continue to support Mastodon 4.3 and release patches for it, please note that Mastodon 4.5 is available with new features, changes and fixes. We encourage administrators to update to the latest 4.5 version when they can.
Changelog
Security
- Fix missing limits on various federated properties GHSA-gg8q-rcg7-p79g
- Fix remote user suspension bypass GHSA-5h2f-wg8j-xqwp
- Fix missing length limits on some user-provided fields GHSA-6x3w-9g92-gvf3
- Fix missing access check for push notification settings update GHSA-f3q8-7vw3-69v4
Fixed
- Fix
FeedManager#filter_from_homeerror when handling a reblog of a deleted status (#37486 by @ClearlyClaire) - Fix needlessly complicated SQL query in status batch removal (#37469 by @ClearlyClaire)
- Fix
Varyparsing in cache control enforcement (#37426 by @MegaManSec) - Fix thread-unsafe ActivityPub activity dispatch (#37423 by @MegaManSec)
- Fix SignatureParser accepting duplicate parameters in HTTP Signature header (#37375 by @shleeable)
Upgrade notes
To get the code for v4.3.18, use git fetch && git checkout v4.3.18.
Note
As always, make sure you have backups of the database before performing any upgrades. If you are using docker-compose, this is how a backup command might look: docker exec mastodon_db_1 pg_dump -Fc -U postgres postgres > name_of_the_backup.dump
Dependencies
External dependencies have not changed since v4.3.0, the compatible Ruby, PostgreSQL, Node, Elasticsearch and Redis versions are the same, that is:
- Ruby: 3.1 or newer
- PostgreSQL: 12 or newer. PostgreSQL versions 14.0 to 14.3 are not supported as they contain a critical data-corruption bug (see v4.3.0 release notes)
- Elasticsearch (recommended, for full-text search): 7.x (OpenSearch should also work)
- LibreTranslate (optional, for translations): 1.3.3 or newer
- Redis: 4 or newer
- Node: 18 or newer
- ImageMagick (optional if using libvips): 6.9.7-7 or newer
- libvips (optional, instead of ImageMagick): 8.13 or newer
Update steps
The following instructions are for updating from 4.3.17.
If you are upgrading directly from an earlier release, please carefully read the upgrade notes for the skipped releases as well, as they often require extra steps such as database migrations. In particular, please read the v4.3.0 release notes, as there have been multiple important changes.
Non-docker
Tip
The charlock_holmes gem may fail to build on some systems with recent versions of gcc.
If you run into such an issue, try BUNDLE_BUILD__CHARLOCK_HOLMES="--with-cxxflags=-std=c++17" bundle install.
- Restart all Mastodon processes.
When using docker
- Restart all Mastodon processes.