mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-04 21:20:09 +01:00
Merge branch 'advplyr:master' into seekback-support
This commit is contained in:
commit
28b1132171
@ -178,6 +178,7 @@ export default {
|
|||||||
this.$store.commit('users/updateUser', user)
|
this.$store.commit('users/updateUser', user)
|
||||||
},
|
},
|
||||||
currentUserAudiobookUpdate(payload) {
|
currentUserAudiobookUpdate(payload) {
|
||||||
|
// console.log('Received user audiobook update', payload)
|
||||||
this.$store.commit('user/updateUserAudiobook', payload)
|
this.$store.commit('user/updateUserAudiobook', payload)
|
||||||
},
|
},
|
||||||
downloadToastClick(download) {
|
downloadToastClick(download) {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "audiobookshelf-client",
|
"name": "audiobookshelf-client",
|
||||||
"version": "1.5.2",
|
"version": "1.5.3",
|
||||||
"description": "Audiobook manager and player",
|
"description": "Audiobook manager and player",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "audiobookshelf",
|
"name": "audiobookshelf",
|
||||||
"version": "1.5.2",
|
"version": "1.5.3",
|
||||||
"description": "Self-hosted audiobook server for managing and playing audiobooks",
|
"description": "Self-hosted audiobook server for managing and playing audiobooks",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
@ -46,7 +46,7 @@ class Server {
|
|||||||
this.watcher = new Watcher(this.AudiobookPath)
|
this.watcher = new Watcher(this.AudiobookPath)
|
||||||
this.coverController = new CoverController(this.db, this.MetadataPath, this.AudiobookPath)
|
this.coverController = new CoverController(this.db, this.MetadataPath, this.AudiobookPath)
|
||||||
this.scanner = new Scanner(this.AudiobookPath, this.MetadataPath, this.db, this.coverController, this.emitter.bind(this))
|
this.scanner = new Scanner(this.AudiobookPath, this.MetadataPath, this.db, this.coverController, this.emitter.bind(this))
|
||||||
this.streamManager = new StreamManager(this.db, this.MetadataPath, this.emitter.bind(this))
|
this.streamManager = new StreamManager(this.db, this.MetadataPath, this.emitter.bind(this), this.clientEmitter.bind(this))
|
||||||
this.rssFeeds = new RssFeeds(this.Port, this.db)
|
this.rssFeeds = new RssFeeds(this.Port, this.db)
|
||||||
this.downloadManager = new DownloadManager(this.db, this.MetadataPath, this.AudiobookPath, this.emitter.bind(this))
|
this.downloadManager = new DownloadManager(this.db, this.MetadataPath, this.AudiobookPath, this.emitter.bind(this))
|
||||||
this.apiController = new ApiController(this.MetadataPath, this.db, this.scanner, this.auth, this.streamManager, this.rssFeeds, this.downloadManager, this.coverController, this.backupManager, this.watcher, this.emitter.bind(this), this.clientEmitter.bind(this))
|
this.apiController = new ApiController(this.MetadataPath, this.db, this.scanner, this.auth, this.streamManager, this.rssFeeds, this.downloadManager, this.coverController, this.backupManager, this.watcher, this.emitter.bind(this), this.clientEmitter.bind(this))
|
||||||
@ -453,18 +453,23 @@ class Server {
|
|||||||
res.sendStatus(200)
|
res.sendStatus(200)
|
||||||
}
|
}
|
||||||
|
|
||||||
audiobookProgressUpdate(socket, progressPayload) {
|
async audiobookProgressUpdate(socket, progressPayload) {
|
||||||
var client = socket.sheepClient
|
var client = socket.sheepClient
|
||||||
if (!client || !client.user) {
|
if (!client || !client.user) {
|
||||||
Logger.error('[Server] audiobookProgressUpdate invalid socket client')
|
Logger.error('[Server] audiobookProgressUpdate invalid socket client')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
var hasUpdates = client.user.updateAudiobookProgress(progressPayload.audiobookId, progressPayload)
|
var audiobookProgress = client.user.updateAudiobookProgress(progressPayload.audiobookId, progressPayload)
|
||||||
if (hasUpdates) {
|
if (audiobookProgress) {
|
||||||
var userAudiobook = client.user.getAudiobookJSON(progressPayload.audiobookId)
|
await this.db.updateEntity('user', client.user)
|
||||||
socket.emit('current_user_audiobook_update', {
|
|
||||||
|
// This audiobook progress is out of date, why?
|
||||||
|
// var userAudiobook = client.user.getAudiobookJSON(progressPayload.audiobookId)
|
||||||
|
// Logger.debug(`[Server] Emitting audiobook progress update to clients ${this.getClientsForUser(client.user.id).length}: ${JSON.stringify(userAudiobook)}`)
|
||||||
|
|
||||||
|
this.clientEmitter(client.user.id, 'current_user_audiobook_update', {
|
||||||
id: progressPayload.audiobookId,
|
id: progressPayload.audiobookId,
|
||||||
data: userAudiobook || null
|
data: audiobookProgress || null
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -478,8 +483,9 @@ class Server {
|
|||||||
var userAudiobook = client.user.createBookmark(payload)
|
var userAudiobook = client.user.createBookmark(payload)
|
||||||
if (userAudiobook) {
|
if (userAudiobook) {
|
||||||
await this.db.updateEntity('user', client.user)
|
await this.db.updateEntity('user', client.user)
|
||||||
socket.emit('bookmark_created', payload.time)
|
|
||||||
socket.emit('current_user_audiobook_update', {
|
this.clientEmitter(client.user.id, 'bookmark_created', payload.time)
|
||||||
|
this.clientEmitter(client.user.id, 'current_user_audiobook_update', {
|
||||||
id: userAudiobook.audiobookId,
|
id: userAudiobook.audiobookId,
|
||||||
data: userAudiobook || null
|
data: userAudiobook || null
|
||||||
})
|
})
|
||||||
|
@ -5,10 +5,11 @@ const fs = require('fs-extra')
|
|||||||
const Path = require('path')
|
const Path = require('path')
|
||||||
|
|
||||||
class StreamManager {
|
class StreamManager {
|
||||||
constructor(db, MetadataPath, emitter) {
|
constructor(db, MetadataPath, emitter, clientEmitter) {
|
||||||
this.db = db
|
this.db = db
|
||||||
|
|
||||||
this.emitter = emitter
|
this.emitter = emitter
|
||||||
|
this.clientEmitter = clientEmitter
|
||||||
|
|
||||||
this.MetadataPath = MetadataPath
|
this.MetadataPath = MetadataPath
|
||||||
this.streams = []
|
this.streams = []
|
||||||
@ -157,7 +158,7 @@ class StreamManager {
|
|||||||
this.db.updateEntity('user', client.user)
|
this.db.updateEntity('user', client.user)
|
||||||
|
|
||||||
if (userAudiobook) {
|
if (userAudiobook) {
|
||||||
socket.emit('current_user_audiobook_update', {
|
this.clientEmitter(client.user.id, 'current_user_audiobook_update', {
|
||||||
id: userAudiobook.audiobookId,
|
id: userAudiobook.audiobookId,
|
||||||
data: userAudiobook.toJSON()
|
data: userAudiobook.toJSON()
|
||||||
})
|
})
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
const Logger = require('../Logger')
|
||||||
const AudioBookmark = require('./AudioBookmark')
|
const AudioBookmark = require('./AudioBookmark')
|
||||||
|
|
||||||
class AudiobookProgress {
|
class AudiobookProgress {
|
||||||
@ -79,6 +80,7 @@ class AudiobookProgress {
|
|||||||
|
|
||||||
update(payload) {
|
update(payload) {
|
||||||
var hasUpdates = false
|
var hasUpdates = false
|
||||||
|
Logger.debug(`[AudiobookProgress] Update called ${JSON.stringify(payload)}`)
|
||||||
for (const key in payload) {
|
for (const key in payload) {
|
||||||
if (payload[key] !== this[key]) {
|
if (payload[key] !== this[key]) {
|
||||||
if (key === 'isRead') {
|
if (key === 'isRead') {
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
const Logger = require('../Logger')
|
||||||
const AudiobookProgress = require('./AudiobookProgress')
|
const AudiobookProgress = require('./AudiobookProgress')
|
||||||
|
|
||||||
class User {
|
class User {
|
||||||
@ -212,7 +213,12 @@ class User {
|
|||||||
this.audiobooks[audiobook.id] = new AudiobookProgress()
|
this.audiobooks[audiobook.id] = new AudiobookProgress()
|
||||||
this.audiobooks[audiobook.id].audiobookId = audiobook.id
|
this.audiobooks[audiobook.id].audiobookId = audiobook.id
|
||||||
}
|
}
|
||||||
return this.audiobooks[audiobook.id].update(updatePayload)
|
var wasUpdated = this.audiobooks[audiobook.id].update(updatePayload)
|
||||||
|
if (wasUpdated) {
|
||||||
|
Logger.debug(`[User] Audiobook progress was updated ${JSON.stringify(this.audiobooks[audiobook.id])}`)
|
||||||
|
return this.audiobooks[audiobook.id]
|
||||||
|
}
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns Boolean If update was made
|
// Returns Boolean If update was made
|
||||||
|
Loading…
Reference in New Issue
Block a user