mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-25 15:52:26 -04:00 
			
		
		
		
	Merge pull request #3867 from advplyr/feed_generator_updates
Updates to generated RSS feed & Fix series/collection feeds
This commit is contained in:
		
						commit
						24ce4a208d
					
				| @ -561,7 +561,42 @@ class Feed extends Model { | |||||||
|    * @param {string} hostPrefix |    * @param {string} hostPrefix | ||||||
|    */ |    */ | ||||||
|   buildXml(hostPrefix) { |   buildXml(hostPrefix) { | ||||||
|     const blockTags = [{ 'itunes:block': 'yes' }, { 'googleplay:block': 'yes' }] |     const customElements = [ | ||||||
|  |       { language: this.language || 'en' }, | ||||||
|  |       { author: this.author || 'advplyr' }, | ||||||
|  |       { 'itunes:author': this.author || 'advplyr' }, | ||||||
|  |       { 'itunes:type': this.podcastType || 'serial' }, | ||||||
|  |       { | ||||||
|  |         'itunes:image': { | ||||||
|  |           _attr: { | ||||||
|  |             href: `${hostPrefix}${this.imageURL}` | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       }, | ||||||
|  |       { 'itunes:explicit': !!this.explicit } | ||||||
|  |     ] | ||||||
|  | 
 | ||||||
|  |     if (this.description) { | ||||||
|  |       customElements.push({ 'itunes:summary': { _cdata: this.description } }) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     const itunesOwnersData = [] | ||||||
|  |     if (this.ownerName || this.author) { | ||||||
|  |       itunesOwnersData.push({ 'itunes:name': this.ownerName || this.author }) | ||||||
|  |     } | ||||||
|  |     if (this.ownerEmail) { | ||||||
|  |       itunesOwnersData.push({ 'itunes:email': this.ownerEmail }) | ||||||
|  |     } | ||||||
|  |     if (itunesOwnersData.length) { | ||||||
|  |       customElements.push({ | ||||||
|  |         'itunes:owner': itunesOwnersData | ||||||
|  |       }) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (this.preventIndexing) { | ||||||
|  |       customElements.push({ 'itunes:block': 'yes' }, { 'googleplay:block': 'yes' }) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     const rssData = { |     const rssData = { | ||||||
|       title: this.title, |       title: this.title, | ||||||
|       description: this.description || '', |       description: this.description || '', | ||||||
| @ -571,29 +606,10 @@ class Feed extends Model { | |||||||
|       image_url: `${hostPrefix}${this.imageURL}`, |       image_url: `${hostPrefix}${this.imageURL}`, | ||||||
|       custom_namespaces: { |       custom_namespaces: { | ||||||
|         itunes: 'http://www.itunes.com/dtds/podcast-1.0.dtd', |         itunes: 'http://www.itunes.com/dtds/podcast-1.0.dtd', | ||||||
|         psc: 'http://podlove.org/simple-chapters', |  | ||||||
|         podcast: 'https://podcastindex.org/namespace/1.0', |         podcast: 'https://podcastindex.org/namespace/1.0', | ||||||
|         googleplay: 'http://www.google.com/schemas/play-podcasts/1.0' |         googleplay: 'http://www.google.com/schemas/play-podcasts/1.0' | ||||||
|       }, |       }, | ||||||
|       custom_elements: [ |       custom_elements: customElements | ||||||
|         { language: this.language || 'en' }, |  | ||||||
|         { author: this.author || 'advplyr' }, |  | ||||||
|         { 'itunes:author': this.author || 'advplyr' }, |  | ||||||
|         { 'itunes:summary': this.description || '' }, |  | ||||||
|         { 'itunes:type': this.podcastType }, |  | ||||||
|         { |  | ||||||
|           'itunes:image': { |  | ||||||
|             _attr: { |  | ||||||
|               href: `${hostPrefix}${this.imageURL}` |  | ||||||
|             } |  | ||||||
|           } |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|           'itunes:owner': [{ 'itunes:name': this.ownerName || this.author || '' }, { 'itunes:email': this.ownerEmail || '' }] |  | ||||||
|         }, |  | ||||||
|         { 'itunes:explicit': !!this.explicit }, |  | ||||||
|         ...(this.preventIndexing ? blockTags : []) |  | ||||||
|       ] |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const rssfeed = new RSS(rssData) |     const rssfeed = new RSS(rssData) | ||||||
|  | |||||||
| @ -220,7 +220,7 @@ class FeedEpisode extends Model { | |||||||
|     const feedEpisodeObjs = [] |     const feedEpisodeObjs = [] | ||||||
|     let numExisting = 0 |     let numExisting = 0 | ||||||
|     for (const book of books) { |     for (const book of books) { | ||||||
|       const trackList = book.libraryItem.getTrackList() |       const trackList = book.getTracklist(book.libraryItem.id) | ||||||
|       const useChapterTitles = this.checkUseChapterTitlesForEpisodes(trackList, book) |       const useChapterTitles = this.checkUseChapterTitlesForEpisodes(trackList, book) | ||||||
|       for (const track of trackList) { |       for (const track of trackList) { | ||||||
|         // Check for existing episode by filepath
 |         // Check for existing episode by filepath
 | ||||||
| @ -305,6 +305,23 @@ class FeedEpisode extends Model { | |||||||
|    * @param {string} hostPrefix |    * @param {string} hostPrefix | ||||||
|    */ |    */ | ||||||
|   getRSSData(hostPrefix) { |   getRSSData(hostPrefix) { | ||||||
|  |     const customElements = [ | ||||||
|  |       { 'itunes:author': this.author || null }, | ||||||
|  |       { 'itunes:duration': Math.round(Number(this.duration)) }, | ||||||
|  |       { | ||||||
|  |         'itunes:explicit': !!this.explicit | ||||||
|  |       }, | ||||||
|  |       { 'itunes:episodeType': this.episodeType || null }, | ||||||
|  |       { 'itunes:season': this.season || null }, | ||||||
|  |       { 'itunes:episode': this.episode || null } | ||||||
|  |     ].filter((element) => { | ||||||
|  |       // Remove empty custom elements
 | ||||||
|  |       return Object.values(element)[0] !== null | ||||||
|  |     }) | ||||||
|  |     if (this.description) { | ||||||
|  |       customElements.push({ 'itunes:summary': { _cdata: this.description } }) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     return { |     return { | ||||||
|       title: this.title, |       title: this.title, | ||||||
|       description: this.description || '', |       description: this.description || '', | ||||||
| @ -317,17 +334,7 @@ class FeedEpisode extends Model { | |||||||
|         type: this.enclosureType, |         type: this.enclosureType, | ||||||
|         size: this.enclosureSize |         size: this.enclosureSize | ||||||
|       }, |       }, | ||||||
|       custom_elements: [ |       custom_elements: customElements | ||||||
|         { 'itunes:author': this.author }, |  | ||||||
|         { 'itunes:duration': secondsToTimestamp(this.duration) }, |  | ||||||
|         { 'itunes:summary': this.description || '' }, |  | ||||||
|         { |  | ||||||
|           'itunes:explicit': !!this.explicit |  | ||||||
|         }, |  | ||||||
|         { 'itunes:episodeType': this.episodeType }, |  | ||||||
|         { 'itunes:season': this.season }, |  | ||||||
|         { 'itunes:episode': this.episode } |  | ||||||
|       ] |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -112,7 +112,7 @@ function secondsToTimestamp(seconds, includeMs = false, alwaysIncludeHours = fal | |||||||
|   var ms = _seconds - Math.floor(seconds) |   var ms = _seconds - Math.floor(seconds) | ||||||
|   _seconds = Math.floor(_seconds) |   _seconds = Math.floor(_seconds) | ||||||
| 
 | 
 | ||||||
|   var msString = '.' + (includeMs ? ms.toFixed(3) : '0.0').split('.')[1] |   const msString = includeMs ? '.' + ms.toFixed(3).split('.')[1] : '' | ||||||
|   if (alwaysIncludeHours) { |   if (alwaysIncludeHours) { | ||||||
|     return `${_hours.toString().padStart(2, '0')}:${_minutes.toString().padStart(2, '0')}:${_seconds.toString().padStart(2, '0')}${msString}` |     return `${_hours.toString().padStart(2, '0')}:${_minutes.toString().padStart(2, '0')}:${_seconds.toString().padStart(2, '0')}${msString}` | ||||||
|   } |   } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user