matrix.org/content/blog/2023/05/2023-05-26-this-week-in-mat...

223 lines
16 KiB
Markdown
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

+++
title = "This Week in Matrix 2023-05-26"
date = "2023-05-26T20:49:36Z"
updated = "2023-05-26T20:24:34Z"
path = "/blog/2023/05/26/this-week-in-matrix-2023-05-26"
[taxonomies]
author = ["Hubert Chathi"]
category = ["This Week in Matrix"]
+++
### Matrix Spec ([website](https://spec.matrix.org/))
[uhoreg](https://matrix.to/#/@hubert:uhoreg.ca) announces
> Here's your weekly spec update! The heart of Matrix is the specification - and this is modified by Matrix Spec Change (MSC) proposals. Learn more about how the process works at https://spec.matrix.org/proposals.
>
> ## MSC Status
>
> **New MSCs:**
>
> * [MSC4020: Room model configuration](https://github.com/matrix-org/matrix-spec-proposals/pull/4020)
> * [MSC4019: Encrypted event relationships](https://github.com/matrix-org/matrix-spec-proposals/pull/4019)
> * [MSC4018: Reliable call membership](https://github.com/matrix-org/matrix-spec-proposals/pull/4018)
>
> **MSCs in Final Comment Period:**
>
> * _No MSCs are in FCP._
>
> **Accepted MSCs:**
>
> * _No MSCs were accepted this week._
>
> **Closed MSCs:**
>
> * [WIP: MSC3588: Encrypted Stories As Rooms](https://github.com/matrix-org/matrix-spec-proposals/pull/3588)
>
> ## Spec Updates
>
> We released version 1.7 of the Matrix Spec on Thursday. This release features media repository improvements and reactions. Thank you to all who contributed to this release, whether through writing or reviewing MSCs, writing spec PRs, or finding spec bugs. And congratulations to those who had their first MSC make it to the release. Read the [blog post](https://matrix.org/blog/2023/05/25/matrix-v-1-7-release) for the full details.
>
> We're in the process of working out what Matrix 1.8 looks like and need to hear what people are working on. If you have an MSC or idea you're planning on looking at in the next 2 months, let us know in #sct-office:matrix.org so we can prioritize it accordingly.
>
> ## Random MSC of the Week
>
> The random MSC of the week is... [MSC3184: Challenges Messages](https://github.com/matrix-org/matrix-spec-proposals/pull/3184)! This feature allows participants in a room to make decisions randomly by playing rock, paper, scissors; flipping a coin; or drawing straws.
<!-- more -->
## Dept of Servers 🏢
### Synapse ([website](https://github.com/matrix-org/synapse/))
Synapse is a Matrix homeserver implementation developed by the matrix.org core team
[dmr](https://matrix.to/#/@dmrobertson:matrix.org) announces
> Happy Friday, everyone. This week we disclosed three security advisories for Synapse. The TL;DR is that you should upgrade to at least Synapse 1.74.0 or newer. Please see [the Matrix.org blogpost](https://matrix.org/blog/2023/05/24/disclosing-synapse-security-advisories) for links to the advisories.
>
> Also of note is the release of [Synapse 1.84.0](https://github.com/matrix-org/synapse/releases/tag/v1.84.0) this Tuesday. New in this release is
>
> * an option to [prevent downloading media from specified domains](https://github.com/matrix-org/synapse/issues/15197);
> * a new set of [redis TLS configuration options](https://github.com/matrix-org/synapse/issues/15312) (Roel ter Maat); and
> * addition support for [new](https://github.com/matrix-org/matrix-spec-proposals/pull/4009) and [stabilised](https://github.com/matrix-org/matrix-spec-proposals/pull/2659) MSCs.
>
> Alongside this are a batch of bugfixes and internal improvements. We are aware of one regression in v1.84.0—expect a minor release with a fix to that sooner rather than later.
>
> We've also begun an effort to profile and improve the performance of the `/messages` endpoint. That should benefit everyone, but in particular we hope to improve the UX of the [Matrix Public Archive](https://archive.matrix.org/).
>
> Thank you as ever to our contributors, testers, and [community of server operators](https://matrix.to/#/#synapse:matrix.org).
## Dept of Clients 📱
### Nheko ([website](https://nheko-reborn.github.io))
Desktop client for Matrix using Qt and C++17.
[Nico](https://matrix.to/#/@deepbluev7:neko.dev) announces
> Hey, it's been a while. Which means we were busy, just not with developing Nheko! However, we did do some stuff now:
>
> * The sticker and emoji pickers now have sections and include both normal emojis and custom emojis in the emoji picker. This means your search results are also sectioned and you don't need to use ~ for custom emoji anymore. You can also now edit your custom emoji right from the picker (or rather open the settings menu from there). This should make going crazy with custom emoji much easier and I hope you have fun with it!
> * LorenDB also finally fixed that pressing a key would focus the input bar but eat the first key. This was pretty annoying, but it should now behave much nicer!
> * Sateallia meanwhile fixed a similar bug with the focus in the search menu on some platforms, implemented selecting multiple files to upload in the filepicker (before you only could drop a group of files into Nheko at once).
> * You can now copy images from the image viewer to the clipboard.
> * And lastly your rooms in the search are now ordered by recency of the last message. This should make rooms with the same name have always the right room appear on top. Additionally upgraded rooms are now in italics, which should make it still possible to jump to them, but also distinguish them in the search.
>
> Have a nice day and try custom stickers and emojis some time!
> ![](/blog/img/RpqJFQcQQnJkgifVovNDhxBI.png)
### Neochat ([website](https://invent.kde.org/network/neochat))
A client for matrix, the decentralized communication protocol
[Tobias Fella](https://matrix.to/#/@tobiasfella:kde.org) announces
> Here's what's happened in NeoChat in the last weeks:
>
> * I (Tobias) implemented support for sending stickers, based on MSC2545. You can now send them from the emoji picker, which has also been improved visually.
> * I also implemented support for editing your account's stickers in NeoChat's settings. Other parts of the MSC (room stickers, etc.) are coming soon.
> * James improved read markers and state changed, limiting the number of the that are shown at the same time.
> * Aleix and I improved the notifications by grouping multiple messages from the same room into a single notification.
> * James added caching for the last event in a room, meaning that on startup, NeoChat will now sort all rooms in a correct order.
> * We fixed a bug where the user/room/emoji completion menu randomly did not open.
> * James finished documenting all of NeoChat's codebase.
> * I improved NeoChat's space support by replacing the existing space view with a new sidebar in style similar to many other clients.
> * I also improved logging, which will hopefully help us debug many problems, especially around encryption issues. In the future, if you notice such problems, make a copy of `~/.local/share/KDE/neochat.log` (on Linux; for other platforms, talk to us to figure out where the log file is) and possible also `neochat.log.old` immediately, to help with debugging.
> * Rooms with only two users (i.e., DMs) will now show a more useful sidebar, omitting irrelevant details like the normal room member list.
> * James also improved NeoChat's developer tools, now showing more useful information.
### FluffyChat ([website](https://fluffychat.im))
[Krille-chan](https://matrix.to/#/@krille:janian.de) reports
> 📢 This Week in FluffyChat 🐾
>
> Fixed memory leak and addressed minor bugs.
> Made progress on new HTML rendering logic for upcoming release.
> Translated FluffyChat into Chinese (Simplified), Croatian, Estonian, Galician, Indonesian, Romanian, Spanish, and Ukrainian.
> Updated dependencies and improved features:
> Updated file_picker to 5.3.0.
> Added storage persistence request on web.
> Optimized member retrieval in public rooms.
> Stay tuned for the new and improved FluffyChat! 🐱💬
### Ement.el ([website](https://github.com/alphapapa/ement.el))
Matrix client for Emacs
[alphapapa](https://matrix.to/#/@alphapapa:matrix.org) announces
> [Ement.el](https://github.com/alphapapa/ement.el), a Matrix client for the [GNU Emacs](https://www.gnu.org/software/emacs/) Lisp machine and text editor, was graciously feature by David Wilson in his weekly [System Crafters stream](https://www.youtube.com/watch?v=KCmlupc9z34). He thoroughly demo'ed Ement's powerful, unique features, giving a great introduction to new users, and showing the power of Emacs in general. Check it out!
### Element Web/Desktop ([website](https://github.com/vector-im/element-web))
Secure and independent communication, connected via Matrix. Come talk with us in [#element-web:matrix.org](https://matrix.to/#/#element-web:matrix.org)!
[Danielle](https://matrix.to/#/@daniellekirkwood:one.ems.host) announces
> Here at Element web our week has been focused on notifications!
>
> * In our journey to rid the ele-web-world of stuck notifications weve fixed several bugs. Unfortunately fixing these bugs has surfaced other existing bugs that make the experience worse :sob:
> - Were hard at work on all these items, keeping the original fixes and introducing new fixes.
> * While that means were skipping the public release this week, it does also mean that well have made some significant improvement in our next version!
> * Also on the topic of notifications were adding the final touches to our new notifications settings screens, ensuring that the push rules and toggles match up as youd expect.
> * Next week were **hosting a community testing session for our Intentional Mentions MSC**. The MSC aims to remove the unnecessary pings when people use your username in the timeline but do not tag you explicitly.
> - **Join us next Wednesday, 31 may 2023 from 7:00am PST to 8:30am PST (3:00pm - 4:30pm BST)**
> - Before joining the call, please complete the [consent form](https://forms.gle/fsfQusuhWNZFhQvq5)
> - For questions use the matrix room: [#element-community-testing:matrix.org](https://matrix.to/#/#element-community-testing:matrix.org)
### Element X iOS
The next generation of Element on iOS.
[Ștefan](https://matrix.to/#/@stefan.ceriu:matrix.org) says
> Were waving bye bye to another fun week in ElementX land. We kept ourselves entertained by:
>
> * [Redesigning the delivery status](https://github.com/vector-im/element-x-ios/pull/931)
> * Fixing bugs [here](https://github.com/vector-im/element-x-ios/pull/936) and [there](https://github.com/vector-im/element-x-ios/pull/940) and [everywhere](https://github.com/vector-im/element-x-ios/pull/945)
> * [Adding the longed for bubble timestamps](https://github.com/vector-im/element-x-ios/pull/947)
> * and chasing down bugs, crashes and other cool maintenance task that have been on the burner for some time
## Dept of Non Chat Clients 🎛️
### Circles ([website](https://circu.li/circles.html))
E2E encrypted social networking built on Matrix. Safe, private sharing for your friends, family, and community.
[cvwright](https://matrix.to/#/@cvwright:matrix.org) reports
> [Circles](https://circu.li/circles.html) is an E2E encrypted social network app built on Matrix.
>
> This week we are happy to announce a new beta build of Circles for Android. New in v1.0.11:
>
> * Major compatibility fixes for cross-signing
> * Improved support for UnifiedPush
> * Use of Matrix threads for replies to top-level posts
> * Bug fixes to enable switching accounts without logging out
>
> The latest build is available in [our F-Droid beta repo](https://circu.li/fdroid/repo/) and in the [Google Play Store](https://play.google.com/store/apps/details?id=org.futo.circles). And for those who like to DIY, you can always grab the [APK](https://circu.li/fdroid/repo/app-fdroid-release-1_0_11.apk) directly and install it yourself.
>
> Also new for this release is a [GitHub mirror](https://github.com/futo-org/circles-android) of the Circles Android source repo, for easier bug reporting.
## Dept of SDKs and Frameworks 🧰
### matrix-rust-sdk ([website](https://github.com/matrix-org/matrix-rust-sdk))
Next-gen crypto-included SDK for developing Clients, Bots and Appservices; written in Rust with bindings for Node, Swift and WASM
[Ivan 🦀](https://matrix.to/#/@mnt_io:matrix.org) reports
> This week, new projects have started!
>
> * A new crate has been created, `matrix-sdk-ui`, which is [the new home for the UI API](https://github.com/matrix-org/matrix-rust-sdk/pull/1931) the Matrix SDK provides, like `Timeline`, and `RoomList`. Developing this kind of UI API inside the Matrix SDK instead of the client side (e.g. ElementX iOS or Android or even Gnome Fractal) means it improves testability and quality greatly, as we can tweak the network layer more easily, and in depth. It also means that it boosts the productivity of developers that create new Matrix clients: no need to deal with synchronisation, room presentation, timeline, pagination etc., everything is managed automatically.
> * `RoomList` is a layer on top of `SlidingSync`. The work has started, and [the progress can be tracked in this meta issue](https://github.com/matrix-org/matrix-rust-sdk/issues/1911). To make it real, some improvements were necessary on the `SlidingSync` side, esp. being able [to change the sync-mode of an existing `SlidingSyncList`](https://github.com/matrix-org/matrix-rust-sdk/pull/1942), which led to [a nice revamping of the ranges API](https://github.com/matrix-org/matrix-rust-sdk/pull/1955). We are not mentioning many small clean ups ([1](https://github.com/matrix-org/matrix-rust-sdk/pull/1950), [2](https://github.com/matrix-org/matrix-rust-sdk/pull/1947), [3](https://github.com/matrix-org/matrix-rust-sdk/pull/1919), [4](https://github.com/matrix-org/matrix-rust-sdk/pull/1963) and so on).
> * Work has started to support [Sliding Sync sticky parameters properly](https://github.com/matrix-org/matrix-rust-sdk/pull/1948),
> * [Ruma has been upgraded](https://github.com/matrix-org/matrix-rust-sdk/pull/1975), notably to support the latest Matrix 1.7 features.
> * In the Crypto land:
> * [User/device pairs who have invalid one-time keys are now timed out](https://github.com/matrix-org/matrix-rust-sdk/pull/1970),
> * [`VerificationRequest` has a new state when a request transitions](https://github.com/matrix-org/matrix-rust-sdk/pull/1939). `VerificationRequest` is used to control the flow of the verification but only up to a certain point. Once different specific verification flows are handled (i.e. SAS or QR Code), the `VerificationRequest` object creates a child object of the `Verification` type. The idea behind this patch is to add a new `VerificationRequestState` variant called `Transitioned` which holds the child verification object as associated data. This makes it much simpler to go through the whole verification flow by allowing users to just listen to the `VerificationRequest::changes()` method,
> * [The return of OTK fetching failures](https://github.com/matrix-org/matrix-rust-sdk/issues/281),
> * [Replace the `libolm` backup encryption code with a native Rust version](https://github.com/matrix-org/matrix-rust-sdk/pull/1944), which allow Wasm targets to use the `backups_v1` feature of `matrix-sdk-crypto`,
> * [Disable automatic-key-forwarding for the `matrix-sdk-ffi` bindings](https://github.com/matrix-org/matrix-rust-sdk/pull/1945),
> * [Better logs](https://github.com/matrix-org/matrix-rust-sdk/pull/1974).
> * In the Notification land, we need two sync loops instead of one (that controls them all), everything is described in [The Two Sync Loops](https://github.com/matrix-org/matrix-rust-sdk/issues/1928), with sub-issues [1](https://github.com/matrix-org/matrix-rust-sdk/issues/1961) and [2](https://github.com/matrix-org/matrix-rust-sdk/issues/1962),
> * In the Media land, we are starting to support [media uploading progress](https://github.com/matrix-org/matrix-rust-sdk/issues/1968),
> * In the Bindings land:
> * We are starting to deploy [UniFFI async support](https://github.com/matrix-org/matrix-rust-sdk/pull/1661), which was partly reverted for particular cases, but it works in general,
> * [Stop unconditionally enabling `native-tls` from `matrix-sdk-ffi`](https://github.com/matrix-org/matrix-rust-sdk/pull/1954), which led to compilation issue on Android architectures.
## That's all I know
See you next week, and be sure to stop by [#twim:matrix.org](https://matrix.to/#/#twim:matrix.org) with your updates!