mirror of
https://github.com/myvesta/vesta
synced 2025-08-21 05:44:08 -07:00
🔒 ♻️ Implement secure exec
wrapper functions.
This commit is contained in:
parent
6e13036780
commit
8e951ac72e
115 changed files with 1345 additions and 1986 deletions
|
@ -5,21 +5,15 @@ ob_start();
|
|||
session_start();
|
||||
include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
|
||||
|
||||
$v_username = escapeshellarg($user);
|
||||
exec (VESTA_CMD."v-schedule-user-backup ".$v_username, $output, $return_var);
|
||||
if ($return_var == 0) {
|
||||
$_SESSION['error_msg'] = __('BACKUP_SCHEDULED');
|
||||
} else {
|
||||
$_SESSION['error_msg'] = implode('<br>', $output);
|
||||
if (empty($_SESSION['error_msg'])) {
|
||||
$_SESSION['error_msg'] = __('Error: vesta did not return any output.');
|
||||
}
|
||||
|
||||
if ($return_var == 4) {
|
||||
$return_var = v_exec('v-schedule-user-backup', [$user]);
|
||||
switch ($return_var) {
|
||||
case 0:
|
||||
$_SESSION['error_msg'] = __('BACKUP_SCHEDULED');
|
||||
break;
|
||||
case 4:
|
||||
$_SESSION['error_msg'] = __('BACKUP_EXISTS');
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
unset($output);
|
||||
|
||||
header("Location: /list/backup/");
|
||||
exit;
|
||||
|
|
|
@ -6,7 +6,7 @@ session_start();
|
|||
|
||||
include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
|
||||
|
||||
$backup = escapeshellarg($_GET['backup']);
|
||||
$backup = $_GET['backup'];
|
||||
|
||||
$web = 'no';
|
||||
$dns = 'no';
|
||||
|
@ -15,30 +15,27 @@ $db = 'no';
|
|||
$cron = 'no';
|
||||
$udir = 'no';
|
||||
|
||||
if ($_GET['type'] == 'web') $web = escapeshellarg($_GET['object']);
|
||||
if ($_GET['type'] == 'dns') $dns = escapeshellarg($_GET['object']);
|
||||
if ($_GET['type'] == 'mail') $mail = escapeshellarg($_GET['object']);
|
||||
if ($_GET['type'] == 'db') $db = escapeshellarg($_GET['object']);
|
||||
if ($_GET['type'] == 'web') $web = $_GET['object'];
|
||||
if ($_GET['type'] == 'dns') $dns = $_GET['object'];
|
||||
if ($_GET['type'] == 'mail') $mail = $_GET['object'];
|
||||
if ($_GET['type'] == 'db') $db = $_GET['object'];
|
||||
if ($_GET['type'] == 'cron') $cron = 'yes';
|
||||
if ($_GET['type'] == 'udir') $udir = escapeshellarg($_GET['object']);
|
||||
if ($_GET['type'] == 'udir') $udir = $_GET['object'];
|
||||
|
||||
if (!empty($_GET['type'])) {
|
||||
$restore_cmd = VESTA_CMD."v-schedule-user-restore ".$user." ".$backup." ".$web." ".$dns." ".$mail." ".$db." ".$cron." ".$udir;
|
||||
$restore_args = [$user, $backup, $web, $dns, $mail, $db, $cron, $udir];
|
||||
} else {
|
||||
$restore_cmd = VESTA_CMD."v-schedule-user-restore ".$user." ".$backup;
|
||||
$restore_args = [$user, $backup];
|
||||
}
|
||||
|
||||
exec ($restore_cmd, $output, $return_var);
|
||||
if ($return_var == 0) {
|
||||
$_SESSION['error_msg'] = __('RESTORE_SCHEDULED');
|
||||
} else {
|
||||
$_SESSION['error_msg'] = implode('<br>', $output);
|
||||
if (empty($_SESSION['error_msg'])) {
|
||||
$_SESSION['error_msg'] = __('Error: vesta did not return any output.');
|
||||
}
|
||||
if ($return_var == 4) {
|
||||
$return_var = v_exec('v-schedule-user-restore', $restore_args);
|
||||
switch ($return_var) {
|
||||
case 0:
|
||||
$_SESSION['error_msg'] = __('RESTORE_SCHEDULED');
|
||||
break;
|
||||
case 4:
|
||||
$_SESSION['error_msg'] = __('RESTORE_EXISTS');
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
header("Location: /list/backup/?backup=" . $_GET['backup']);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue