Some people are like "don't use browser forks, they will get you pwned" and while I haven't look into that, from a distance this looks like "Don't roll your own crypto".
And similar to how we don't want to discourage people from learning how to implement cryptographt, so it's more of a "Don't (let people) rely on your own crypto"
we also shouldn't discourage people from learning to work on these inscrutable behemoths that we call browser engines, so we advise people to just not rely on them
1/
But it seems to me that the browaer engine ecosystem isn't as healthy as cryptography implementation ecosystem these days.
It seems more like pre-PGP times (which I don't remember because I wasn't alive back then, so correct me if I'm wrong):
The only widely established implementations are opaque and developed by insular groups with questionable agendas.
IOW, unlike with libssl or libsodium, we desoerately need forks of browser engines.
2/
But let's take a step back: why are browser engines, which are one of the most comolex pieces of software in the world, so security critical?
Is it a skill issue that forks fail to keep the same security level as Chromium and Gecko?
Or are these two projects trying to achieve something that shouldn't be done, and they're lucky to have any resemblence of security?
Maybe Stallman was right to only open a few trusted websited in his browser, and read every other site through a sandboxed wget...
Maybe the browser we use to log in to our bank account or domain registrar should not run with the same OS privileges as the browser we use to explore random websites or watch videos
@lanodan I've seen "don't implement crypto algorithms yourself because you'll make a timing sidechannel, a padding oracle, or just, you know, accidentally override the key with all zeros"
I've also seen
"Don't build your own protocols on top of AES and SHA-256 because cryptogrqphic primitives are not lego bricks"
@lanodan can't say that about browsers, can we?
@lanodan I like how you assumed using gstreamer is worse than forking a video player
@lanodan no no
You said if ffmpeg didn't exist, you'd have to fork an existing video player, which is horrible.
This implies by omission that gstreamer is not your 2nd choice after ffmpeg :P
@lanodan which brings me to my next point:
It's not enough to have reusabke components. GNOME has reusable components (eg. gtk) but a lot of them have GNOME policy embedded in them - they will only do what GNOME needs them to do, and of you want to do things differently, tough luck, go write your own GUI toolkit.
We need unopinionated reusable components.
@lanodan
(meant to reply earlier but forgot)
Maybe the software, as in a snapshot of source code, can't be absolutely unopinionated. But it's a spectrum.
And you can look at the process of developing that software and see in which direction decisions are made.
1/
@lanodan
For example: if I make a pull request that says "hey, this library does $X which makes sense in your project but doesn't make sense in mine, so I let's make this behaviour configurable like this"
Do the maintainers approach it constructively, and work with you to find a solution that works for both/all projects using that library?
Or do they just reject the PR because "this is incompatible with $project's human interface guidelines" ?
@lanodan
re support - that's why it's ideal when all projects using the reusable component co-maintain it
@lanodan
wayland-protocols is a good example, although not exactly a reusable component...
Also, kubernetes and a lot of the CNCF stuff comes to my mind
@lanodan idk, I think wayland-protocols is better than the alternative of gtk only working on GNOME and Qt only working on KDE.
@lanodan I mean it'd still work on the other DEs but only with the most basic features