Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support Bluesky oEmbed auto-discovery #20028

Closed
1 task done
bnewbold opened this issue Apr 16, 2024 · 4 comments · Fixed by #20435
Closed
1 task done

Support Bluesky oEmbed auto-discovery #20028

bnewbold opened this issue Apr 16, 2024 · 4 comments · Fixed by #20435
Labels

Comments

@bnewbold
Copy link

Issue Summary

Bluesky (https://bsky.app) recently added post embeds, including oEmbed discovery.

For the later, it looks like Ghost does not allow the <script> tag to be auto-included, probably as a safety/security feature.

From a quick check, it looks like Ghost uses @extractus/oembed-extractor to parse out oEmbed, and that package doesn't seem to work with the bluesky oEmbed discovery: https://extractor-demos.pages.dev/oembed-extractor

It looks like they synchronize with the "official" provider list at: https://oembed.com/providers.json

I opened an issue to get us on that provider list (iamcal/oembed#743).

I'm opening this issue in Ghost to confirm that this is the correct way to get supported in Ghost, and to track interoperability with Ghost specifically.

For what it is worth, the source code for our embed widget script, the embed.bsky.app service, and the Bluesky Social app itself are all open source: https://github.com/bluesky-social/social-app

Thanks for all you do maintaining Ghost!

Steps to Reproduce

Paste a bsky.app post link. Expect a fully-functional post (with JS/iframe). Instead get either a "card", or the raw embed <blockquote> without javascript re-write.

Ghost Version

hosted

Node.js Version

hosted

How did you install Ghost?

hosted

Database type

MySQL 5.7

Browser & OS version

N/A

Relevant log / error output

No response

Code of Conduct

  • I agree to be friendly and polite to people in this repository
@github-actions github-actions bot added the needs:triage [triage] this needs to be triaged by the Ghost team label Apr 16, 2024
@kevinansfield
Copy link
Member

Bluesky oembed should already be supported via the <link rel="alternate" type="application/json+oembed" href="..."> tag.

However looking at the oembed data returned it's missing a height property so it isn't seen as a valid oembed response. According to the oembed spec (See "2.3.4.4. The rich type") both width and height are required fields for the rich type.

@bnewbold
Copy link
Author

Hi @kevinansfield, thanks for the fast reply!

Our intention is to set height to null, which is what Twitter does (https://developer.twitter.com/en/docs/twitter-for-websites/oembed-api#item1). We don't have a way to pre-compute height of an embed ahead of time, so we can't set an accurate height value.

@kevinansfield
Copy link
Member

kevinansfield commented Apr 17, 2024

Ok, taking a look at the code it seems we don't have validation steps for "known" providers handled by the oembed-extractor library which is why Twitter works. I think we should at least be able to drop the height requirement here when checking that the rel="alternate" derived data is valid - we don't actually use the height anywhere, the check was just protection against potentially reading/storing/exposing data from non-oembed resources.

@bnewbold
Copy link
Author

@daniellockyer daniellockyer added P4 - Low and removed needs:triage [triage] this needs to be triaged by the Ghost team labels May 1, 2024
@ErisDS ErisDS removed the P4 - Low label Jun 14, 2024
@ErisDS ErisDS added the P4 - Low label Jun 14, 2024 — with Linear
kevinansfield added a commit to kevinansfield/Ghost that referenced this issue Jun 20, 2024
closes TryGhost#20028

It's fairly common practice for oembed providers to skip some of the "required" fields from the oembed spec such as `height` when it doesn't make sense for the embeddable content, this was the case with Bluesky embeds which return `height: null`

- removed validation for `height` being present in the response for it to be recognised as an embed because we don't use it anywhere and the validation is blocking otherwise valid embeds
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants