#dev 2025-02-24

2025-02-24 UTC
[snarfed] and sebbu joined the channel
#
gregsarjeant
It's taken me a while to get here, but I have a janky little node.js app monitoring my site and sending out webmentions in response to new posts and I'm so happy.
#
gregsarjeant
aaronpk++ Thanks for all the posts you've written and tools you've built for webmentions. They've been a huge help.
#
Loqi
aaronpk has 58 karma in this channel over the last year (136 in all channels)
#
aaronpk
yay thanks!
#
gregsarjeant
Next step: write up my journey!
MyNetAz, SylvatiCodes, grufwub, bterry1, CRISPR, sp1ff, gRegor and [Joe_Crawford] joined the channel
#
zachary.kai
I've managed to add a search function to my site! (Using PHP.) Next: a note on how I did it. https://zacharykai.net/search Suggestions for improvements always welcome!
#
zachary.kai
[edit] I've managed to add a search function to my site! (Using PHP.) Next: a note on how I did it. https://zacharykai.net/search Suggestions for improvements always welcome!
#
zachary.kai
[edit] I've managed to add a search function to my site! (Using PHP.) Next: a note on how I did it. https://zacharykai.net/search Suggestions for improvements always welcome!
thegreekgeek, thegreekgeek_, chenghiz_, nemonical, ttybitnik, [jeremycherfas] and [lazcorp] joined the channel
#
[lazcorp]
@zachary.kai - I'd be interested to read about how you added search - I've been thinking of doing that for my site (also PHP)
[qubyte] and revi joined the channel
#
zachary.kai
lazcorp Of course! I'll post the link here as soon as I've written it. Hope you'll find it useful!
#
GWG-
I've been playing with upgrading my media server... I see it offers webhooks... wondering what interesting integrations I can do with my website. Any ideas?
CRISPR joined the channel
#
[tantek]
conneg-- because yes it can screw with and make it much harder to properly do caching
#
Loqi
conneg has -25 karma in this channel over the last year (-28 in all channels)
#
[tantek]
per that WordPress ActivityPub plugin returning a bunch of JSON to normal web browsers sometimes
#
[snarfed]
that one specifically is yet another problem that I hadn't originally included in https://snarfed.org/2023-03-24_49619-2 : experienced engineers who understand it, but deliberately choose not to serve Vary by default due to FUD that it will expand cache sizes too much
#
[snarfed]
ie, conneg can incentivize you to knowingly serve incorrect results
#
[tantek]
is there a way to force it like with a random query param?
[schmarty] and [Murray] joined the channel
#
[Murray]
@GWG: would that enable things like automated "scrobbling" of what you're watching; something like Trakt? Or perhaps a "now watching" widget 🙂
#
GWG-
[Murray]: Yes, just not sure how much I want to reveal what I'm watching and when.
#
GWG-
I was thinking of making it private and then aggregating
paotsaq joined the channel
#
[Murray]
could definitely be a fun way to do it 🙂 I have a manual-ish approach to that, but have always wanted something to gather the data in the background. Out of interest, what is your media server running on?
#
[Murray]
also, something like a "now watching" doesn't need to be real-time. You could log it when you start watching a season of something, and have it show until the final episode is sent (maybe; not sure how you'd automatically determine the final episode 😄). Or just a "most recently watched" with some kind of delay
[pfefferle] joined the channel
#
[pfefferle]
[tantek] that is a cache glitch 😞
#
[tantek]
[pfefferle] any chance of re-opening the issue that [snarfed] cited?
#
[tantek]
because it's obviously still a problem
#
[tantek]
yes, I witnessed it myself
#
[pfefferle]
cleared the cache now
#
[tantek]
I clicked the blog post permalink, and got a pageful of JSON in my browser. that's a problem.
#
[tantek]
for reference, this issue: https://github.com/Automattic/wordpress-activitypub/issues/580 IMO should be re-opened until there's a solution that doesn't require the blog user to manually clear their cache
#
Loqi
[preview] [uk3] #580 WordPress sometimes returns JSON to a Webbrowser instead of the HTML page.
#
[pfefferle]
it is not a problem by the plugin, but by caching plugins not supporting conneg
#
capjamesg[d]
I am encouraged that the W3C community is doing more work in this area!
#
[tantek]
[pfefferle] can the issue be transferred to those plugins?
#
[pfefferle]
a lot of them are already ignoring the application header
#
[pfefferle]
but there are so many
#
[tantek]
^ that indicates a systemic problem then
#
[tantek]
so either there should be bug on WordPress core with its interface to caching plugins, OR
#
[tantek]
there should be a bug on anything that uses conneg to do so in a way that doesn't break caches
#
[pfefferle]
or to disable conneg for the permalinks 😞
#
[tantek]
the worst solution is to close the issue with no place to follow-up
#
[pfefferle]
do you see html now?
#
[pfefferle]
I am directing all people with issues to the wiki and help them to report it to their plugin devs
#
[tantek]
Once I explicitly reloaded in the browser I saw HTML
#
[tantek]
er I mean I saw an HTML page rendered properly, not HTML source 🙂
#
[pfefferle]
😮‍💨
Daijo and voxpelli joined the channel
#
GWG-
[Murray]: Running Plex and Jellyfin in parallel... waiting for a final face-off
gRegor and jonnybarnes joined the channel
#
[snarfed]
[pfefferle] I don't think "it is not a problem by the plugin, but by caching plugins not supporting conneg" is quite right. the AP plugin is the one serving different content types for the same URL based on the `Accept` header, so I'd argue it's the AP plugin's responsibility to also serve the `Vary` header
#
[snarfed]
caching plugins can't know ahead of time whether the server is going to serve multiple content types on a given URL
#
[snarfed]
you all did add a config variable to make the AP plugin serve `Vary`. which is good! even if it's currently off by default iirc
nemonical joined the channel
#
[pfefferle]
we had this conversation so many times 🙂
#
[snarfed]
yes we have! sorry
#
[pfefferle]
these are plugins, not caching services
#
[snarfed]
right! that's what I said
#
[pfefferle]
I am not aware that any of the plugins even care about the header
#
[snarfed]
really?! that would be very surprising
#
[snarfed]
and obviously wrong of them too
#
[snarfed]
is your site serving `Vary: Accept`?
#
[pfefferle]
isn't this somehting cloudflare cares about?
#
[pfefferle]
why should a local/in app caching check the vary header?
#
[snarfed]
no, your site is only serving `Vary: Accept-Encoding`
#
[snarfed]
because that's how it will know if it needs to include the content type in the cache key
#
[snarfed]
you're welcome to have the AP plugin tell caching plugins that a different way if you want. it would be non-standard, but fine
#
[snarfed]
but regardless of caching plugins, your site isn't serving `Vary: Accept`, so caching services and probably plugins too will currently incorrectly cache your pages and cause this bug for viewers
#
[pfefferle]
no support
#
[snarfed]
are you sure? you clicked all the "more results" links?
#
[snarfed]
if you fully understand all of those search results and you're confident, then ok. that would seem like a bug in WP Super Cache then. I'd be surprised, but ok
#
[pfefferle]
that is the inhouse caching
#
[snarfed]
regardless, I don't think that's the main point. I expect the vast majority of AP plugin users haven't changed its config variable - including your own site! - so they keep serving JSON to human users in web browsers, like tantek
#
[pfefferle]
but that is what I always try to tell you
#
[pfefferle]
my caching plugin does not support vary headers
#
[snarfed]
but your site isn't serving the Vary header anyway!
#
[snarfed]
even if your caching plugin supported it, other caches between your site and users couldn't know, and would cache and serve JSON to humans, since your site isn't serving the header
#
[pfefferle]
now its sending it
#
[pfefferle]
but I am sure that it does not help here
#
[snarfed]
it may not fix all the cases, eg plugins, but it'll absolutely help
#
[snarfed]
now let's turn it on by default so that other sites are fixed (or helped) too 😁
#
[pfefferle]
should it always send the header or only when it is requested with the application/activity+json?
#
[snarfed]
otherwise caches would cache and serve HTML to AP requests, which is also wrong
#
[snarfed]
(at least, always serve the header on URLs that serve both HTML and AS2)
#
[tantek]
so always server the header on URLs that use conneg to server different content types on the same URL!
#
[tantek]
serve* the header even
#
[pfefferle]
I am fine with adding it, but it will not solve the plugin problem
#
[snarfed]
I'm still skeptical that WordPress caching plugins ignore Vary
#
[snarfed]
...but if they do, that's a big bug that we should file with them!@
#
[pfefferle]
I have checked all big plugins
#
[snarfed]
by checked, you mean you tested them with the AP plugin, configured to serve the Vary header, and you requested one content type, then the other type, and they served the first response, with the wrong type?
#
[snarfed]
if so, that's bad. definitely file bugs!
#
[pfefferle]
I checked their code
#
aaronpk
so if i'm understanding this conversation right, there is a mechanism in HTTP to prevent this kind of caching bug, but wordpress, the activitypub plugin, and caching plugins are all not using it?
#
[snarfed]
the AP plugin now supports it (serving Vary) but that support is off by default afaik
#
[pfefferle]
we provide a mechanism for it, but it is opt-in
#
[snarfed]
caching plugins, there's a difference of opinion. I'd be curious to see actual test results
#
[pfefferle]
I had a long discussion with WP-Rocket, one of the biggest caching systems and they had no way to do it
#
[snarfed]
[pfefferle] obviously knows WordPress code well though, so I do trust him
#
[snarfed]
trust but verify I guess
#
[snarfed]
no way to do it?! that seems really unlikely. that would mean, when a caching plugins is storing a response in its cache, it has no access to the response's headers?
#
[snarfed]
that sounds...like a contradiction in terms
#
[Joe_Crawford]
Cache hit depends on what's used for the key. If `Vary` and its value isn't part of the key then you get a false cache hit. Would be ... uh... fun to read some different implementations - see how they compose that key.
#
[pfefferle]
[snarfed] let me phrase it differently... "not urgent/important/critical enough to implement it"
#
[snarfed]
that's up to them I guess, correctness notwithstanding
#
[pfefferle]
and most caching plugin devs build en exception for the content header... which means that they are not cached...
#
[snarfed]
interesting that all of the bugs, posts, and fixes use the Accept header, but not the Vary header 🤷
#
[snarfed]
no matter
#
[pfefferle]
but I am fine with sending the vary by default
#
[pfefferle]
so I will work on a PR tomorrow to implement that
#
[pfefferle]
let's see if it helps
#
[pfefferle]
on the other hand I thought about disabling the conneg by default
#
[snarfed]
yes! that's maybe an even better approach: use different URLs for AP ids
#
[snarfed]
harder to migrate existing installations though
#
[pfefferle]
we do that already for quite a while
#
[snarfed]
really? why did tantek see this bug on your site then?
#
[pfefferle]
for posts it was easy... but profiles might be tricky
#
[pfefferle]
I still have conneg enabled
#
[pfefferle]
I am not sure if there are still implementations around that query the URL
#
[snarfed]
huh. so your site in particular doesn't use different URLs yet?
#
[snarfed]
and yeah there's no good way to change an AP actor id
#
[snarfed]
hmm, then I still don't understand why tantek saw the JSON bug
#
[pfefferle]
as I said... maybe there are still implementations that query the URL instead of the ID
#
[snarfed]
maybe! but that shouldn't matter if the AP plugin always lets WordPress serve HTML for the URL
#
[pfefferle]
I have not deactivated conneg for my permalinks
#
[snarfed]
ah right ok. yeah using different URLs vs ids only helps if you don't do conneg on them
#
[snarfed]
the real answer here is that conneg is awful
#
[snarfed]
sorry you have to deal with this! and sorry I push so hard
#
[pfefferle]
yes, but I like that you can simply search for a permalink to react to a post
#
gRegor
conneg--
#
Loqi
conneg has -26 karma in this channel over the last year (-29 in all channels)
#
[pfefferle]
at least on mastodon
#
[snarfed]
you don't need to serve conneg to make search in Mastodon work, right? rel-alternate should be enough for that? http://localhost:8080/docs#web-searchable
#
[pfefferle]
but what is even worse is, that I have an exception in my caching plugin... 😞
#
[pfefferle]
that is a localhost URL
Cas joined the channel
#
[pfefferle]
I do that already
#
[pfefferle]
so let me run some experiments on that
#
[pfefferle]
that would be even easier
#
[tantek]
rel=alternate > conneg
#
aaronpk
seriously, what a mess
#
[pfefferle]
thanks for pushing me again and again [snarfed] ☺️
#
[pfefferle]
snarfed++
#
Loqi
snarfed has 43 karma in this channel over the last year (77 in all channels)
#
[pfefferle]
and thanks to all of you for your feedback/input
#
[pfefferle]
Will see how I can clean up the plugin a bit
#
[snarfed]
you're welcome [pfefferle], and apologies for pushing so hard!
#
[snarfed]
thank you for being so gracious
jak2k joined the channel
#
[snarfed]
good luck!
#
[pfefferle]
not always easy to fight the old code that developed, because I tried to reverse engineer mastodon instead of reading the spec 🫣
#
[pfefferle]
aside from conneg, it was a very bad idea to use the pretty permalinks as ids… but as an IndieWeb guy, this made the most sense… back in the days ☺️
#
[tantek]
^ so much of the interop story
#
[tantek]
why not pretty permalinks as ids? curious about your thoughts on that [pfefferle]
#
[tantek]
is it because ids are supposed to be unchanging? while "pretty permalinks" have user-editable content (slugs)?
#
[pfefferle]
Exactly because of the conneg problem and that ap is expecting the id to serve the json
#
[pfefferle]
And the “unchanging” argument is valid too… it makes changing usernames way harder if the username is part of the pretty permalink
#
[pfefferle]
you never stop learning ☺️
#
[pfefferle]
Mastodon made the same mistake btw.
#
[pfefferle]
(the username in the permalink mistake)
#
[tantek]
sounds like good lessons to document in /URL_design
#
[tantek]
what is URL design
#
Loqi
URL design is the practice of deliberately designing URLs, in particular, permalinks, typically for a better UX for everyone who creates, reads, and shares content https://indieweb.org/URL_design
#
[tantek]
[pfefferle] do you know if Mastodon blogged about this mistake and learning from it?
#
[pfefferle]
not publicly (yet)
#
[pfefferle]
but they definitely learned from that and thinking about ways to "fix" it
#
[tantek]
even if there are mere conversations in GitHub issues, those would be useful to cite
ttybitnik, Daijo, sebbu2, CRISPR and yewscion__ joined the channel