From 557d3243c3e4d14a0af11efb3f50fab79a82cb75 Mon Sep 17 00:00:00 2001 From: advplyr Date: Sun, 5 Mar 2023 15:26:18 -0600 Subject: [PATCH] Fix:Series & collection rss feeds repeating first book #1531 --- server/objects/Feed.js | 1 + server/objects/FeedEpisode.js | 17 ++++++++++------- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/server/objects/Feed.js b/server/objects/Feed.js index 0e67df8d..10d6d282 100644 --- a/server/objects/Feed.js +++ b/server/objects/Feed.js @@ -77,6 +77,7 @@ class Feed { getEpisodePath(id) { var episode = this.episodes.find(ep => ep.id === id) + console.log('getEpisodePath=', id, episode) if (!episode) return null return episode.fullPath } diff --git a/server/objects/FeedEpisode.js b/server/objects/FeedEpisode.js index 65395f04..0f5ac28c 100644 --- a/server/objects/FeedEpisode.js +++ b/server/objects/FeedEpisode.js @@ -95,19 +95,22 @@ class FeedEpisode { this.fullPath = episode.audioFile.metadata.path } - setFromAudiobookTrack(libraryItem, serverAddress, slug, audioTrack, meta, additionalOffset = 0) { + setFromAudiobookTrack(libraryItem, serverAddress, slug, audioTrack, meta, additionalOffset = null) { // Example: Fri, 04 Feb 2015 00:00:00 GMT let timeOffset = isNaN(audioTrack.index) ? 0 : (Number(audioTrack.index) * 1000) // Offset pubdate to ensure correct order + let episodeId = String(audioTrack.index) // Additional offset can be used for collections/series - if (additionalOffset && !isNaN(additionalOffset)) { + if (additionalOffset !== null && !isNaN(additionalOffset)) { timeOffset += Number(additionalOffset) * 1000 + + episodeId = String(additionalOffset) + '-' + episodeId } // e.g. Track 1 will have a pub date before Track 2 const audiobookPubDate = date.format(new Date(libraryItem.addedAt + timeOffset), 'ddd, DD MMM YYYY HH:mm:ss [GMT]') - const contentUrl = `/feed/${slug}/item/${audioTrack.index}/${audioTrack.metadata.filename}` + const contentUrl = `/feed/${slug}/item/${episodeId}/${audioTrack.metadata.filename}` const media = libraryItem.media const mediaMetadata = media.metadata @@ -122,7 +125,7 @@ class FeedEpisode { } } - this.id = String(audioTrack.index) + this.id = episodeId this.title = title this.description = mediaMetadata.description || '' this.enclosure = { @@ -157,9 +160,9 @@ class FeedEpisode { { "itunes:explicit": !!this.explicit }, - {"itunes:episodeType": this.episodeType}, - {"itunes:season": this.season}, - {"itunes:episode": this.episode} + { "itunes:episodeType": this.episodeType }, + { "itunes:season": this.season }, + { "itunes:episode": this.episode } ] } }