-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathBd_back
More file actions
85 lines (57 loc) · 2.23 KB
/
Bd_back
File metadata and controls
85 lines (57 loc) · 2.23 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
Route::get('db-backup', [DatabaseBackupController::class, 'db_backup'])->name('db-backup');
<?php
namespace App\Http\Controllers;
use App\Traits\FileSaver;
use Illuminate\Http\Request;
use Spatie\DbDumper\Databases\MySql;
class DatabaseBackupController extends Controller
{
use FileSaver;
//--------------------------------------------------------------------------
// DB-BACKUP METHOD
//--------------------------------------------------------------------------
public function db_backup(Request $request)
{
$ds = DIRECTORY_SEPARATOR;
$path = public_path() . $ds . 'app' . $ds . 'backups' . $ds;
$file = 'dump.sql';
$directory = $path . $file;
$filename = 'Hotel_backup_' . fdate(now(), 'Y_m_d_h_i_s') . '.sql';
if (!is_dir($path)) {
mkdir($path, 0755, true);
}
if ($request->export_type == 'full') {
MySql::create()
->setDbName(env('DB_DATABASE'))
->setUserName(env('DB_USERNAME'))
->setPassword(env('DB_PASSWORD'))
->setHost(env('DB_HOST'))
->setPort(env('DB_PORT'))
->dumpToFile($directory);
} else {
MySql::create()
->setDbName(env('DB_DATABASE'))
->setUserName(env('DB_USERNAME'))
->setPassword(env('DB_PASSWORD'))
->setHost(env('DB_HOST'))
->setPort(env('DB_PORT'))
->doNotCreateTables()
->dumpToFile($directory);
}
return response()->download($directory, $filename);
}
//--------------------------------------------------------------------------
// DB-BACKUP TO DRIVE METHOD
//--------------------------------------------------------------------------
public function databaseBackupToDrive()
{
$messageType = 'message';
$response = $this->backupSavedToGoogleDrive();
if (str_contains($response, 'Error')) {
$messageType = 'error';
}
return redirect()->back()->with($messageType, $response);
}
}
url : /db-backup?export_type=full
composer require spatie/db-dumper