mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-22 00:07:52 +01:00
Fix:Scanner overwriting metadata when metadata file is not stored with items #2155
This commit is contained in:
parent
ed82a5aa19
commit
98ed2e01cc
@ -168,9 +168,7 @@ class BookScanner {
|
|||||||
hasMediaChanges = true
|
hasMediaChanges = true
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: When metadata file is stored in /metadata/items/{libraryItemId}.[abs|json] we should load this
|
const bookMetadata = await this.getBookMetadataFromScanData(media.audioFiles, libraryItemData, libraryScan, existingLibraryItem.id)
|
||||||
// TODO: store an additional array of metadata keys that the user has changed manually so we know what not to override
|
|
||||||
const bookMetadata = await this.getBookMetadataFromScanData(media.audioFiles, libraryItemData, libraryScan)
|
|
||||||
let authorsUpdated = false
|
let authorsUpdated = false
|
||||||
const bookAuthorsRemoved = []
|
const bookAuthorsRemoved = []
|
||||||
let seriesUpdated = false
|
let seriesUpdated = false
|
||||||
@ -550,9 +548,10 @@ class BookScanner {
|
|||||||
* @param {import('../models/Book').AudioFileObject[]} audioFiles
|
* @param {import('../models/Book').AudioFileObject[]} audioFiles
|
||||||
* @param {import('./LibraryItemScanData')} libraryItemData
|
* @param {import('./LibraryItemScanData')} libraryItemData
|
||||||
* @param {LibraryScan} libraryScan
|
* @param {LibraryScan} libraryScan
|
||||||
|
* @param {string} [existingLibraryItemId]
|
||||||
* @returns {Promise<BookMetadataObject>}
|
* @returns {Promise<BookMetadataObject>}
|
||||||
*/
|
*/
|
||||||
async getBookMetadataFromScanData(audioFiles, libraryItemData, libraryScan) {
|
async getBookMetadataFromScanData(audioFiles, libraryItemData, libraryScan, existingLibraryItemId = null) {
|
||||||
// First set book metadata from folder/file names
|
// First set book metadata from folder/file names
|
||||||
const bookMetadata = {
|
const bookMetadata = {
|
||||||
title: libraryItemData.mediaMetadata.title,
|
title: libraryItemData.mediaMetadata.title,
|
||||||
@ -722,11 +721,31 @@ class BookScanner {
|
|||||||
|
|
||||||
// If metadata.json or metadata.abs use this for metadata
|
// If metadata.json or metadata.abs use this for metadata
|
||||||
const metadataLibraryFile = libraryItemData.metadataJsonLibraryFile || libraryItemData.metadataAbsLibraryFile
|
const metadataLibraryFile = libraryItemData.metadataJsonLibraryFile || libraryItemData.metadataAbsLibraryFile
|
||||||
const metadataText = metadataLibraryFile ? await readTextFile(metadataLibraryFile.metadata.path) : null
|
let metadataText = metadataLibraryFile ? await readTextFile(metadataLibraryFile.metadata.path) : null
|
||||||
|
let metadataFilePath = metadataLibraryFile?.metadata.path
|
||||||
|
let metadataFileFormat = libraryItemData.metadataJsonLibraryFile ? 'json' : 'abs'
|
||||||
|
|
||||||
|
// When metadata file is not stored with library item then check in the /metadata/items folder for it
|
||||||
|
if (!metadataText && existingLibraryItemId) {
|
||||||
|
let metadataPath = Path.join(global.MetadataPath, 'items', existingLibraryItemId)
|
||||||
|
|
||||||
|
let altFormat = global.ServerSettings.metadataFileFormat === 'json' ? 'abs' : 'json'
|
||||||
|
// First check the metadata format set in server settings, fallback to the alternate
|
||||||
|
metadataFilePath = Path.join(metadataPath, `metadata.${global.ServerSettings.metadataFileFormat}`)
|
||||||
|
metadataFileFormat = global.ServerSettings.metadataFileFormat
|
||||||
|
if (await fsExtra.pathExists(metadataFilePath)) {
|
||||||
|
metadataText = await readTextFile(metadataFilePath)
|
||||||
|
} else if (await fsExtra.pathExists(Path.join(metadataPath, `metadata.${altFormat}`))) {
|
||||||
|
metadataFilePath = Path.join(metadataPath, `metadata.${altFormat}`)
|
||||||
|
metadataFileFormat = altFormat
|
||||||
|
metadataText = await readTextFile(metadataFilePath)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (metadataText) {
|
if (metadataText) {
|
||||||
libraryScan.addLog(LogLevel.INFO, `Found metadata file "${metadataLibraryFile.metadata.path}" - preferring`)
|
libraryScan.addLog(LogLevel.INFO, `Found metadata file "${metadataFilePath}" - preferring`)
|
||||||
let abMetadata = null
|
let abMetadata = null
|
||||||
if (!!libraryItemData.metadataJsonLibraryFile) {
|
if (metadataFileFormat === 'json') {
|
||||||
abMetadata = abmetadataGenerator.parseJson(metadataText)
|
abMetadata = abmetadataGenerator.parseJson(metadataText)
|
||||||
} else {
|
} else {
|
||||||
abMetadata = abmetadataGenerator.parse(metadataText, 'book')
|
abMetadata = abmetadataGenerator.parse(metadataText, 'book')
|
||||||
|
@ -145,8 +145,7 @@ class PodcastScanner {
|
|||||||
hasMediaChanges = true
|
hasMediaChanges = true
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: When metadata file is stored in /metadata/items/{libraryItemId}.[abs|json] we should load this
|
const podcastMetadata = await this.getPodcastMetadataFromScanData(existingPodcastEpisodes, libraryItemData, libraryScan, existingLibraryItem.id)
|
||||||
const podcastMetadata = await this.getPodcastMetadataFromScanData(existingPodcastEpisodes, libraryItemData, libraryScan)
|
|
||||||
|
|
||||||
for (const key in podcastMetadata) {
|
for (const key in podcastMetadata) {
|
||||||
// Ignore unset metadata and empty arrays
|
// Ignore unset metadata and empty arrays
|
||||||
@ -312,9 +311,10 @@ class PodcastScanner {
|
|||||||
* @param {PodcastEpisode[]} podcastEpisodes Not the models for new podcasts
|
* @param {PodcastEpisode[]} podcastEpisodes Not the models for new podcasts
|
||||||
* @param {import('./LibraryItemScanData')} libraryItemData
|
* @param {import('./LibraryItemScanData')} libraryItemData
|
||||||
* @param {import('./LibraryScan')} libraryScan
|
* @param {import('./LibraryScan')} libraryScan
|
||||||
|
* @param {string} [existingLibraryItemId]
|
||||||
* @returns {Promise<PodcastMetadataObject>}
|
* @returns {Promise<PodcastMetadataObject>}
|
||||||
*/
|
*/
|
||||||
async getPodcastMetadataFromScanData(podcastEpisodes, libraryItemData, libraryScan) {
|
async getPodcastMetadataFromScanData(podcastEpisodes, libraryItemData, libraryScan, existingLibraryItemId = null) {
|
||||||
const podcastMetadata = {
|
const podcastMetadata = {
|
||||||
title: libraryItemData.mediaMetadata.title,
|
title: libraryItemData.mediaMetadata.title,
|
||||||
titleIgnorePrefix: getTitleIgnorePrefix(libraryItemData.mediaMetadata.title),
|
titleIgnorePrefix: getTitleIgnorePrefix(libraryItemData.mediaMetadata.title),
|
||||||
@ -389,11 +389,31 @@ class PodcastScanner {
|
|||||||
|
|
||||||
// If metadata.json or metadata.abs use this for metadata
|
// If metadata.json or metadata.abs use this for metadata
|
||||||
const metadataLibraryFile = libraryItemData.metadataJsonLibraryFile || libraryItemData.metadataAbsLibraryFile
|
const metadataLibraryFile = libraryItemData.metadataJsonLibraryFile || libraryItemData.metadataAbsLibraryFile
|
||||||
const metadataText = metadataLibraryFile ? await readTextFile(metadataLibraryFile.metadata.path) : null
|
let metadataText = metadataLibraryFile ? await readTextFile(metadataLibraryFile.metadata.path) : null
|
||||||
|
let metadataFilePath = metadataLibraryFile?.metadata.path
|
||||||
|
let metadataFileFormat = libraryItemData.metadataJsonLibraryFile ? 'json' : 'abs'
|
||||||
|
|
||||||
|
// When metadata file is not stored with library item then check in the /metadata/items folder for it
|
||||||
|
if (!metadataText && existingLibraryItemId) {
|
||||||
|
let metadataPath = Path.join(global.MetadataPath, 'items', existingLibraryItemId)
|
||||||
|
|
||||||
|
let altFormat = global.ServerSettings.metadataFileFormat === 'json' ? 'abs' : 'json'
|
||||||
|
// First check the metadata format set in server settings, fallback to the alternate
|
||||||
|
metadataFilePath = Path.join(metadataPath, `metadata.${global.ServerSettings.metadataFileFormat}`)
|
||||||
|
metadataFileFormat = global.ServerSettings.metadataFileFormat
|
||||||
|
if (await fsExtra.pathExists(metadataFilePath)) {
|
||||||
|
metadataText = await readTextFile(metadataFilePath)
|
||||||
|
} else if (await fsExtra.pathExists(Path.join(metadataPath, `metadata.${altFormat}`))) {
|
||||||
|
metadataFilePath = Path.join(metadataPath, `metadata.${altFormat}`)
|
||||||
|
metadataFileFormat = altFormat
|
||||||
|
metadataText = await readTextFile(metadataFilePath)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (metadataText) {
|
if (metadataText) {
|
||||||
libraryScan.addLog(LogLevel.INFO, `Found metadata file "${metadataLibraryFile.metadata.path}" - preferring`)
|
libraryScan.addLog(LogLevel.INFO, `Found metadata file "${metadataFilePath}" - preferring`)
|
||||||
let abMetadata = null
|
let abMetadata = null
|
||||||
if (!!libraryItemData.metadataJsonLibraryFile) {
|
if (metadataFileFormat === 'json') {
|
||||||
abMetadata = abmetadataGenerator.parseJson(metadataText)
|
abMetadata = abmetadataGenerator.parseJson(metadataText)
|
||||||
} else {
|
} else {
|
||||||
abMetadata = abmetadataGenerator.parse(metadataText, 'podcast')
|
abMetadata = abmetadataGenerator.parse(metadataText, 'podcast')
|
||||||
|
Loading…
Reference in New Issue
Block a user