Versia Server 0.8.0
is fully backwards compatible with 0.7.0
.
- Outbound federation, inbox processing and data fetching are now handled by a queue system (like most federated software).
- Added an administration UI for managing the queue.
- Media processing is now also handled by a queue system.
- Added Push Notifications support.
- Upgraded Bun to
1.2.2
. - Implemented support for the Instance Messaging Extension
- Implement Shared Inboxes support.
- Allowed
<div>
and<span>
tags in Markdown. - Added
--password
flag to the user creation CLI. - Overhaul Roles API to allow for full role control (create, update, delete, assign).
[notifications]
[notifications.push]
# Whether to enable push notifications
enabled = true
[notifications.push.vapid]
# VAPID keys for push notifications
# Run Versia Server with those values missing to generate new keys
public = ""
private = ""
# Optional
# subject = "mailto:[email protected]"
[queues]
# Controls the delivery queue (for outbound federation)
[queues.delivery]
# Time in seconds to remove completed jobs
remove_on_complete = 31536000
# Time in seconds to remove failed jobs
remove_on_failure = 31536000
# Controls the inbox processing queue (for inbound federation)
[queues.inbox]
# Time in seconds to remove completed jobs
remove_on_complete = 31536000
# Time in seconds to remove failed jobs
remove_on_failure = 31536000
# Controls the fetch queue (for remote data refreshes)
[queues.fetch]
# Time in seconds to remove completed jobs
remove_on_complete = 31536000
# Time in seconds to remove failed jobs
remove_on_failure = 31536000
# Controls the push queue (for push notification delivery)
[queues.push]
# Time in seconds to remove completed jobs
remove_on_complete = 31536000
# Time in seconds to remove failed jobs
remove_on_failure = 31536000
# Controls the media queue (for media processing)
[queues.media]
# Time in seconds to remove completed jobs
remove_on_complete = 31536000
# Time in seconds to remove failed jobs
remove_on_failure = 31536000
[validation]
max_emoji_size = 1000000
max_emoji_shortcode_size = 100
max_emoji_description_size = 1000
- The
enabled
field inredis.queue
has been removed. This field was never functional in the first place, as Redis is required for federation.
- Correctly proxy all URIs in custom Markdown text.
- Fixed several issues with the ActivityPub Federation Bridge preventing it from operating properly.
- Fixed incorrect content-type on some media when using S3.
- All media content-type is now correctly fetched, instead of guessed from the file extension.
- Added missing attributes to
/api/v1/instance
(some clients were expecting them).
Warning
This release marks the rename of the project from Lysand
to Versia
.
Versia Server 0.7.0
is backwards compatible with 0.6.0
. However, some new features may not be available to older clients. Notably, versia-fe
has had major improvements and will not work with 0.6.0
.
- Upgraded Bun to
1.1.34
. This brings performance upgrades and better stability. - Added support for the ActivityPub Federation Bridge.
- Added support for the Sonic search indexer.
- Note deletions are now federated.
- Note edits are now federated.
- Added support for Sentry.
- Added option for more federation debug logging.
- Added Roles API.
- Added Permissions API and enabled it for every route.
- Added TOS and Privacy Policy endpoints.
- Added Challenge API. (basically CAPTCHAS). This can be enabled/disabled by administrators. No
versia-fe
support yet. - Added ability to refetch user data from remote instances.
- Added ability to change the
username
of a user. (Mastodon API extension). - Added an endpoint to get a user by its username.
- Add OpenID Connect registration support. Admins can now disable username/password registration entirely and still allow users to sign up via OpenID Connect.
- Add option to never convert vector images to a raster format.
- Refactor logging system to be more robust and easier to use. Log files are now automatically rotated.
- Add support for HTTP proxies.
- Add support for serving Versia over a Tor hidden service.
- Add global server error handler, to properly return 500 error messages to clients.
- Sign all federation HTTP requests.
- Add JSON schema for configuration file.
- Rewrite federation stack
- Updated federation to Versia 0.4
- Implement OAuth2 token revocation
- Add new Plugin API
A new plugin system for extending Versia Server has been added in this release!
Note
This is an internal feature and is not documented. Support for third-party plugins will be given on a "if we have time" basis, until the API is fully stabilized and documented
Plugins using this framework support:
- Plugin hotswapping and hotreloading
- Manifest files (JSON, JSON5, JSONC supported) with metadata (JSON schema provided)
- Installation by dropping a folder into the plugins/ directory
- Support for plugins having their own NPM dependencies
- Support for storing plugins' configuration in the main config.toml (single source of truth)
- Schema-based strict config validation (plugins can specify their own schemas)
- Full type-safety
- Custom hooks
- FFI compatibility (with
bun:ffi
or Node's FFI) - Custom API route registration or overriding or middlewaring
- Automatic OpenAPI schema generation for all installed plugins
- End-to-end and unit testing supported
- Automatic user input validation for API routes with schemas (specify a schema for the route and the server will take care of validating everything)
- Access to internal database abstractions
- Support for sending raw SQL to database (type-safe!)
- Plugin autoload on startup with override controls (enable/disable)
As a demonstration of the power of this system and an effort to modularize the codebase further, OpenID functionality has been moved to a plugin. This plugin is required for login.
- Fix favouriting/unfavouriting sometimes returning negative counts.
- Non-images will now properly be uploaded to object storage.
- Make account searches case-insensitive
- Fix image decoding error when passing media through proxy.
- OpenID Connect now correctly remembers and passes
state
parameter. - OpenID Connect will not reject some correct but weird redirect URIs.
- Markdown posts will not have invisible anchor tags anymore (this messed up accessibility).
- Reverse proxies incorrectly reporting an HTTPS request as HTTP will now be handled correctly during OpenID Connect flows.
- API Relationships will now correctly return
requested_by
. - Make process wait for Ctrl+C to exit on error, instead of exiting immediately. This fixes some issues with Docker restarting endlessly.
- Animated media will now stay animated when uploaded.
- Some instance metadata will no longer be missing from
/api/v2/instabnce
endpoint. In fact, it will now be more complete than Mastodon's implementation. - The Origin HTTP header will no longer be used to determine the origin of a request. This was a security issue.
- New notes will no longer incorrectly be federated to all remote users at once.
- Fix Elk Client not being able to log in.
- Remove old logging system, to be replaced by a new one.
- Removed Meilisearch support, in favor of Sonic. Follow instructions in the installation guide to set up Sonic.
- Removed explicit Glitch-FE support. Glitch-FE will still work, but must be hosted separately like any other frontend.
- Remove Node.js from Docker build.
- Update all dependencies.