mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-22 00:07:52 +01:00
174 lines
5.0 KiB
JavaScript
174 lines
5.0 KiB
JavaScript
const uuidv4 = require("uuid").v4
|
|
const Folder = require('./Folder')
|
|
const LibrarySettings = require('./settings/LibrarySettings')
|
|
const { filePathToPOSIX } = require('../utils/fileUtils')
|
|
|
|
class Library {
|
|
constructor(library = null) {
|
|
this.id = null
|
|
this.oldLibraryId = null // TODO: Temp
|
|
this.name = null
|
|
this.folders = []
|
|
this.displayOrder = 1
|
|
this.icon = 'database'
|
|
this.mediaType = 'book' // book, podcast
|
|
this.provider = 'google'
|
|
|
|
this.lastScan = 0
|
|
this.settings = null
|
|
|
|
this.createdAt = null
|
|
this.lastUpdate = null
|
|
|
|
if (library) {
|
|
this.construct(library)
|
|
}
|
|
}
|
|
|
|
get folderPaths() {
|
|
return this.folders.map(f => f.fullPath)
|
|
}
|
|
get isPodcast() {
|
|
return this.mediaType === 'podcast'
|
|
}
|
|
get isMusic() {
|
|
return this.mediaType === 'music'
|
|
}
|
|
get isBook() {
|
|
return this.mediaType === 'book'
|
|
}
|
|
|
|
construct(library) {
|
|
this.id = library.id
|
|
this.oldLibraryId = library.oldLibraryId
|
|
this.name = library.name
|
|
this.folders = (library.folders || []).map(f => new Folder(f))
|
|
this.displayOrder = library.displayOrder || 1
|
|
this.icon = library.icon || 'database'
|
|
this.mediaType = library.mediaType
|
|
this.provider = library.provider || 'google'
|
|
|
|
this.settings = new LibrarySettings(library.settings)
|
|
if (library.settings === undefined) { // LibrarySettings added in v2, migrate settings
|
|
this.settings.disableWatcher = !!library.disableWatcher
|
|
}
|
|
|
|
this.createdAt = library.createdAt
|
|
this.lastUpdate = library.lastUpdate
|
|
this.cleanOldValues() // mediaType changed for v2 and icon change for v2.2.2
|
|
}
|
|
|
|
cleanOldValues() {
|
|
const availableIcons = ['database', 'audiobookshelf', 'books-1', 'books-2', 'book-1', 'microphone-1', 'microphone-3', 'radio', 'podcast', 'rss', 'headphones', 'music', 'file-picture', 'rocket', 'power', 'star', 'heart']
|
|
if (!availableIcons.includes(this.icon)) {
|
|
if (this.icon === 'audiobook') this.icon = 'audiobookshelf'
|
|
else if (this.icon === 'book') this.icon = 'books-1'
|
|
else if (this.icon === 'comic') this.icon = 'file-picture'
|
|
else this.icon = 'database'
|
|
}
|
|
|
|
const mediaTypes = ['podcast', 'book', 'video', 'music']
|
|
if (!this.mediaType || !mediaTypes.includes(this.mediaType)) {
|
|
this.mediaType = 'book'
|
|
}
|
|
}
|
|
|
|
toJSON() {
|
|
return {
|
|
id: this.id,
|
|
oldLibraryId: this.oldLibraryId,
|
|
name: this.name,
|
|
folders: (this.folders || []).map(f => f.toJSON()),
|
|
displayOrder: this.displayOrder,
|
|
icon: this.icon,
|
|
mediaType: this.mediaType,
|
|
provider: this.provider,
|
|
settings: this.settings.toJSON(),
|
|
createdAt: this.createdAt,
|
|
lastUpdate: this.lastUpdate
|
|
}
|
|
}
|
|
|
|
setData(data) {
|
|
this.id = data.id || uuidv4()
|
|
this.name = data.name
|
|
if (data.folder) {
|
|
this.folders = [
|
|
new Folder(data.folder)
|
|
]
|
|
} else if (data.folders) {
|
|
this.folders = data.folders.map(folder => {
|
|
var newFolder = new Folder()
|
|
newFolder.setData({
|
|
fullPath: folder.fullPath,
|
|
libraryId: this.id
|
|
})
|
|
return newFolder
|
|
})
|
|
}
|
|
this.displayOrder = data.displayOrder || 1
|
|
this.icon = data.icon || 'database'
|
|
this.mediaType = data.mediaType || 'book'
|
|
this.provider = data.provider || 'google'
|
|
this.settings = new LibrarySettings(data.settings)
|
|
this.createdAt = Date.now()
|
|
this.lastUpdate = Date.now()
|
|
}
|
|
|
|
update(payload) {
|
|
let hasUpdates = false
|
|
|
|
const keysToCheck = ['name', 'provider', 'mediaType', 'icon']
|
|
keysToCheck.forEach((key) => {
|
|
if (payload[key] && payload[key] !== this[key]) {
|
|
this[key] = payload[key]
|
|
hasUpdates = true
|
|
}
|
|
})
|
|
|
|
if (payload.settings && this.settings.update(payload.settings)) {
|
|
hasUpdates = true
|
|
}
|
|
|
|
if (!isNaN(payload.displayOrder) && payload.displayOrder !== this.displayOrder) {
|
|
this.displayOrder = Number(payload.displayOrder)
|
|
hasUpdates = true
|
|
}
|
|
if (payload.folders) {
|
|
const newFolders = payload.folders.filter(f => !f.id)
|
|
const removedFolders = this.folders.filter(f => !payload.folders.some(_f => _f.id === f.id))
|
|
|
|
if (removedFolders.length) {
|
|
const removedFolderIds = removedFolders.map(f => f.id)
|
|
this.folders = this.folders.filter(f => !removedFolderIds.includes(f.id))
|
|
}
|
|
|
|
if (newFolders.length) {
|
|
newFolders.forEach((folderData) => {
|
|
folderData.libraryId = this.id
|
|
const newFolder = new Folder()
|
|
newFolder.setData(folderData)
|
|
this.folders.push(newFolder)
|
|
})
|
|
}
|
|
|
|
if (newFolders.length || removedFolders.length) {
|
|
hasUpdates = true
|
|
}
|
|
}
|
|
if (hasUpdates) {
|
|
this.lastUpdate = Date.now()
|
|
}
|
|
return hasUpdates
|
|
}
|
|
|
|
checkFullPathInLibrary(fullPath) {
|
|
fullPath = filePathToPOSIX(fullPath)
|
|
return this.folders.find(folder => fullPath.startsWith(filePathToPOSIX(folder.fullPath)))
|
|
}
|
|
|
|
getFolderById(id) {
|
|
return this.folders.find(folder => folder.id === id)
|
|
}
|
|
}
|
|
module.exports = Library |