Add:Delete playback session button and api route

This commit is contained in:
advplyr 2022-08-13 12:24:19 -05:00
parent 1ad9ea92b6
commit 0c5db214d1
6 changed files with 94 additions and 21 deletions

View File

@ -1,5 +1,5 @@
<template> <template>
<modals-modal v-model="show" name="listening-session-modal" :width="700" :height="'unset'"> <modals-modal v-model="show" name="listening-session-modal" :processing="processing" :width="700" :height="'unset'">
<template #outer> <template #outer>
<div class="absolute top-0 left-0 p-5 w-2/3 overflow-hidden"> <div class="absolute top-0 left-0 p-5 w-2/3 overflow-hidden">
<p class="font-book text-3xl text-white truncate">Session {{ _session.id }}</p> <p class="font-book text-3xl text-white truncate">Session {{ _session.id }}</p>
@ -96,6 +96,10 @@
<p v-if="deviceInfo.deviceType" class="mb-1">Type: {{ deviceInfo.deviceType }}</p> <p v-if="deviceInfo.deviceType" class="mb-1">Type: {{ deviceInfo.deviceType }}</p>
</div> </div>
</div> </div>
<div class="flex items-center">
<ui-btn small color="error" @click.stop="deleteSessionClick">Delete</ui-btn>
</div>
</div> </div>
</modals-modal> </modals-modal>
</template> </template>
@ -110,7 +114,9 @@ export default {
} }
}, },
data() { data() {
return {} return {
processing: false
}
}, },
computed: { computed: {
show: { show: {
@ -147,7 +153,37 @@ export default {
return 'Unknown' return 'Unknown'
} }
}, },
methods: {}, methods: {
deleteSessionClick() {
const payload = {
message: `Are you sure you want to delete this session?`,
callback: (confirmed) => {
if (confirmed) {
this.deleteSession()
}
},
type: 'yesNo'
}
this.$store.commit('globals/setConfirmPrompt', payload)
},
deleteSession() {
this.processing = true
this.$axios
.$delete(`/api/sessions/${this._session.id}`)
.then(() => {
this.processing = false
this.$toast.success('Session deleted successfully')
this.$emit('removedSession')
this.show = false
})
.catch((error) => {
this.processing = false
console.error('Failed to delete session', error)
var errMsg = error.response ? error.response.data || '' : ''
this.$toast.error(errMsg || 'Failed to delete session')
})
}
},
mounted() {} mounted() {}
} }
</script> </script>

View File

@ -58,7 +58,7 @@
<p v-else class="text-white text-opacity-50">No sessions yet...</p> <p v-else class="text-white text-opacity-50">No sessions yet...</p>
</div> </div>
<modals-listening-session-modal v-model="showSessionModal" :session="selectedSession" /> <modals-listening-session-modal v-model="showSessionModal" :session="selectedSession" @removedSession="removedSession" />
</div> </div>
</template> </template>
@ -111,6 +111,9 @@ export default {
} }
}, },
methods: { methods: {
removedSession() {
this.loadSessions(this.currentPage)
},
async clickCurrentTime(session) { async clickCurrentTime(session) {
if (this.processingGoToTimestamp) return if (this.processingGoToTimestamp) return
this.processingGoToTimestamp = true this.processingGoToTimestamp = true

View File

@ -62,7 +62,7 @@
</div> </div>
</div> </div>
<modals-listening-session-modal v-model="showSessionModal" :session="selectedSession" /> <modals-listening-session-modal v-model="showSessionModal" :session="selectedSession" @removedSession="removedSession" />
</div> </div>
</template> </template>
@ -98,6 +98,9 @@ export default {
} }
}, },
methods: { methods: {
removedSession() {
this.loadSessions(this.currentPage)
},
async clickCurrentTime(session) { async clickCurrentTime(session) {
if (this.processingGoToTimestamp) return if (this.processingGoToTimestamp) return
this.processingGoToTimestamp = true this.processingGoToTimestamp = true

View File

@ -183,17 +183,6 @@ class Db {
getLibraryItemsInLibrary(libraryId) { getLibraryItemsInLibrary(libraryId) {
return this.libraryItems.filter(li => li.libraryId === libraryId) return this.libraryItems.filter(li => li.libraryId === libraryId)
} }
getPlaybackSession(id) {
return this.sessionsDb.select((pb) => pb.id == id).then((results) => {
if (results.data.length) {
return new PlaybackSession(results.data[0])
}
return null
}).catch((error) => {
Logger.error('Failed to get session', error)
return null
})
}
async updateLibraryItem(libraryItem) { async updateLibraryItem(libraryItem) {
return this.updateLibraryItems([libraryItem]) return this.updateLibraryItems([libraryItem])
@ -452,6 +441,18 @@ class Db {
}) })
} }
getPlaybackSession(id) {
return this.sessionsDb.select((pb) => pb.id == id).then((results) => {
if (results.data.length) {
return new PlaybackSession(results.data[0])
}
return null
}).catch((error) => {
Logger.error('Failed to get session', error)
return null
})
}
selectUserSessions(userId) { selectUserSessions(userId) {
return this.sessionsDb.select((session) => session.userId === userId).then((results) => { return this.sessionsDb.select((session) => session.userId === userId).then((results) => {
return results.data || [] return results.data || []

View File

@ -42,7 +42,7 @@ class SessionController {
res.json(payload) res.json(payload)
} }
getSession(req, res) { getOpenSession(req, res) {
var libraryItem = this.db.getLibraryItem(req.session.libraryItemId) var libraryItem = this.db.getLibraryItem(req.session.libraryItemId)
var sessionForClient = req.session.toJSONForClient(libraryItem) var sessionForClient = req.session.toJSONForClient(libraryItem)
res.json(sessionForClient) res.json(sessionForClient)
@ -58,12 +58,24 @@ class SessionController {
this.playbackSessionManager.closeSessionRequest(req.user, req.session, req.body, res) this.playbackSessionManager.closeSessionRequest(req.user, req.session, req.body, res)
} }
// DELETE: api/session/:id
async delete(req, res) {
// if session is open then remove it
const openSession = this.playbackSessionManager.getSession(req.session.id)
if (openSession) {
await this.playbackSessionManager.removeSession(req.session.id)
}
await this.db.removeEntity('session', req.session.id)
res.sendStatus(200)
}
// POST: api/session/local // POST: api/session/local
syncLocal(req, res) { syncLocal(req, res) {
this.playbackSessionManager.syncLocalSessionRequest(req.user, req.body, res) this.playbackSessionManager.syncLocalSessionRequest(req.user, req.body, res)
} }
middleware(req, res, next) { openSessionMiddleware(req, res, next) {
var playbackSession = this.playbackSessionManager.getSession(req.params.id) var playbackSession = this.playbackSessionManager.getSession(req.params.id)
if (!playbackSession) return res.sendStatus(404) if (!playbackSession) return res.sendStatus(404)
@ -75,5 +87,21 @@ class SessionController {
req.session = playbackSession req.session = playbackSession
next() next()
} }
async middleware(req, res, next) {
var playbackSession = await this.db.getPlaybackSession(req.params.id)
if (!playbackSession) return res.sendStatus(404)
if (req.method == 'DELETE' && !req.user.canDelete) {
Logger.warn(`[SessionController] User attempted to delete without permission`, req.user)
return res.sendStatus(403)
} else if ((req.method == 'PATCH' || req.method == 'POST') && !req.user.canUpdate) {
Logger.warn('[SessionController] User attempted to update without permission', req.user.username)
return res.sendStatus(403)
}
req.session = playbackSession
next()
}
} }
module.exports = new SessionController() module.exports = new SessionController()

View File

@ -175,9 +175,11 @@ class ApiRouter {
// Playback Session Routes // Playback Session Routes
// //
this.router.get('/sessions', SessionController.getAllWithUserData.bind(this)) this.router.get('/sessions', SessionController.getAllWithUserData.bind(this))
this.router.get('/session/:id', SessionController.middleware.bind(this), SessionController.getSession.bind(this)) this.router.delete('/sessions/:id', SessionController.middleware.bind(this), SessionController.delete.bind(this))
this.router.post('/session/:id/sync', SessionController.middleware.bind(this), SessionController.sync.bind(this)) // TODO: Update these endpoints because they are only for open playback sessions
this.router.post('/session/:id/close', SessionController.middleware.bind(this), SessionController.close.bind(this)) this.router.get('/session/:id', SessionController.openSessionMiddleware.bind(this), SessionController.getOpenSession.bind(this))
this.router.post('/session/:id/sync', SessionController.openSessionMiddleware.bind(this), SessionController.sync.bind(this))
this.router.post('/session/:id/close', SessionController.openSessionMiddleware.bind(this), SessionController.close.bind(this))
this.router.post('/session/local', SessionController.syncLocal.bind(this)) this.router.post('/session/local', SessionController.syncLocal.bind(this))
// //