Add:forceRescan rescans existing audio files,Fix:False positives for if an audio file was updated

This commit is contained in:
advplyr 2021-12-05 11:29:42 -06:00
parent 040548c6db
commit 975984e8d1
5 changed files with 50 additions and 24 deletions

View File

@ -96,9 +96,9 @@ class AudioFile {
this.exclude = !!data.exclude this.exclude = !!data.exclude
this.error = data.error || null this.error = data.error || null
this.trackNumFromMeta = data.trackNumFromMeta || null this.trackNumFromMeta = data.trackNumFromMeta
this.trackNumFromFilename = data.trackNumFromFilename || null this.trackNumFromFilename = data.trackNumFromFilename
this.cdNumFromFilename = data.cdNumFromFilename || null this.cdNumFromFilename = data.cdNumFromFilename
this.format = data.format this.format = data.format
this.duration = data.duration this.duration = data.duration
@ -130,9 +130,9 @@ class AudioFile {
this.fullPath = data.fullPath this.fullPath = data.fullPath
this.addedAt = Date.now() this.addedAt = Date.now()
this.trackNumFromMeta = data.trackNumFromMeta || null this.trackNumFromMeta = data.trackNumFromMeta
this.trackNumFromFilename = data.trackNumFromFilename || null this.trackNumFromFilename = data.trackNumFromFilename
this.cdNumFromFilename = data.cdNumFromFilename || null this.cdNumFromFilename = data.cdNumFromFilename
this.manuallyVerified = !!data.manuallyVerified this.manuallyVerified = !!data.manuallyVerified
this.invalid = !!data.invalid this.invalid = !!data.invalid
@ -302,9 +302,9 @@ class AudioFile {
hasUpdated = true hasUpdated = true
} }
} else if (this[key] !== newjson[key]) { } else if (this[key] !== newjson[key]) {
// console.log(this.filename, 'key', key, 'updated', this[key], newjson[key])
this[key] = newjson[key] this[key] = newjson[key]
hasUpdated = true hasUpdated = true
// console.log('key', key, 'updated', this[key], newjson[key])
} }
} }
return hasUpdated return hasUpdated

View File

@ -542,10 +542,9 @@ class Audiobook {
var alreadyHasDescTxt = otherFilenamesAlreadyInBook.includes('desc.txt') var alreadyHasDescTxt = otherFilenamesAlreadyInBook.includes('desc.txt')
var alreadyHasReaderTxt = otherFilenamesAlreadyInBook.includes('reader.txt') var alreadyHasReaderTxt = otherFilenamesAlreadyInBook.includes('reader.txt')
// Filter out other files no longer in directory
var newOtherFilePaths = newOtherFiles.map(f => f.path) var newOtherFilePaths = newOtherFiles.map(f => f.path)
this.otherFiles = this.otherFiles.filter(f => newOtherFilePaths.includes(f.path)) this.otherFiles = this.otherFiles.filter(f => newOtherFilePaths.includes(f.path))
// Some files are not there anymore and filtered out
if (currOtherFileNum !== this.otherFiles.length) { if (currOtherFileNum !== this.otherFiles.length) {
Logger.debug(`[Audiobook] ${currOtherFileNum - this.otherFiles.length} other files were removed for "${this.title}"`) Logger.debug(`[Audiobook] ${currOtherFileNum - this.otherFiles.length} other files were removed for "${this.title}"`)
hasUpdates = true hasUpdates = true
@ -937,6 +936,8 @@ class Audiobook {
var newAudioFileData = [] var newAudioFileData = []
var newOtherFileData = [] var newOtherFileData = []
var existingAudioFileData = []
var existingOtherFileData = []
dataFound.audioFiles.forEach((af) => { dataFound.audioFiles.forEach((af) => {
var audioFileFoundCheck = this.checkFileFound(af, true) var audioFileFoundCheck = this.checkFileFound(af, true)
@ -944,6 +945,9 @@ class Audiobook {
newAudioFileData.push(af) newAudioFileData.push(af)
} else if (audioFileFoundCheck) { } else if (audioFileFoundCheck) {
hasUpdated = true hasUpdated = true
existingAudioFileData.push(af)
} else {
existingAudioFileData.push(af)
} }
}) })
@ -953,6 +957,9 @@ class Audiobook {
newOtherFileData.push(otherFileData) newOtherFileData.push(otherFileData)
} else if (fileFoundCheck) { } else if (fileFoundCheck) {
hasUpdated = true hasUpdated = true
existingOtherFileData.push(otherFileData)
} else {
existingOtherFileData.push(otherFileData)
} }
}) })
@ -1010,7 +1017,9 @@ class Audiobook {
newAudioFileData, newAudioFileData,
newOtherFileData, newOtherFileData,
audioFilesRemoved, audioFilesRemoved,
otherFilesRemoved otherFilesRemoved,
existingAudioFileData, // Existing file data may get re-scanned if forceRescan is set
existingOtherFileData
} }
} }
} }

View File

@ -139,12 +139,10 @@ class AudioFileScanner {
} }
if (existingAF) { if (existingAF) {
if (audiobook.updateAudioFile(newAF)) { if (audiobook.updateAudioFile(newAF)) {
// console.log('update dauido file')
hasUpdated = true hasUpdated = true
} }
} else { } else {
audiobook.addAudioFile(newAF) audiobook.addAudioFile(newAF)
// console.log('added auido file')
hasUpdated = true hasUpdated = true
} }
} }

View File

@ -35,7 +35,7 @@ class AudioProbeData {
setData(data) { setData(data) {
var audioStream = this.getDefaultAudioStream(data.audio_streams) var audioStream = this.getDefaultAudioStream(data.audio_streams)
this.embeddedCoverArt = data.video_stream ? this.getEmbeddedCoverArt(data.video_stream) : false this.embeddedCoverArt = data.video_stream ? this.getEmbeddedCoverArt(data.video_stream) : null
this.format = data.format this.format = data.format
this.duration = data.duration this.duration = data.duration
this.size = data.size this.size = data.size

View File

@ -305,10 +305,12 @@ class Scanner {
return this.rescanAudiobook(abd, libraryScan) return this.rescanAudiobook(abd, libraryScan)
})) }))
audiobooksUpdated = audiobooksUpdated.filter(ab => ab) // Filter out nulls audiobooksUpdated = audiobooksUpdated.filter(ab => ab) // Filter out nulls
if (audiobooksUpdated.length) {
libraryScan.resultsUpdated += audiobooksUpdated.length libraryScan.resultsUpdated += audiobooksUpdated.length
await this.db.updateEntities('audiobook', audiobooksUpdated) await this.db.updateEntities('audiobook', audiobooksUpdated)
this.emitter('audiobooks_updated', audiobooksUpdated.map(ab => ab.toJSONExpanded())) this.emitter('audiobooks_updated', audiobooksUpdated.map(ab => ab.toJSONExpanded()))
} }
}
async scanNewAudiobookDataChunk(newAudiobookDataToScan, libraryScan) { async scanNewAudiobookDataChunk(newAudiobookDataToScan, libraryScan) {
var newAudiobooks = await Promise.all(newAudiobookDataToScan.map((abd) => { var newAudiobooks = await Promise.all(newAudiobookDataToScan.map((abd) => {
@ -321,24 +323,38 @@ class Scanner {
} }
async rescanAudiobook(audiobookCheckData, libraryScan) { async rescanAudiobook(audiobookCheckData, libraryScan) {
const { newAudioFileData, newOtherFileData, audiobook, bookScanData } = audiobookCheckData const { newAudioFileData, newOtherFileData, audiobook, bookScanData, updated, existingAudioFileData, existingOtherFileData } = audiobookCheckData
libraryScan.addLog(LogLevel.DEBUG, `Library "${libraryScan.libraryName}" Re-scanning "${audiobook.path}"`) libraryScan.addLog(LogLevel.DEBUG, `Library "${libraryScan.libraryName}" Re-scanning "${audiobook.path}"`)
var hasUpdated = updated
// Sync other files first to use local images as cover before extracting audio file cover // Sync other files first to use local images as cover before extracting audio file cover
if (newOtherFileData.length || libraryScan.scanOptions.forceRescan) { if (newOtherFileData.length || libraryScan.scanOptions.forceRescan) {
// TODO: Cleanup other file sync // TODO: Cleanup other file sync
var allOtherFiles = newOtherFileData.concat(audiobook._otherFiles) var allOtherFiles = newOtherFileData.concat(existingOtherFileData)
await audiobook.syncOtherFiles(allOtherFiles, this.MetadataPath, libraryScan.preferOpfMetadata) if (await audiobook.syncOtherFiles(allOtherFiles, this.MetadataPath, libraryScan.preferOpfMetadata)) {
hasUpdated = true
}
} }
// forceRescan all existing audio files - will probe and update ID3 tag metadata
if (libraryScan.scanOptions.forceRescan && existingAudioFileData.length) {
if (await AudioFileScanner.scanAudioFiles(existingAudioFileData, bookScanData, audiobook, libraryScan.preferAudioMetadata, libraryScan)) {
hasUpdated = true
}
}
// Scan new audio files
if (newAudioFileData.length) {
if (await AudioFileScanner.scanAudioFiles(newAudioFileData, bookScanData, audiobook, libraryScan.preferAudioMetadata, libraryScan)) {
hasUpdated = true
}
}
// If an audio file has embedded cover art and no cover is set yet, extract & use it
if (newAudioFileData.length || libraryScan.scanOptions.forceRescan) { if (newAudioFileData.length || libraryScan.scanOptions.forceRescan) {
await AudioFileScanner.scanAudioFiles(newAudioFileData, bookScanData, audiobook, libraryScan.preferAudioMetadata, libraryScan)
// Extract embedded cover art if cover is not already in directory
if (audiobook.hasEmbeddedCoverArt && !audiobook.cover) { if (audiobook.hasEmbeddedCoverArt && !audiobook.cover) {
var outputCoverDirs = this.getCoverDirectory(audiobook) var outputCoverDirs = this.getCoverDirectory(audiobook)
var relativeDir = await audiobook.saveEmbeddedCoverArt(outputCoverDirs.fullPath, outputCoverDirs.relPath) var relativeDir = await audiobook.saveEmbeddedCoverArt(outputCoverDirs.fullPath, outputCoverDirs.relPath)
if (relativeDir) { if (relativeDir) {
hasUpdated = true
libraryScan.addLog(LogLevel.DEBUG, `Saved embedded cover art "${relativeDir}"`) libraryScan.addLog(LogLevel.DEBUG, `Saved embedded cover art "${relativeDir}"`)
} }
} }
@ -346,17 +362,20 @@ class Scanner {
if (!audiobook.audioFilesToInclude.length && !audiobook.ebooks.length) { // Audiobook is invalid if (!audiobook.audioFilesToInclude.length && !audiobook.ebooks.length) { // Audiobook is invalid
audiobook.setInvalid() audiobook.setInvalid()
hasUpdated = true
} else if (audiobook.isInvalid) { } else if (audiobook.isInvalid) {
audiobook.isInvalid = false audiobook.isInvalid = false
hasUpdated = true
} }
// Scan for cover if enabled and has no cover // Scan for cover if enabled and has no cover (and author or title has changed OR has been 7 days since last lookup)
if (audiobook && libraryScan.findCovers && !audiobook.cover && audiobook.book.shouldSearchForCover) { if (audiobook && libraryScan.findCovers && !audiobook.cover && audiobook.book.shouldSearchForCover) {
var updatedCover = await this.searchForCover(audiobook, libraryScan) var updatedCover = await this.searchForCover(audiobook, libraryScan)
audiobook.book.updateLastCoverSearch(updatedCover) audiobook.book.updateLastCoverSearch(updatedCover)
hasUpdated = true
} }
return audiobook return hasUpdated ? audiobook : null
} }
async scanNewAudiobook(audiobookData, preferAudioMetadata, preferOpfMetadata, findCovers, libraryScan = null) { async scanNewAudiobook(audiobookData, preferAudioMetadata, preferOpfMetadata, findCovers, libraryScan = null) {