mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01:00 
			
		
		
		
	Merge pull request #489 from selfhost-alt/configurable-backup-size
Make maximum backup size configurable
This commit is contained in:
		
						commit
						c5a9c2bf5a
					
				| @ -20,6 +20,14 @@ | ||||
|         <p class="pl-4 text-lg">Number of backups to keep</p> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="flex items-center py-2"> | ||||
|         <ui-text-input type="number" v-model="maxBackupSize" no-spinner :disabled="updatingServerSettings" :padding-x="1" text-center class="w-10" @change="updateBackupsSettings" /> | ||||
| 
 | ||||
|         <ui-tooltip :text="maxBackupSizeTooltip"> | ||||
|           <p class="pl-4 text-lg">Maximum backup size (in GB) <span class="material-icons icon-text">info_outlined</span></p> | ||||
|         </ui-tooltip> | ||||
|       </div> | ||||
| 
 | ||||
|       <tables-backups-table /> | ||||
|     </div> | ||||
|   </div> | ||||
| @ -32,6 +40,7 @@ export default { | ||||
|       updatingServerSettings: false, | ||||
|       dailyBackups: true, | ||||
|       backupsToKeep: 2, | ||||
|       maxBackupSize: 1, | ||||
|       newServerSettings: {} | ||||
|     } | ||||
|   }, | ||||
| @ -47,19 +56,27 @@ export default { | ||||
|     dailyBackupsTooltip() { | ||||
|       return 'Runs at 1am every day (your server time). Saved in /metadata/backups.' | ||||
|     }, | ||||
|     maxBackupSizeTooltip() { | ||||
|       return 'As a safeguard against misconfiguration, backups will fail if they exceed the configured size.' | ||||
|     }, | ||||
|     serverSettings() { | ||||
|       return this.$store.state.serverSettings | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     updateBackupsSettings() { | ||||
|       if (isNaN(this.maxBackupSize) || this.maxBackupSize <= 0) { | ||||
|         this.$toast.error('Invalid maximum backup size') | ||||
|         return | ||||
|       } | ||||
|       if (isNaN(this.backupsToKeep) || this.backupsToKeep <= 0 || this.backupsToKeep > 99) { | ||||
|         this.$toast.error('Invalid number of backups to keep') | ||||
|         return | ||||
|       } | ||||
|       var updatePayload = { | ||||
|         backupSchedule: this.dailyBackups ? '0 1 * * *' : false, | ||||
|         backupsToKeep: Number(this.backupsToKeep) | ||||
|         backupsToKeep: Number(this.backupsToKeep), | ||||
|         maxBackupSize: Number(this.maxBackupSize) | ||||
|       } | ||||
|       this.updateServerSettings(updatePayload) | ||||
|     }, | ||||
| @ -81,6 +98,7 @@ export default { | ||||
| 
 | ||||
|       this.backupsToKeep = this.newServerSettings.backupsToKeep || 2 | ||||
|       this.dailyBackups = !!this.newServerSettings.backupSchedule | ||||
|       this.maxBackupSize = this.newServerSettings.maxBackupSize || 1 | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|  | ||||
| @ -23,9 +23,6 @@ class BackupManager { | ||||
|     this.scheduleTask = null | ||||
| 
 | ||||
|     this.backups = [] | ||||
| 
 | ||||
|     // If backup exceeds this value it will be aborted
 | ||||
|     this.MaxBytesBeforeAbort = 1000000000 // ~ 1GB
 | ||||
|   } | ||||
| 
 | ||||
|   get serverSettings() { | ||||
| @ -263,7 +260,8 @@ class BackupManager { | ||||
|         reject(err) | ||||
|       }) | ||||
|       archive.on('progress', ({ fs: fsobj }) => { | ||||
|         if (fsobj.processedBytes > this.MaxBytesBeforeAbort) { | ||||
|         const maxBackupSizeInBytes = this.serverSettings.maxBackupSize * 1000 * 1000 * 1000  | ||||
|         if (fsobj.processedBytes > maxBackupSizeInBytes) { | ||||
|           Logger.error(`[BackupManager] Archiver is too large - aborting to prevent endless loop, Bytes Processed: ${fsobj.processedBytes}`) | ||||
|           archive.abort() | ||||
|           setTimeout(() => { | ||||
|  | ||||
| @ -29,6 +29,7 @@ class ServerSettings { | ||||
|     // this.backupSchedule = '0 1 * * *' // If false then auto-backups are disabled (default every day at 1am)
 | ||||
|     this.backupSchedule = false | ||||
|     this.backupsToKeep = 2 | ||||
|     this.maxBackupSize = 1 | ||||
|     this.backupMetadataCovers = true | ||||
| 
 | ||||
|     // Logger
 | ||||
| @ -78,6 +79,7 @@ class ServerSettings { | ||||
| 
 | ||||
|     this.backupSchedule = settings.backupSchedule || false | ||||
|     this.backupsToKeep = settings.backupsToKeep || 2 | ||||
|     this.maxBackupSize  = settings.maxBackupSize || 1 | ||||
|     this.backupMetadataCovers = settings.backupMetadataCovers !== false | ||||
| 
 | ||||
|     this.loggerDailyLogsToKeep = settings.loggerDailyLogsToKeep || 7 | ||||
| @ -114,6 +116,7 @@ class ServerSettings { | ||||
|       rateLimitLoginWindow: this.rateLimitLoginWindow, | ||||
|       backupSchedule: this.backupSchedule, | ||||
|       backupsToKeep: this.backupsToKeep, | ||||
|       maxBackupSize: this.maxBackupSize, | ||||
|       backupMetadataCovers: this.backupMetadataCovers, | ||||
|       loggerDailyLogsToKeep: this.loggerDailyLogsToKeep, | ||||
|       loggerScannerLogsToKeep: this.loggerScannerLogsToKeep, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user