mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-25 04:26:52 +02:00 
			
		
		
		
	Add endpoint for triggering restoration completion
This commit is contained in:
		
							parent
							
								
									e700b4da78
								
							
						
					
					
						commit
						f24193801a
					
				| @ -3,7 +3,9 @@ | ||||
| namespace Pterodactyl\Http\Controllers\Api\Remote\Backups; | ||||
| 
 | ||||
| use Carbon\CarbonImmutable; | ||||
| use Illuminate\Http\Request; | ||||
| use Pterodactyl\Models\Backup; | ||||
| use Pterodactyl\Models\Server; | ||||
| use Pterodactyl\Models\AuditLog; | ||||
| use Illuminate\Http\JsonResponse; | ||||
| use League\Flysystem\AwsS3v3\AwsS3Adapter; | ||||
| @ -47,7 +49,7 @@ class BackupStatusController extends Controller | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      */ | ||||
|     public function __invoke(ReportBackupCompleteRequest $request, string $backup) | ||||
|     public function index(ReportBackupCompleteRequest $request, string $backup) | ||||
|     { | ||||
|         /** @var \Pterodactyl\Models\Backup $model */ | ||||
|         $model = Backup::query()->where('uuid', $backup)->firstOrFail(); | ||||
| @ -63,6 +65,7 @@ class BackupStatusController extends Controller | ||||
|             : AuditLog::SERVER__BACKUP_FAILED; | ||||
| 
 | ||||
|         $model->server->audit($action, function (AuditLog $audit) use ($model, $request) { | ||||
|             $audit->is_system = true; | ||||
|             $audit->metadata = ['backup_uuid' => $model->uuid]; | ||||
| 
 | ||||
|             $successful = $request->input('successful') ? true : false; | ||||
| @ -84,6 +87,39 @@ class BackupStatusController extends Controller | ||||
|         return new JsonResponse([], JsonResponse::HTTP_NO_CONTENT); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Handles toggling the restoration status of a server. The server status field should be | ||||
|      * set back to null, even if the restoration failed. This is not an unsolvable state for | ||||
|      * the server, and the user can keep trying to restore, or just use the reinstall button. | ||||
|      * | ||||
|      * The only thing the successful field does is update the entry value for the audit logs | ||||
|      * table tracking for this restoration. | ||||
|      * | ||||
|      * @param \Illuminate\Http\Request $request | ||||
|      * @param string $backup | ||||
|      * @return \Illuminate\Http\JsonResponse | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      */ | ||||
|     public function restore(Request $request, string $backup) | ||||
|     { | ||||
|         /** @var \Pterodactyl\Models\Backup $model */ | ||||
|         $model = Backup::query()->where('uuid', $backup)->firstOrFail(); | ||||
|         $action = $request->get('successful') | ||||
|             ? AuditLog::SERVER__BACKUP_RESTORE_COMPLETED | ||||
|             : AuditLog::SERVER__BACKUP_RESTORE_FAILED; | ||||
| 
 | ||||
|         // Just create a new audit entry for this event and update the server state
 | ||||
|         // so that power actions, file management, and backups can resume as normal.
 | ||||
|         $model->server->audit($action, function (AuditLog $audit, Server $server) use ($backup, $request) { | ||||
|             $audit->is_system = true; | ||||
|             $audit->metadata = ['backup_uuid' => $backup]; | ||||
|             $server->update(['status' => null]); | ||||
|         }); | ||||
| 
 | ||||
|         return new JsonResponse([], JsonResponse::HTTP_NO_CONTENT); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Marks a multipart upload in a given S3-compatiable instance as failed or successful for | ||||
|      * the given backup. | ||||
|  | ||||
| @ -32,6 +32,7 @@ export const rawDataToFileObject = (data: FractalResponseData): FileObject => ({ | ||||
|             'application/x-br', // .tar.br
 | ||||
|             'application/x-bzip2', // .tar.bz2, .bz2
 | ||||
|             'application/gzip', // .tar.gz, .gz
 | ||||
|             'application/x-gzip', | ||||
|             'application/x-lzip', // .tar.lz4, .lz4 (not sure if this mime type is correct)
 | ||||
|             'application/x-sz', // .tar.sz, .sz (not sure if this mime type is correct)
 | ||||
|             'application/x-xz', // .tar.xz, .xz
 | ||||
|  | ||||
| @ -19,5 +19,6 @@ Route::group(['prefix' => '/servers/{uuid}'], function () { | ||||
| 
 | ||||
| Route::group(['prefix' => '/backups'], function () { | ||||
|     Route::get('/{backup}', 'Backups\BackupRemoteUploadController'); | ||||
|     Route::post('/{backup}', 'Backups\BackupStatusController'); | ||||
|     Route::post('/{backup}', 'Backups\BackupStatusController@index'); | ||||
|     Route::post('/{backup}/restore', 'Backups\BackupStatusController@restore'); | ||||
| }); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dane Everitt
						Dane Everitt