mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2026-03-02 22:19:40 +00:00
feat: Add 'Write Metadata Files' button to Library Tools modal
This commit is contained in:
parent
a73ce12945
commit
b5caadd4c2
5 changed files with 99 additions and 1 deletions
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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))
|
||||
|
||||
|
|
|
|||
|
|
@ -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
|
||||
Loading…
Add table
Add a link
Reference in a new issue