feat: Add 'Write Metadata Files' button to Library Tools modal

This commit is contained in:
Tiberiu Ichim 2026-02-20 20:26:33 +02:00
parent a73ce12945
commit b5caadd4c2
5 changed files with 99 additions and 1 deletions

View file

@ -1575,6 +1575,56 @@ class LibraryController {
}
}
/**
* POST: /api/libraries/:id/write-metadata-files
* Write metadata.json files for all items in library that don't already have one
*
* @param {LibraryControllerRequest} req
* @param {Response} res
*/
async writeMetadataFiles(req, res) {
if (!req.user.isAdminOrUp) {
Logger.error(`[LibraryController] Non-admin user "${req.user.username}" attempted to write metadata files`)
return res.sendStatus(403)
}
const absMetadataMigration = require('../utils/migrations/absMetadataMigration')
Logger.info(`[LibraryController] Writing metadata files for library "${req.library.name}"`)
let created = 0
let skipped = 0
let failed = 0
let offset = 0
const batchSize = 500
// eslint-disable-next-line no-constant-condition
while (true) {
const libraryItems = await Database.libraryItemModel.getLibraryItemsIncrement(offset, batchSize, {
libraryId: req.library.id,
isMissing: false
})
if (!libraryItems.length) break
for (const libraryItem of libraryItems) {
const result = await absMetadataMigration.writeMetadataFileForItem(libraryItem)
if (result === null) {
skipped++ // Already existed
} else if (result === false) {
failed++
} else {
created++
}
}
if (libraryItems.length < batchSize) break
offset += libraryItems.length
}
Logger.info(`[LibraryController] Finished writing metadata files for library "${req.library.name}" (created=${created}, skipped=${skipped}, failed=${failed})`)
res.json({ created, skipped, failed })
}
/**
*
* @param {RequestWithUser} req

View file

@ -96,6 +96,7 @@ class ApiRouter {
this.router.post('/libraries/:id/remove-metadata', LibraryController.middleware.bind(this), LibraryController.removeAllMetadataFiles.bind(this))
this.router.post('/libraries/:id/update-consolidation', LibraryController.middleware.bind(this), LibraryController.updateConsolidationStatus.bind(this))
this.router.post('/libraries/:id/update-cover-dimensions', LibraryController.middleware.bind(this), LibraryController.updateCoverDimensions.bind(this))
this.router.post('/libraries/:id/write-metadata-files', LibraryController.middleware.bind(this), LibraryController.writeMetadataFiles.bind(this))
this.router.get('/libraries/:id/podcast-titles', LibraryController.middleware.bind(this), LibraryController.getPodcastTitles.bind(this))
this.router.get('/libraries/:id/download', LibraryController.middleware.bind(this), LibraryController.downloadMultiple.bind(this))

View file

@ -90,4 +90,6 @@ module.exports.migrate = async (Database) => {
Logger.info(`[absMetadataMigration] Starting metadata.json migration`)
const totalCreated = await runMigration(Database)
Logger.info(`[absMetadataMigration] Finished metadata.json migration (${totalCreated} files created)`)
}
}
module.exports.writeMetadataFileForItem = writeMetadataFileForItem