You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

126 lines
3.4 KiB

<?php
namespace App\Http\Controllers;
use BackupManager\Manager;
use Illuminate\Http\Request;
use League\Flysystem\FileExistsException;
use App\Http\Requests\BackupUploadRequest;
use BackupManager\Filesystems\Destination;
use League\Flysystem\FileNotFoundException;
/**
* Database Backups Controller.
*
* @author Nafies Luthfi <nafiesL@gmail.com>
*/
class BackupsController extends Controller
{
/**
* List of backup files.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\View\View
*/
public function index(Request $request)
{
if (!file_exists(storage_path('app/backup/db'))) {
$backups = [];
} else {
$backups = \File::allFiles(storage_path('app/backup/db'));
// Sort files by modified time DESC
usort($backups, function ($a, $b) {
return -1 * strcmp($a->getMTime(), $b->getMTime());
});
}
return view('backups.index', compact('backups'));
}
/**
* Create new backup file.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Routing\Redirector
*/
public function store(Request $request)
{
$this->validate($request, [
'file_name' => 'nullable|max:30|regex:/^[\w._-]+$/',
]);
try {
$manager = app()->make(Manager::class);
$fileName = $request->get('file_name') ?: date('Y-m-d_Hi');
$manager->makeBackup()->run('mysql', [
new Destination('local', 'backup/db/'.$fileName),
], 'gzip');
return redirect()->route('backups.index');
} catch (FileExistsException $e) {
return redirect()->route('backups.index');
}
}
/**
* Delete a backup file from storage.
*
* @param string $fileName
* @return \Illuminate\Routing\Redirector
*/
public function destroy($fileName)
{
if (file_exists(storage_path('app/backup/db/').$fileName)) {
unlink(storage_path('app/backup/db/').$fileName);
}
return redirect()->route('backups.index');
}
/**
* Download a backup file.
*
* @param string $fileName
* @return \Symfony\Component\HttpFoundation\BinaryFileResponse
*/
public function download($fileName)
{
return response()->download(storage_path('app/backup/db/').$fileName);
}
/**
* Restore database from a backup file.
*
* @param string $fileName
* @return \Illuminate\Routing\Redirector
*/
public function restore($fileName)
{
try {
$manager = app()->make(Manager::class);
$manager->makeRestore()->run('local', 'backup/db/'.$fileName, 'mysql', 'gzip');
} catch (FileNotFoundException $e) {
}
return redirect()->route('backups.index');
}
/**
* Upload a backup file to the storage.
*
* @param \App\Http\Requests\BackupUploadRequest $request
* @return \Illuminate\Routing\Redirector
*/
public function upload(BackupUploadRequest $request)
{
$file = $request->file('backup_file');
if (file_exists(storage_path('app/backup/db/').$file->getClientOriginalName()) == false) {
$file->storeAs('backup/db', $file->getClientOriginalName());
}
return redirect()->route('backups.index');
}
}