Fix:Update author updatedAt when downloading new image, fixes author image refresh #2934

This commit is contained in:
advplyr 2024-05-06 17:17:35 -05:00
parent ce98bcc989
commit 941c798d78
4 changed files with 39 additions and 26 deletions

View File

@ -32,7 +32,6 @@ class AuthorController {
authorJson.libraryItems.forEach((li) => { authorJson.libraryItems.forEach((li) => {
if (li.media.metadata.series) { if (li.media.metadata.series) {
li.media.metadata.series.forEach((series) => { li.media.metadata.series.forEach((series) => {
const itemWithSeries = li.toJSONMinified() const itemWithSeries = li.toJSONMinified()
itemWithSeries.media.metadata.series = series itemWithSeries.media.metadata.series = series
@ -50,14 +49,14 @@ class AuthorController {
}) })
// Sort series items // Sort series items
for (const key in seriesMap) { for (const key in seriesMap) {
seriesMap[key].items = naturalSort(seriesMap[key].items).asc(li => li.media.metadata.series.sequence) seriesMap[key].items = naturalSort(seriesMap[key].items).asc((li) => li.media.metadata.series.sequence)
} }
authorJson.series = Object.values(seriesMap) authorJson.series = Object.values(seriesMap)
} }
// Minify library items // Minify library items
authorJson.libraryItems = authorJson.libraryItems.map(li => li.toJSONMinified()) authorJson.libraryItems = authorJson.libraryItems.map((li) => li.toJSONMinified())
} }
return res.json(authorJson) return res.json(authorJson)
@ -91,7 +90,8 @@ class AuthorController {
if (existingAuthor) { if (existingAuthor) {
const bookAuthorsToCreate = [] const bookAuthorsToCreate = []
const itemsWithAuthor = await Database.libraryItemModel.getForAuthor(req.author) const itemsWithAuthor = await Database.libraryItemModel.getForAuthor(req.author)
itemsWithAuthor.forEach(libraryItem => { // Replace old author with merging author for each book itemsWithAuthor.forEach((libraryItem) => {
// Replace old author with merging author for each book
libraryItem.media.metadata.replaceAuthor(req.author, existingAuthor) libraryItem.media.metadata.replaceAuthor(req.author, existingAuthor)
bookAuthorsToCreate.push({ bookAuthorsToCreate.push({
bookId: libraryItem.media.id, bookId: libraryItem.media.id,
@ -101,7 +101,10 @@ class AuthorController {
if (itemsWithAuthor.length) { if (itemsWithAuthor.length) {
await Database.removeBulkBookAuthors(req.author.id) // Remove all old BookAuthor await Database.removeBulkBookAuthors(req.author.id) // Remove all old BookAuthor
await Database.createBulkBookAuthors(bookAuthorsToCreate) // Create all new BookAuthor await Database.createBulkBookAuthors(bookAuthorsToCreate) // Create all new BookAuthor
SocketAuthority.emitter('items_updated', itemsWithAuthor.map(li => li.toJSONExpanded())) SocketAuthority.emitter(
'items_updated',
itemsWithAuthor.map((li) => li.toJSONExpanded())
)
} }
// Remove old author // Remove old author
@ -118,7 +121,8 @@ class AuthorController {
author: existingAuthor.toJSON(), author: existingAuthor.toJSON(),
merged: true merged: true
}) })
} else { // Regular author update } else {
// Regular author update
if (req.author.update(payload)) { if (req.author.update(payload)) {
hasUpdated = true hasUpdated = true
} }
@ -127,12 +131,16 @@ class AuthorController {
req.author.updatedAt = Date.now() req.author.updatedAt = Date.now()
const itemsWithAuthor = await Database.libraryItemModel.getForAuthor(req.author) const itemsWithAuthor = await Database.libraryItemModel.getForAuthor(req.author)
if (authorNameUpdate) { // Update author name on all books if (authorNameUpdate) {
itemsWithAuthor.forEach(libraryItem => { // Update author name on all books
itemsWithAuthor.forEach((libraryItem) => {
libraryItem.media.metadata.updateAuthor(req.author) libraryItem.media.metadata.updateAuthor(req.author)
}) })
if (itemsWithAuthor.length) { if (itemsWithAuthor.length) {
SocketAuthority.emitter('items_updated', itemsWithAuthor.map(li => li.toJSONExpanded())) SocketAuthority.emitter(
'items_updated',
itemsWithAuthor.map((li) => li.toJSONExpanded())
)
} }
} }
@ -206,6 +214,7 @@ class AuthorController {
} }
req.author.imagePath = result.path req.author.imagePath = result.path
req.author.updatedAt = Date.now()
await Database.authorModel.updateFromOld(req.author) await Database.authorModel.updateFromOld(req.author)
const numBooks = (await Database.libraryItemModel.getForAuthor(req.author)).length const numBooks = (await Database.libraryItemModel.getForAuthor(req.author)).length
@ -292,10 +301,14 @@ class AuthorController {
// GET api/authors/:id/image // GET api/authors/:id/image
async getImage(req, res) { async getImage(req, res) {
const { query: { width, height, format, raw }, author } = req const {
query: { width, height, format, raw },
author
} = req
if (raw) { // any value if (raw) {
if (!author.imagePath || !await fs.pathExists(author.imagePath)) { // any value
if (!author.imagePath || !(await fs.pathExists(author.imagePath))) {
return res.sendStatus(404) return res.sendStatus(404)
} }