2022-03-18 01:10:47 +01:00
|
|
|
const Logger = require('../Logger')
|
2023-07-05 01:14:44 +02:00
|
|
|
const Database = require('../Database')
|
2022-06-04 19:44:42 +02:00
|
|
|
const { toNumber } = require('../utils/index')
|
2022-03-18 01:10:47 +01:00
|
|
|
|
|
|
|
class SessionController {
|
|
|
|
constructor() { }
|
|
|
|
|
|
|
|
async findOne(req, res) {
|
|
|
|
return res.json(req.session)
|
|
|
|
}
|
|
|
|
|
2022-06-04 19:44:42 +02:00
|
|
|
async getAllWithUserData(req, res) {
|
|
|
|
if (!req.user.isAdminOrUp) {
|
|
|
|
Logger.error(`[SessionController] getAllWithUserData: Non-admin user requested all session data ${req.user.id}/"${req.user.username}"`)
|
|
|
|
return res.sendStatus(404)
|
|
|
|
}
|
|
|
|
|
2023-04-09 01:01:24 +02:00
|
|
|
let listeningSessions = []
|
2022-06-04 19:44:42 +02:00
|
|
|
if (req.query.user) {
|
|
|
|
listeningSessions = await this.getUserListeningSessionsHelper(req.query.user)
|
|
|
|
} else {
|
|
|
|
listeningSessions = await this.getAllSessionsWithUserData()
|
|
|
|
}
|
|
|
|
|
|
|
|
const itemsPerPage = toNumber(req.query.itemsPerPage, 10) || 10
|
|
|
|
const page = toNumber(req.query.page, 0)
|
|
|
|
|
|
|
|
const start = page * itemsPerPage
|
|
|
|
const sessions = listeningSessions.slice(start, start + itemsPerPage)
|
|
|
|
|
|
|
|
const payload = {
|
|
|
|
total: listeningSessions.length,
|
|
|
|
numPages: Math.ceil(listeningSessions.length / itemsPerPage),
|
|
|
|
page,
|
|
|
|
itemsPerPage,
|
|
|
|
sessions
|
|
|
|
}
|
|
|
|
|
|
|
|
if (req.query.user) {
|
|
|
|
payload.userFilter = req.query.user
|
|
|
|
}
|
|
|
|
|
|
|
|
res.json(payload)
|
|
|
|
}
|
|
|
|
|
2023-07-22 22:32:20 +02:00
|
|
|
async getOpenSessions(req, res) {
|
2023-04-09 01:01:24 +02:00
|
|
|
if (!req.user.isAdminOrUp) {
|
|
|
|
Logger.error(`[SessionController] getOpenSessions: Non-admin user requested open session data ${req.user.id}/"${req.user.username}"`)
|
|
|
|
return res.sendStatus(404)
|
|
|
|
}
|
|
|
|
|
2023-07-22 22:32:20 +02:00
|
|
|
const minifiedUserObjects = await Database.models.user.getMinifiedUserObjects()
|
2023-04-09 01:01:24 +02:00
|
|
|
const openSessions = this.playbackSessionManager.sessions.map(se => {
|
|
|
|
return {
|
|
|
|
...se.toJSON(),
|
2023-07-22 22:32:20 +02:00
|
|
|
user: minifiedUserObjects.find(u => u.id === se.userId) || null
|
2023-04-09 01:01:24 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
res.json({
|
|
|
|
sessions: openSessions
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-08-13 19:24:19 +02:00
|
|
|
getOpenSession(req, res) {
|
2023-07-05 01:14:44 +02:00
|
|
|
var libraryItem = Database.getLibraryItem(req.session.libraryItemId)
|
2022-06-04 01:59:42 +02:00
|
|
|
var sessionForClient = req.session.toJSONForClient(libraryItem)
|
|
|
|
res.json(sessionForClient)
|
|
|
|
}
|
|
|
|
|
2022-03-18 01:10:47 +01:00
|
|
|
// POST: api/session/:id/sync
|
|
|
|
sync(req, res) {
|
|
|
|
this.playbackSessionManager.syncSessionRequest(req.user, req.session, req.body, res)
|
|
|
|
}
|
|
|
|
|
|
|
|
// POST: api/session/:id/close
|
|
|
|
close(req, res) {
|
2023-05-30 23:08:30 +02:00
|
|
|
let syncData = req.body
|
|
|
|
if (syncData && !Object.keys(syncData).length) syncData = null
|
|
|
|
this.playbackSessionManager.closeSessionRequest(req.user, req.session, syncData, res)
|
2022-03-18 01:10:47 +01:00
|
|
|
}
|
|
|
|
|
2022-08-13 19:24:19 +02:00
|
|
|
// 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)
|
|
|
|
}
|
|
|
|
|
2023-07-05 01:14:44 +02:00
|
|
|
await Database.removePlaybackSession(req.session.id)
|
2022-08-13 19:24:19 +02:00
|
|
|
res.sendStatus(200)
|
|
|
|
}
|
|
|
|
|
2022-04-10 00:56:51 +02:00
|
|
|
// POST: api/session/local
|
|
|
|
syncLocal(req, res) {
|
2023-07-16 22:05:51 +02:00
|
|
|
this.playbackSessionManager.syncLocalSessionRequest(req, res)
|
2022-04-10 00:56:51 +02:00
|
|
|
}
|
|
|
|
|
2023-02-05 23:52:17 +01:00
|
|
|
// POST: api/session/local-all
|
|
|
|
syncLocalSessions(req, res) {
|
|
|
|
this.playbackSessionManager.syncLocalSessionsRequest(req, res)
|
|
|
|
}
|
|
|
|
|
2022-08-13 19:24:19 +02:00
|
|
|
openSessionMiddleware(req, res, next) {
|
2022-03-18 01:10:47 +01:00
|
|
|
var playbackSession = this.playbackSessionManager.getSession(req.params.id)
|
|
|
|
if (!playbackSession) return res.sendStatus(404)
|
|
|
|
|
|
|
|
if (playbackSession.userId !== req.user.id) {
|
|
|
|
Logger.error(`[SessionController] User "${req.user.username}" attempting to access session belonging to another user "${req.params.id}"`)
|
|
|
|
return res.sendStatus(404)
|
|
|
|
}
|
|
|
|
|
|
|
|
req.session = playbackSession
|
|
|
|
next()
|
|
|
|
}
|
2022-08-13 19:24:19 +02:00
|
|
|
|
|
|
|
async middleware(req, res, next) {
|
2023-07-05 01:14:44 +02:00
|
|
|
const playbackSession = await Database.getPlaybackSession(req.params.id)
|
2023-02-02 23:24:34 +01:00
|
|
|
if (!playbackSession) {
|
|
|
|
Logger.error(`[SessionController] Unable to find playback session with id=${req.params.id}`)
|
|
|
|
return res.sendStatus(404)
|
|
|
|
}
|
2022-08-13 19:24:19 +02:00
|
|
|
|
|
|
|
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()
|
|
|
|
}
|
2022-03-18 01:10:47 +01:00
|
|
|
}
|
|
|
|
module.exports = new SessionController()
|