View the history of public and world readable Matrix rooms
Go to file
Eric Eastwood 56f7d17126 Ensure deps available 2022-02-16 14:13:39 -06:00
public Fix lints 2022-02-15 21:33:31 -06:00
server Ensure deps available 2022-02-16 14:13:39 -06:00
shared Fix lints 2022-02-15 21:33:31 -06:00
.eslintignore Fix lints 2022-02-15 21:33:31 -06:00
.eslintrc.json Fix lints 2022-02-15 21:33:31 -06:00
.gitignore Fetch and render from homeserver 2022-02-07 19:55:11 -06:00
.prettierrc.json SSR with linkedom 2022-02-03 23:44:50 -06:00
README.md Fix lints 2022-02-15 21:33:31 -06:00
package-lock.json Add npm run start-dev to build vite and run server at once 2022-02-15 17:17:14 -06:00
package.json Fix lints 2022-02-15 21:33:31 -06:00
vite.config.js Stop restarting server when the client bundle updates 2022-02-15 17:30:30 -06:00

README.md

Matrix public archive

NB: This project is very much a work-in-progress (WIP)! Undocumented config/secrets, using a draft branch of Hydrogen, etc.

In the vein of feature parity with Gitter, the goal is to make a public archive site like Gitter's archives which search engines can index and keep all of the content accessible/available. There is already https://view.matrix.org/ (https://github.com/matrix-org/matrix-static) but there is some desire to make something with more Element-feeling polish and loading faster (avoid the slow 502's errors that are frequent on view.matrix.org).

Plan summary

The plan is to server-side render (SSR) the Hydrogen Matrix client on a Node.js server (since both use JavaScript) and serve pages on the fly (probably with some Cloudflare caching on top) when someone requests /archives/${year}/${month}/${day}. To fetch the events for a given day/time, we will use MSC3030's /timestamp_to_event endpoint to jump to a given day in the timeline and fetch the messages from a Matrix homeserver.

Re-using Hydrogen gets us pretty and native(to Element) looking styles and keeps the maintenance burden of supporting more event types in Hydrogen.

Prerequisites

  • Node.js v17
    • We only need v17 because it includes require('crypto').webcrypto