matrix.org/content/blog/2020/12/2020-12-25-the-matrix-holid...

89 lines
23 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 = "The Matrix Holiday Special 2020"
path = "/blog/2020/12/25/the-matrix-holiday-special-2020"
[taxonomies]
author = ["Matthew Hodgson"]
category = ["General"]
[extra]
image = "https://matrix.org/blog/img/matrix-logo.png"
+++
Hi all,
Over the years its become a tradition to write an end-of-year wrap-up on Christmas Eve, reviewing all the things the core Matrix team has been up over the year, and looking forwards to the next (e.g. heres [last years edition](https://matrix.org/blog/2019/12/24/the-2019-matrix-holiday-update)). These days theres so much going on in Matrix its impossible to cover it all (and besides, we now have [This Week In Matrix](https://matrix.org/blog/category/this-week-in-matrix) and better blogging in general to cover events as they happen). So heres a quick overview of the highlights:
Looking back at our [plans for 2020](https://matrix.org/blog/2019/12/24/the-2019-matrix-holiday-update#2020) in last years wrap-up, amazingly it seems we pretty much achieved what we set out to do. Going through the bulletpoints in order:
* We [turned on End-to-end Encryption by default](https://matrix.org/blog/2020/05/06/cross-signing-and-end-to-end-encryption-by-default-is-here).
* We have a dedicated team making major improvements to First-Time User Experience in Element (as of the last few months; hopefully youve been noticing the improvements!)
* [RiotX became Element Android and shipped](https://element.io/blog/welcome-to-element/).
* Communities have been completely reinvented as [Spaces](https://youtu.be/_Ade0FZfnWo?t=39) ([MSC1772](https://github.com/matrix-org/matrix-doc/commits/matthew/msc1772/proposals/1772-groups-as-rooms.md)) and while in alpha currently, they should ship in Jan.
* [Synapse scalability is fixed](https://matrix.org/blog/2020/11/03/how-we-fixed-synapses-scalability): we now shard horizontally by event - and Synapse is now pretty much [entirely async/await](https://patrick.cloke.us/areweasyncyet/)!
* [Dendrite Beta shipped](https://matrix.org/blog/2020/10/08/dendrite-is-entering-beta/), as did the [initial P2P Matrix experiments](https://matrix.org/blog/2020/06/02/introducing-p-2-p-matrix/), which have subsequently continued to evolve significantly (although we havent implemented [MSC1228](https://github.com/matrix-org/matrix-doc/blob/rav/proposal/remove_mxids_from_events/proposals/1228-removing-mxids-from-events.md) or [MSC2787](https://github.com/matrix-org/matrix-doc/blob/neilalexander/identities/proposals/2787-portable-identities.md) portable accounts yet). Check out the [Dendrite end-of-year update](https://matrix.org/blog/2020/12/15/dendrite-2020-progress-update) for more.
* [MLS experiments are in full swing](https://youtu.be/_Ade0FZfnWo?t=939) - we got the first MLS messages passing over Matrix a few days ago, and Decentralised MLS work is back on the menu after an initial sprint in May.
* Theres been a valiant mission to improve Bridge UX in the form of [MSC2346](https://github.com/matrix-org/matrix-doc/pull/2346) and its implementations in Element Web, although this has ended up failing to get to the top of the todo list (sorry Half-Shot! :/)
* Spec progress has improved somewhat, and we are very excited to have welcomed Will Bamberg (formerly MDN) to support the spec from a professional tech writer perspective, with [the all-new engine](https://friendly-yonath-3de225.netlify.app/) landing any day now! Were still experimenting with ways to ensure the spec gets enough time allocated to keep up with the backlog, however - particularly community contributions.
* ...and in terms of Abuse/Reputation - we properly [kicked off our anti-abuse work](https://matrix.org/blog/2020/10/19/combating-abuse-in-matrix-without-backdoors) and launched a first PoC implementation in the depths of [Cerulean](https://matrix.org/blog/2020/12/18/introducing-cerulean#whats-with-the-decentralised-reputation-button) last week.
Perhaps more interesting is the stuff we didnt predict (or at least didnt want to pre-announce ;) for 2020:
* Riot, Modular and New Vector got unified at last behind a single name: [Element](https://element.io/blog/welcome-to-element/); hopefully the shock has worn off by now :)
* [Mozilla joined Matrix](https://matrix.org/blog/2020/03/03/moznet-irc-is-dead-long-live-mozilla-matrix) in force, turning off Moznet IRC in favour of going full Matrix.
* [We welcomed Gitter](https://matrix.org/blog/2020/09/30/welcoming-gitter-to-matrix) into the heart of the Matrix ecosystem (with [Element acquiring Gitter](https://element.io/blog/gitter-is-joining-element/) from [Gitlab](https://about.gitlab.com/blog/2020/09/30/gitter-moves-to-element/) in order to ensure Gitters Matrix integration acts as a reference for integrating future chat silos into Matrix) - with [native Matrix support in Gitter](https://matrix.org/blog/2020/12/07/gitter-now-speaks-matrix) going live shortly afterwards.
* [Automattic](https://matrix.org/blog/2020/05/21/welcoming-automattic-to-matrix) launched itself into the Matrix ecosystem with an investment in Element, and since then weve been working on getting Matrix better integrated and available to them (although all of Elements Matrix-for-governments activity has ended up delaying this a bit). If you want to work for Automattic on integrating Matrix, [theyre hiring](https://automattic.com/work-with-us/matrix-integrations-engineer/)!
* We previewed [Cerulean](https://matrix.org/blog/2020/12/18/introducing-cerulean) as a super-exciting proof-of-concept client, demonstrating how social media could work on Matrix, with native threading, profiles-as-rooms, decentralised reputation, and (shortly) peeking-over-federation.
* [We completely rewrote matrix.to](https://matrix.org/blog/2020/12/17/matrix-to-reloaded) and relaunched it as a much more capable and friendly permalink redirection service; a precursor to finally getting matrix:// URLs everywhere!
* We certainly didnt predict that the “[how to install Synapse](https://matrix.org/blog/2020/04/06/running-your-own-secure-communication-service-with-matrix-and-jitsi)” video tutorial published at the beginning of the COVID-19 pandemic would end up with 25.5K views (and counting…)
Then, theres whole new waves of exciting stuff going on. The most obvious has to be the amount of Government uptake weve seen with Matrix this year, following on from [France embracing Matrix](https://joinup.ec.europa.eu/collection/open-source-observatory-osor/document/french-government-launches-house-developed-messaging-service-tchap) across the public sector last year. Firstly the German armed forces announced their [transition to Matrix](https://www.bwi.de/news-blog/news/artikel/open-source-matrix-ist-einheitlicher-messenger-standard-fuer-die-bundeswehr), and then the German states of Schleswig-Holstein and Hamburg announced a [mammoth 500K user Matrix deployment](https://sifted.eu/articles/element-germany-deal/) for education and public administration. Meanwhile, North Rhine Westphalia (the biggest state in Germany) launched their own Matrix-powered [messager for education](https://www.logineo.schulministerium.nrw.de/LOGINEO-NRW/NEU-LOGINEO-NRW-Messenger/Messenger.html); loads of different universities have rolled out Matrix for collaboration - and we hear [Famedly](https://famedly.com) is [making good progress](https://www.businessinsider.de/gruenderszene/health/famedly-kommunikation-app-gesundheitswesen/) with Matrix-powered healthcare messaging solutions. Finally, outside of Germany, were seeing the first official deployments in the UK government and US federal government - well share details where possible (but sometimes big deployments of encrypted communication systems want to remain discreet). Its incredibly exciting to see Matrix spreading across the public sector and education, and were hoping this will follow a similar pattern to how the Internet, email or indeed the Web first developed: a mix of high profile public sector deployments, complemented by a passionate grass-roots technical community, eventually spreading to span the rest of society :).
Another exciting thing which emerged this year is the amazing academic work that Karlsruhe Institute of Technologys [Decentralized Systems and Network Services Research Group](https://dsn.tm.kit.edu/english/) has been conducting on Matrix. This really came on the radar back in June when their [Matrix Decomposition: Analysis of an Access Control Approach on Transaction-based DAGs without Finality](https://matrix.org/blog/2020/06/16/matrix-decomposition-an-independent-academic-analysis-of-matrix-state-resolution) paper was published - a truly fascinating analysis of how state resolution works in Matrix, and how we manage to preserve access control within rooms without using blockchain-style sealed blocks (and has helped fix a few nasty bugs!). Im not sure any of us realised that Matrixs state resolution counts as a new field of research, but its been great to follow along with their independent work. Most recently, and even more excitingly, theyre circulating a preview of their [Analysis of the Matrix Event Graph Replicated Data Type](https://arxiv.org/abs/2011.06488) paper - a deep analysis of the properties of Matrix DAGs themselves. We highly recommend reading the papers (what better way to spend the holiday break!). To give a taste, the final paragraph of the paper concludes:
[![MEG summary](https://matrix.org/blog/img/2020-12-25-meg-summary.png)](https://arxiv.org/abs/2011.06488)
2020 has also seen the arrival and maturation of a whole new generation of Matrix clients - [Hydrogen](https://hydrogen.element.io) is *really* impressive as an experimental next-generation Web (and Mobile Web) client; an account with 3000 rooms that uses 1.4GB of RAM on Element Web uses 14MB of RAM on Hydrogen and launches instantly, complete with excellent E2EE implementation. It even works on MSIE! The whole app, including dependencies, is about 70KB of code (200KB including Olm). Meanwhile, [matrix-rust-sdk](https://github.com/matrix-org/matrix-rust-sdk) is coming along well, providing a general purpose native library for writing excellent native Matrix clients. Fractal merged initial matrix-rust-sdk a few weeks ago, and well be experimenting with switching to it in Element iOS and Element Android (for its e2ee) in the coming year. Its not inconceivable to think of a world where matrix-rust-sdk ends up being the no-brainer official SDK for native apps, and Hydrogens SDK becomes the no-brainer official SDK for JS apps.
Meanwhile, in the community, theres been so much activity its untrue. But on the subject of maturing apps, its been incredibly exciting to see [NeoChat](https://invent.kde.org/network/neochat) emerge as an official KDE Matrix client (built on [libQuotient](https://github.com/quotient-im/libQuotient) and [Kirigami](https://develop.kde.org/frameworks/kirigami), forked from [Spectral](https://gitlab.com/spectral-im/spectral)), [FluffyChat](https://gitlab.com/famedly/fluffychat) going from strength to strength; [Nheko](https://nheko.im/nheko-reborn/nheko) continuing to mature impressively; [Mirage](https://github.com/mirukana/mirage) appearing out of nowhere as a fully featured desktop client; [Fractal](https://gitlab.gnome.org/GNOME/fractal) merging matrix-rust-sdk etc. On the serverside, [Conduit](http://conduit.rs/) was the big community story of the year - with an incredibly fast Rust + Sled server appearing out of the blue, with viable federation coming up on the horizon. The best bet for an overview of all things community is to checkout the [TWIM backlogs](https://matrix.org/blog/category/this-week-in-matrix) however - theres simply way too much stuff to mention it all here.
Obviously, no 2020 wrap-up post would be complete without acknowledging the COVID-19 pandemic - which increased focus on Matrix and other remote collaboration technology more than anyone could have predicted (especially given all the privacy missteps from Zoom, Teams and others). One of the highlights of the year was seeing the HOPE (Hackers On Planet Earth) conference shift [their entire proceedings over to Matrix](https://hackaday.com/2020/08/11/hope-2020-delivers-historic-marathon-of-hacking/) - turning the conference into a 10 day television station of premium hacking content, with Matrix successfully providing the social glue to preserve a sense of community despite going virtual. Similarly, were incredibly excited that FOSDEM 2021 is highly likely to run primarily via Matrix (with bridges to IRC and XMPP, of course) - our work is going to be cut out for us in January to ensure the amazing atmosphere of FOSDEM is preserved online for the >8,500 participants and ~800 talks. And if any other event organisers are reading this - please do reach out if youre interested in going online via Matrix: we want Matrix to be the best possible ecosystem for online communities, including virtual events, and well be happy to help :)
Talking of FOSDEM, a really fun bit of work which landed in Element this year was to (finally!) polish Widgets: the ability to embed arbitrary webapps into Matrix chatrooms. This includes being able to embed widgets in the RightPanel on Element Web, the LeftPanel too, add as many as you like to a room, resize them(!), and generally build much more sophisticated dashboards of additional content. Modal and fullscreen widgets are coming too, as are ways to simplify and unify access control. It turns out that these have arrived in the nick of time for events like FOSDEM, where were expecting to very heavily use widgets to embed video streams, video conferences, schedules, and generally automate the workflow of the conference via adding in web UIs as widgets wherever necessary. The work for this has been driven by the various German education deployments, where the same tricks are invaluable for automating online learning experiences. We originally wrote Widgets back in 2017 as a proof-of-concept to try to illustrate how chatrooms could be used to host proper custom UIs, and it's fantastic to see that dream finally come of age.
Finally, its been really exciting to see major progress in recent months on whats essentially a whole new evolution of Matrix. Two years ago, a quiet patch during the Christmas holidays gave birth to a whole bunch of wild science fiction Matrix Spec Changes: [MSC1772](https://github.com/matrix-org/matrix-doc/pull/1772): Spaces (groups as rooms), [MSC1769](https://github.com/matrix-org/matrix-doc/pull/1769): Profiles as rooms, [MSC1767](https://github.com/matrix-org/matrix-doc/pull/1767): Extensible events, [MSC1776](https://github.com/matrix-org/matrix-doc/pull/1776): Peeking over /sync, [MSC1777](https://github.com/matrix-org/matrix-doc/pull/1777): Peeking over federation, etc. This was in part trying to ensure that we had something to look forward to when we emerged from the tunnel of launching Matrix 1.0, and in part trying to draw a coherent high-level sketch of what the next big wave of Matrix features could look like. Inevitably the MSCs got stuck in limbo for ages while we exited beta, launched Matrix 1.0, turned on E2EE by default etc - but in the latter half of this year theyve hit the top of the todo list and its been incredibly exciting to see entirely new features landing once again. Implementation for Spaces is in in full swing and [looking great](https://youtu.be/_Ade0FZfnWo?t=39); Profiles-as-rooms are effectively being trialled in Cerulean; Peeking over /sync has landed in Dendrite and peeking over federation is in PR (and unlocks all sorts of desirable features for using rooms more generically than we have today, including Spaces). Only Extensible events remains in limbo for now (we have enough to handle getting the others landed!)
Of these, Spaces has turned out to be exciting in wholly unexpected ways. While prototyping the UX for how best to navigate hierarchies of spaces, we had a genuine epiphany: the ability for anyone to define and share arbitrary hierarchies of rooms makes Matrix effectively a global decentralised hierarchical file system (where the files are streams of realtime data, but can obviously store static content too). The decentralised access controls that KIT DSN [wrote about](https://matrix.org/blog/2020/06/16/matrix-decomposition-an-independent-academic-analysis-of-matrix-state-resolution) could *literally* be file-system style access controls; enforcing access on a global decentralised hierarchy. We obviously have shared hierarchical filesystems today thanks to Dropbox and Google Drive, but these of course are centralised and effectively only store files - whereas Spaces could potentially scale to the whole web. In fact, you could even think of Spaces as flipping Matrix entirely on its head: the most defining building block going forwards could be the Spaces themselves rather than the rooms and events - just as directories are intrinsic to how you navigate a conventional filesystem. How has Matrix got this far without the concept of folders/directories?!
Right now these thoughts are just overexcited science fiction, but the potential really is mindblowing. It could give us a global read/write web for organising any arbitrary realtime data - with the social controls via ACLs to delegate and crowdsource curation of hierarchies however folks choose. The Matrix.org Foundation could seed a root hierarchy, go curate all the rooms we know about into some Linnean-style taxonomy, delegate curation of the various subspaces to moderators from the community, and hey presto weve reinvented USENET… but with modern semantics, and without the rigid governance models. Hell, we could just mount (i.e. bridge) USENET straight into it. And any other hierarchical namespace of conversations you can think of - Google Groups, Stackoverflow, Discourse, IMAP trees…
Of course, the initial Spaces implementation is going to be focused of on letting communities publish their existing rooms, and users organise their own rooms, rather than managing an infinite ever-expanding global space hierarchy - but given weve been designing Spaces to support government (and inter-government) scales of Spaces, its not inconceivable to think we could use it to navigate gigantic public shared Spaces in the longer term.
Anyway, enough Space scifi - whats coming up in 2021?
## 2021
Our current hit list is:
* **Spaces** - see above :)
* **Social Login** - were going to be making Single Sign On (SSO) a proper first-class citizen in Matrix (and Synapse and Element) in the coming weeks, and enabling it on the matrix.org homeserver, so users can do single-click logins via Github/Gitlab/Google and other SSO providers. Obviously this means your Matrix identity will be beholden to your identity provider (IdP), but this may well be preferable for many users who just want a single-click way to enter Matrix and dont care about being tied to a given IdP.
* **VoIP** - we have a *lot* of work in flight at the moment to make 1:1 VoIP super robust. Some of it has already landed in Element, but the rest will land in the coming weeks - and then were hoping to revisit Matrix-native group voice/video.
* **Voice messaging** - were hoping to finally add voice messaging to Element (and Matrix)
* **Location sharing** - ...and this too.
* **P2P **- Lots of P2P work on the horizon, now Dendrite is increasingly stable. First of all we need to iterate more on Pinecone, our pre-alpha next-generation P2P overlay network - and then sort out account portability, and privacy-preserving store-and-forward. Were hoping to see the live P2P Matrix network turn on this year, however, and ideally see homeservers (probably Dendrite) multihoming by default on both todays Matrix as well as the P2P network, acting as gateways between the two.
* **Threads** - Cerulean is excellent proof for how threading could work in Matrix; we just need to get it implemented in Element!
* **Peeking** - Peeking is going to become so much more important for participating in non-chat rooms, such as Spaces, Profiles, Reputation feeds, etc. Well finish it in Dendrite, and then implement it in Synapse too.
* **Decentralised Reputation **- Cerulean has the first implementation of decentralised reputation for experimentation purposes, and well be working solidly on it over the coming year to empower users to counter abuse by applying their own subjective reputation feeds to their content.
* **Incremental Signup **- Once upon a time, Element (Riot) had the ability to gradually sign-up without the user even really realising theyd signed up. We want to bring it back - perhaps this will be the year?
* **DMLS** - with the first [MLS](https://datatracker.ietf.org/wg/mls) messages flowing over Matrix, we want to at least provide MLS as an option alongside Megolm for encryption. It should be radically more performant in larger rooms (logarithmic rather than linear complexity), but lacks deniability (the assurance that you cannot prove a user said something in retrospect, in order to blackmail them or similar), and is still unproven technology. Well aim to prove it in 2021.
* **E2EE improvements** - We improved E2EE immeasurably in 2020; turning it on by default, adding cross-signing, QR code verification etc. But usability and reliability can still be improved. Well be looking at further simplifying the UX, and potentially combining together your login password and recovery/security passphrase so you only have one password to remember going forwards.
* **Hydrogen** - Well keep polishing Hydrogen, bringing it towards feature parity with Element, ensure its SDK is available for other clients, and start seeing how we can use it in Element itself. For instance, the Spaces-aware RoomList in Element may well end up stealing alien technology from Hydrogen.
* **matrix-rust-sdk** - Similarly, well keep polishing matrix-rust-sdk; stealing inspiration from Hydrogens state model, and start migrating bits of the native mobile Element apps to use it.
* **The Spec** - get Wills new spec website live, and get improving all the surrounding material too.
Im sure Im missing lots here, but these are the ones which pop immediately to mind. You can also check [Element's public roadmap](https://github.com/vector-im/roadmap/projects/1), which covers all the core Matrix work donated by Element (as well as everything else Element is getting up to).
As always, huge huge thanks goes to the whole Matrix community for flying Matrix and keeping the dream alive and growing faster than ever. Its been a rough year, and we hope that youve survived it intact (and you have our sincere sympathies if you havent). Lets hope that 2021 will be a massive improvement, and that the whole Matrix ecosystem will continue to prosper in the new year.
\-- Matthew, Amandine, and the whole Matrix team.