Skip to content

Commit

Permalink
Fix empty podcast and empty book queries when cleaning db on init
Browse files Browse the repository at this point in the history
  • Loading branch information
advplyr committed Sep 17, 2023
1 parent 3ad4f05 commit 87eaace
Showing 1 changed file with 15 additions and 9 deletions.
24 changes: 15 additions & 9 deletions server/Database.js
Original file line number Diff line number Diff line change
Expand Up @@ -666,7 +666,11 @@ class Database {
async cleanDatabase() {
// Remove invalid Podcast records
const podcastsWithNoLibraryItem = await this.podcastModel.findAll({
where: Sequelize.where(Sequelize.literal(`(SELECT count(*) FROM libraryItems li WHERE li.mediaId = podcast.id)`), 0)
include: {
model: this.libraryItemModel,
required: false
},
where: { '$libraryItem.id$': null }
})
for (const podcast of podcastsWithNoLibraryItem) {
Logger.warn(`Found podcast "${podcast.title}" with no libraryItem - removing it`)
Expand All @@ -675,7 +679,11 @@ class Database {

// Remove invalid Book records
const booksWithNoLibraryItem = await this.bookModel.findAll({
where: Sequelize.where(Sequelize.literal(`(SELECT count(*) FROM libraryItems li WHERE li.mediaId = book.id)`), 0)
include: {
model: this.libraryItemModel,
required: false
},
where: { '$libraryItem.id$': null }
})
for (const book of booksWithNoLibraryItem) {
Logger.warn(`Found book "${book.title}" with no libraryItem - removing it`)
Expand All @@ -684,13 +692,11 @@ class Database {

// Remove empty series
const emptySeries = await this.seriesModel.findAll({
include: [
{
model: this.bookSeriesModel,
required: false
}
],
where:{ '$bookSeries.id$': null }
include: {
model: this.bookSeriesModel,
required: false
},
where: { '$bookSeries.id$': null }
})
for (const series of emptySeries) {
Logger.warn(`Found series "${series.name}" with no books - removing it`)
Expand Down

0 comments on commit 87eaace

Please sign in to comment.