mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-02-06 00:16:02 +01:00
Add new api route for downloading backup, remove static metadata route
This commit is contained in:
parent
5b0d105e21
commit
aeba7674f8
@ -23,12 +23,13 @@
|
|||||||
<div class="w-full flex flex-row items-center justify-center">
|
<div class="w-full flex flex-row items-center justify-center">
|
||||||
<ui-btn v-if="backup.serverVersion" small color="primary" @click="applyBackup(backup)">{{ $strings.ButtonRestore }}</ui-btn>
|
<ui-btn v-if="backup.serverVersion" small color="primary" @click="applyBackup(backup)">{{ $strings.ButtonRestore }}</ui-btn>
|
||||||
|
|
||||||
<a v-if="backup.serverVersion" :href="`/metadata/${$encodeUriPath(backup.path)}?token=${userToken}`" class="mx-1 pt-1 hover:text-opacity-100 text-opacity-70 text-white" download><span class="material-icons text-xl">download</span></a>
|
<button v-if="backup.serverVersion" aria-label="Download Backup" class="inline-flex material-icons text-xl mx-1 mt-1 text-white/70 hover:text-white/100" @click.stop="downloadBackup(backup)">download</button>
|
||||||
|
|
||||||
<ui-tooltip v-else text="This backup was created with an old version of audiobookshelf no longer supported" direction="bottom" class="mx-2 flex items-center">
|
<ui-tooltip v-else text="This backup was created with an old version of audiobookshelf no longer supported" direction="bottom" class="mx-2 flex items-center">
|
||||||
<span class="material-icons-outlined text-2xl text-error">error_outline</span>
|
<span class="material-icons-outlined text-2xl text-error">error_outline</span>
|
||||||
</ui-tooltip>
|
</ui-tooltip>
|
||||||
|
|
||||||
<span class="material-icons text-xl hover:text-error hover:text-opacity-100 text-opacity-70 text-white cursor-pointer mx-1" @click="deleteBackupClick(backup)">delete</span>
|
<button v-if="backup.serverVersion" aria-label="Delete Backup" class="inline-flex material-icons text-xl mx-1 text-white/70 hover:text-error" @click="deleteBackupClick(backup)">delete</button>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -80,6 +81,9 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
downloadBackup(backup) {
|
||||||
|
this.$downloadFile(`${process.env.serverUrl}/api/backups/${backup.id}/download?token=${this.userToken}`)
|
||||||
|
},
|
||||||
confirm() {
|
confirm() {
|
||||||
this.showConfirmApply = false
|
this.showConfirmApply = false
|
||||||
|
|
||||||
|
@ -159,9 +159,6 @@ class Server {
|
|||||||
const distPath = Path.join(global.appRoot, '/client/dist')
|
const distPath = Path.join(global.appRoot, '/client/dist')
|
||||||
router.use(express.static(distPath))
|
router.use(express.static(distPath))
|
||||||
|
|
||||||
// Metadata folder static path
|
|
||||||
router.use('/metadata', this.authMiddleware.bind(this), express.static(global.MetadataPath))
|
|
||||||
|
|
||||||
// Static folder
|
// Static folder
|
||||||
router.use(express.static(Path.join(global.appRoot, 'static')))
|
router.use(express.static(Path.join(global.appRoot, 'static')))
|
||||||
|
|
||||||
|
@ -14,18 +14,14 @@ class BackupController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async delete(req, res) {
|
async delete(req, res) {
|
||||||
var backup = this.backupManager.backups.find(b => b.id === req.params.id)
|
await this.backupManager.removeBackup(req.backup)
|
||||||
if (!backup) {
|
|
||||||
return res.sendStatus(404)
|
|
||||||
}
|
|
||||||
await this.backupManager.removeBackup(backup)
|
|
||||||
|
|
||||||
res.json({
|
res.json({
|
||||||
backups: this.backupManager.backups.map(b => b.toJSON())
|
backups: this.backupManager.backups.map(b => b.toJSON())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
async upload(req, res) {
|
upload(req, res) {
|
||||||
if (!req.files.file) {
|
if (!req.files.file) {
|
||||||
Logger.error('[BackupController] Upload backup invalid')
|
Logger.error('[BackupController] Upload backup invalid')
|
||||||
return res.sendStatus(500)
|
return res.sendStatus(500)
|
||||||
@ -33,12 +29,22 @@ class BackupController {
|
|||||||
this.backupManager.uploadBackup(req, res)
|
this.backupManager.uploadBackup(req, res)
|
||||||
}
|
}
|
||||||
|
|
||||||
async apply(req, res) {
|
/**
|
||||||
var backup = this.backupManager.backups.find(b => b.id === req.params.id)
|
* api/backups/:id/download
|
||||||
if (!backup) {
|
*
|
||||||
return res.sendStatus(404)
|
* @param {*} req
|
||||||
|
* @param {*} res
|
||||||
|
*/
|
||||||
|
download(req, res) {
|
||||||
|
if (global.XAccel) {
|
||||||
|
Logger.debug(`Use X-Accel to serve static file ${req.backup.fullPath}`)
|
||||||
|
return res.status(204).header({ 'X-Accel-Redirect': global.XAccel + req.backup.fullPath }).send()
|
||||||
}
|
}
|
||||||
await this.backupManager.requestApplyBackup(backup)
|
res.sendFile(req.backup.fullPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
async apply(req, res) {
|
||||||
|
await this.backupManager.requestApplyBackup(req.backup)
|
||||||
res.sendStatus(200)
|
res.sendStatus(200)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,6 +53,14 @@ class BackupController {
|
|||||||
Logger.error(`[BackupController] Non-admin user attempting to access backups`, req.user)
|
Logger.error(`[BackupController] Non-admin user attempting to access backups`, req.user)
|
||||||
return res.sendStatus(403)
|
return res.sendStatus(403)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (req.params.id) {
|
||||||
|
req.backup = this.backupManager.backups.find(b => b.id === req.params.id)
|
||||||
|
if (!req.backup) {
|
||||||
|
return res.sendStatus(404)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
next()
|
next()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ class BackupManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async init() {
|
async init() {
|
||||||
var backupsDirExists = await fs.pathExists(this.BackupPath)
|
const backupsDirExists = await fs.pathExists(this.BackupPath)
|
||||||
if (!backupsDirExists) {
|
if (!backupsDirExists) {
|
||||||
await fs.ensureDir(this.BackupPath)
|
await fs.ensureDir(this.BackupPath)
|
||||||
await filePerms.setDefault(this.BackupPath)
|
await filePerms.setDefault(this.BackupPath)
|
||||||
|
@ -196,6 +196,7 @@ class ApiRouter {
|
|||||||
this.router.get('/backups', BackupController.middleware.bind(this), BackupController.getAll.bind(this))
|
this.router.get('/backups', BackupController.middleware.bind(this), BackupController.getAll.bind(this))
|
||||||
this.router.post('/backups', BackupController.middleware.bind(this), BackupController.create.bind(this))
|
this.router.post('/backups', BackupController.middleware.bind(this), BackupController.create.bind(this))
|
||||||
this.router.delete('/backups/:id', BackupController.middleware.bind(this), BackupController.delete.bind(this))
|
this.router.delete('/backups/:id', BackupController.middleware.bind(this), BackupController.delete.bind(this))
|
||||||
|
this.router.get('/backups/:id/download', BackupController.middleware.bind(this), BackupController.download.bind(this))
|
||||||
this.router.get('/backups/:id/apply', BackupController.middleware.bind(this), BackupController.apply.bind(this))
|
this.router.get('/backups/:id/apply', BackupController.middleware.bind(this), BackupController.apply.bind(this))
|
||||||
this.router.post('/backups/upload', BackupController.middleware.bind(this), BackupController.upload.bind(this))
|
this.router.post('/backups/upload', BackupController.middleware.bind(this), BackupController.upload.bind(this))
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user