artlu pfp
artlu
@artlu
feels: so fking defeated rn my old frames are half-dead on Warpcast with "couldn't be loaded" images, but appear 💯 fine on /recaster . I fight linkrot / decay with every fibre of my hacker soul, going back to my early training in writing code for the International Space Station (it's still up there in space orbit), to making an archival tool my first Farcaster project, to SassyHash which was built difficult-ly in order to be able to survive any attack and live forever
8 replies
2 recasts
31 reactions

Tony D’Addeo  pfp
Tony D’Addeo
@deodad
images don’t get cached, only proxied so we don’t expose users ips to 3parties even scrolling the feed most be something else related to the proxy like missing content type header that may be trivial to fix happy to look into it
1 reply
0 recast
3 reactions

artlu pfp
artlu
@artlu
proxy is my fren, wdym he's not forwarding my images? actually, if it's related to headers, I was on an early (working) version of frog 🐸 and maybe requirements evolved over time? idk 🤷 here's the gh https://github.com/artlu99/fartcaster-action and a video showing the user flow in warpcast vs recaster
1 reply
0 recast
1 reaction

Tony D’Addeo  pfp
Tony D’Addeo
@deodad
thanks for sharing, the URL that frame embed was pointing to is now a 404 https://fartcaster-action.vercel.app/api/image&s=724507676c1e1d0d8f0e14b0e8021672b2b9b4e76b7569cfd8ce0e5d58cf5556 it probably works on recaster because recaster didn't scrape the frame until a later point if you re-cast this frame on WC it will work fine since the current image defined in the metatag is valid once a cast is made we don't rescrape the metatags as there's not an obvious scalable way—at what point do you re-scrape the embed URL for any particular cast? a nice devtool I've considered adding for devs is a quick way to manually trigger a rescrapping of the metadata for a cast though the limitation is this only let's you fix a specific cast which might not be useful if there are hundreds
1 reply
0 recast
1 reaction

Tony D’Addeo  pfp
Tony D’Addeo
@deodad
stepping back the core problem is a framework generated a URL that then at somepoint (probably an upgrade that changed how rendered happened) became 404 which is unfortunate but not shocking given it was a very early version I think the idea that once you cast something the content of it doesn't change is reasonable and there's not an obvious problem with how Warpcast is caching anything
1 reply
0 recast
1 reaction

Tony D’Addeo  pfp
Tony D’Addeo
@deodad
the best generalized solution I can think of for this is to expect Farcaster clients to take ownership of making sure images are live by downloading and hosting them themselves rather than relying on every frame server to be running and backwards compatible for ever this is what Warcpast does with an image directly embedded in a cast this is even a stronger version of caching, the reason we don't do this with frames is there's some fun things frame servers can do where they use a short cache policy and serve a dynamic image but maybe this is something that could be opted into with a flag that indicates you want full control over image serving
1 reply
0 recast
1 reaction

artlu pfp
artlu
@artlu
There's still a missing piece in my mental model. Can you help me understand better? Right now, the frame's entrypoint the image at is broken on warpcast/fine on recaster. If I cast again, it will work again. This is consistent with my mental model of how Warpcast caches cast content. Inside the user flow, there should be no caching, only proxying (?). These dynamic images get generated as part of an interactive flow. Why are they broken in Warpcast, and not broken elsewhere? Practical question 1 (on me to answer, not on you): if I upgrade frog, will my old cast magically get better? I am more interested in resurrecting the old cast than a fresh new one, tbh. That feels more credible, less bait-and-switchy. Practical question 2: will Frames V2 have similar dependencies and/or fragility that I can design around? It seems ... for the dynamic OG image displayed on the landing page, maybe yes maybe no? Inside the flow, no? because the interaction all happens in my own sandbox?
1 reply
0 recast
1 reaction

Tony D’Addeo  pfp
Tony D’Addeo
@deodad
correct, I'm able to see leaderboard and secondary steps fine on web but tried on mobile and they are all broken. my guess w/o having looked is this is just a stupid bug where we don't update the "image is broken" state on subsequent loads — will look into / fix if so on Monday as to q1, I doubt upgrading will fix but if it somehow means that an image is served at the image url above then yes it would q2, frames v2 feed images work the same as of now, the frame server must continue server an image at whatever urls it once was and also yes once they in the frame it's just your web app always fetching the latest pages from your server based on the caching policy you set and with no proxying
1 reply
0 recast
1 reaction

artlu pfp
artlu
@artlu
ok I will also update my server to serve the original image at that old url (as a one-off hack!) thx 🙏
1 reply
0 recast
0 reaction

Tony D’Addeo  pfp
Tony D’Addeo
@deodad
indeed mobile had a bug where the initial image being broken would mean subsequent renders would still show the same error even if their image was fine once this get's out even broken versions of the frame will work once the user start interacting
0 reply
0 recast
1 reaction