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

Proposal: <podcast:recommendations> tag #205

Open
benjaminbellamy opened this issue Mar 6, 2021 · 20 comments
Open

Proposal: <podcast:recommendations> tag #205

benjaminbellamy opened this issue Mar 6, 2021 · 20 comments

Comments

@benjaminbellamy
Copy link
Contributor

benjaminbellamy commented Mar 6, 2021

Hello everyone!

I wrote a specification for a recommendation tag:
https://github.com/Podcastindex-org/podcast-namespace/blob/main/proposal-docs/recommendations/recommendations.md

The basic idea is to allow podcasters to tell what other content they recommend.
The tag contains a URL to a JSON file that contains the actual recommendations.

<podcast:recommendations url="[url to json file]" type="application/json" language="[language code]" />[Optionnal comments]</podcast:recommendations>

Any comment or feedback is welcome. I'll update the specification accordingly.

@adamc199
Copy link

I really like this idea. A reverse recommendation algo.
I would use it.

@bjoreman
Copy link

bjoreman commented Apr 1, 2021

As a lover and creator of extensive show notes, this really appeals to me 😃. Coming from this angle, I feel like there should be an optional comment on each recommendation object, as I often want to add some context. ”This was the project X worked on during the time we discussed.” ”We were totally wrong when we said Y in the episode, X (the recommended page) is the actual right answer”, or ”Listener Z suggested this as additional listening, a great deep-dive on the topic we touched on.”

@daveajones
Copy link
Contributor

This is a big structure. We need more eyes on this if people can take some time and look through it:

Proposal

Ben, how much of this has been put into Castopod so far?

@benjaminbellamy
Copy link
Contributor Author

The podcast:recommendation tag has not been implemented into Castopod yet, but we plan to insert it into the next sprint.

@thebells1111
Copy link
Contributor

Would this be a feed level tag, an episode level tag, or both? I can see a strong argument for both. Feed for recommendations that are constant for the podcast, but episode for links to guest podcasts, amazon link to product recommendations, or anything else mentioned in that episode. It would remove the need to clutter the description with a bunch of links.

@PofMagicfingers
Copy link
Contributor

I'm wondering if it does not overlap a bit with the topics "topics" introduced in #180 and which would probably be moved to a separate file rather than tags (discussed in #184). Maybe we can merge theses ideas together ?

I guess we could make one big optional metadata file, one for the feed, and one per item as well, containing all topics, recommendations, soundbites of the podcast/episode. We could update it and change its url or hash like discussed in #184 to trigger updates in the podcast clients

@theDanielJLewis
Copy link

I noticed the proposal has an rss attribute. I suggest we use feed instead of rss in this spec and wherever possible.

@benjaminbellamy
Copy link
Contributor Author

I created a MR to replace rss by feed.

@benjaminbellamy
Copy link
Contributor Author

AbleKirby, cottongin and I had a fruitful talk together about the podcast:recommendation tag.
In a nutshell we added:

non-podcast feeds
the motive for the recommendation (acknowledgment, ad, similar content, audience exchange…)
As usual all comments are welcome.

Updated version (1.1) is here: https://github.com/Podcastindex-org/podcast-namespace/blob/main/proposal-docs/recommendations/recommendations.md

@daveajones
Copy link
Contributor

Looks good. Will read through today.

@ablekirby
Copy link

GJ Benjamin!

I'm endorsing this tag for phase 4 because I think it's necessary to make the podcast namespace viable to use in a decentralized music back end. Sound data (mp3) is only one part of what a modern music app needs. Relational data about artists (influences, contemporaries, associated acts...) cluster them into scenes (ex: portland folk scene) is also needed to get good (or even plausible) UX.

Basically, If we decentralize the sound data then the metadata must be decentralized with it, and that is what this proposal does.

@daveajones
Copy link
Contributor

I’ll be writing up phase 4 at the end of this month. I’m down with this. I’ll put it in the readme and we can hammer it out.

@benjaminbellamy
Copy link
Contributor Author

I just added some final corrections:
https://github.com/benjaminbellamy/podcast-namespace/blob/patch-13/proposal-docs/recommendations/recommendations.md

@daveajones
Copy link
Contributor

Merged.

@jamescridland
Copy link
Contributor

The proposal at #447 seems more elegant: just a comma-separated list of GUIDs. I don't quite understand the benefit of an external JSON file here.

@theDanielJLewis
Copy link

I agree that podcast GUIDs would be better. However, I'm thinking having multiple instances of this would allow for more flexibility, like being able to say something about the recommendation. For example:

<podcast:recommendation label="My clean-comedy podcast">guid…</podcast:recommendation>
<podcast:recommendation label="Hear me regularly on Podcasters' Roundtable" website="https://podcastersroundtable.com">guid…</podcast:recommendation>

@benjaminbellamy
Copy link
Contributor Author

The proposal at #447 seems more elegant: just a comma-separated list of GUIDs. I don't quite understand the benefit of an external JSON file here.

  • Having an external file allows the use of external recommendation service providers
  • It's easier when you want to update recommendations (for instance when a new episode is recommended on an old one, you would not have to update the rss for the old one, nor would you have to parse it again. On the other hand, you can just launch a HEAD http query on the external json to see if it was updated)

@adamc199
Copy link

  • Having an external file allows the use of external recommendation service providers
  • It's easier when you want to update recommendations (for instance when a new episode is recommended on an old one, you would not have to update the rss for the old one, nor would you have to parse it again. On the other hand, you can just launch a HEAD http query on the external json to see if it was updated)

I agree with external file being important for external services or audience produced recommendations.

Just as important as external chapters and transcripts.

@theDanielJLewis
Copy link

I can see that, too. If recommending on the episode level, this would be perfect to include in the episode metadata file (item incorrectly called a “chapters file”).

But speaking of chapters, would you still think this best to be an episode-level option instead of being inside richer chapters (#400)?

@X-Cli
Copy link

X-Cli commented Oct 15, 2024

Just a quick note that I appreciate that tag (syntax, structure, using an external JSON file, all of it) and I added support for it in my feed generator (using Hugo). I would love to see it more widely adopted.

My use case is that I record episodes about information security and I want to provide links and sources for my listeners to learn more about the topics I discuss. Show notes are unstructured, timecodes are not well integrated, and max length is an issue. My average blog post contains 30 to 50 links. My episodes should contain about the same amount of links.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

10 participants