27 require
'../../main.inc.php';
28 require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
29 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
30 require_once DOL_DOCUMENT_ROOT.
'/core/class/utils.class.php';
31 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
33 $langs->load(
"admin");
35 $action =
GETPOST(
'action',
'aZ09');
36 $what =
GETPOST(
'what',
'alpha');
37 $export_type =
GETPOST(
'export_type',
'alpha');
41 $limit =
GETPOST(
'limit',
'int') ?
GETPOST(
'limit',
'int') : $conf->liste_limit;
42 $sortfield =
GETPOST(
'sortfield',
'aZ09comma');
43 $sortorder =
GETPOST(
'sortorder',
'aZ09comma');
45 if (empty($page) || $page == -1 ||
GETPOST(
'button_search',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha') || (empty($toselect) && $massaction ===
'0')) {
48 $offset = $limit * $page;
62 $utils =
new Utils($db);
69 if ($file && !$what) {
71 header(
"Location: ".DOL_URL_ROOT.
'/admin/tools/dolibarr_export.php?msg='.urlencode($langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"ExportMethod"))).(GETPOST(
'page_y',
'int') ?
'&page_y='.GETPOST(
'page_y',
'int') :
''));
75 if ($action ==
'delete') {
86 $_SESSION[
"commandbackuplastdone"] =
'';
87 $_SESSION[
"commandbackuptorun"] =
'';
88 $_SESSION[
"commandbackupresult"] =
'';
92 if (!empty($ExecTimeLimit)) {
93 $err = error_reporting();
96 @set_time_limit($ExecTimeLimit);
97 error_reporting($err);
100 if (!empty($MemoryLimit)) {
101 @ini_set(
'memory_limit', $MemoryLimit);
106 $dump_buffer_len = 0;
109 $time_start = time();
112 $outputdir = $conf->admin->dir_output.
'/backup';
120 if ($what ==
'mysql') {
121 $cmddump =
GETPOST(
"mysqldump",
'none');
124 if (!empty($dolibarr_main_restrict_os_commands)) {
125 $arrayofallowedcommand = explode(
',', $dolibarr_main_restrict_os_commands);
126 dol_syslog(
"Command are restricted to ".$dolibarr_main_restrict_os_commands.
". We check that one of this command is inside ".$cmddump);
127 $basenamecmddump = basename($cmddump);
128 if (!in_array($basenamecmddump, $arrayofallowedcommand)) {
129 $errormsg = $langs->trans(
'CommandIsNotInsideAllowedCommands');
133 if (!$errormsg && $cmddump) {
134 dolibarr_set_const($db,
'SYSTEMTOOLS_MYSQLDUMP', $cmddump,
'chaine', 0,
'', $conf->entity);
138 $utils->dumpDatabase(
GETPOST(
'compression',
'alpha'), $what, 0, $file, 0, 0, $lowmemorydump);
139 $errormsg = $utils->error;
140 $_SESSION[
"commandbackuplastdone"] = $utils->result[
'commandbackuplastdone'];
141 $_SESSION[
"commandbackuptorun"] = $utils->result[
'commandbackuptorun'];
146 if ($what ==
'mysqlnobin') {
147 $utils->dumpDatabase(
GETPOST(
'compression',
'alpha'), $what, 0, $file, 0, 0, $lowmemorydump);
149 $errormsg = $utils->error;
150 $_SESSION[
"commandbackuplastdone"] = $utils->result[
'commandbackuplastdone'];
151 $_SESSION[
"commandbackuptorun"] = $utils->result[
'commandbackuptorun'];
155 if ($what ==
'postgresql') {
156 $cmddump =
GETPOST(
"postgresqldump",
'none');
171 if (!$errormsg && $cmddump) {
172 dolibarr_set_const($db,
'SYSTEMTOOLS_POSTGRESQLDUMP', $cmddump,
'chaine', 0,
'', $conf->entity);
176 $utils->dumpDatabase(
GETPOST(
'compression',
'alpha'), $what, 0, $file, 0, 0, $lowmemorydump);
177 $errormsg = $utils->error;
178 $_SESSION[
"commandbackuplastdone"] = $utils->result[
'commandbackuplastdone'];
179 $_SESSION[
"commandbackuptorun"] = $utils->result[
'commandbackuptorun'];
190 $resultstring .=
'<div class="error">'.$langs->trans(
"Error").
" : ".$errormsg.
'</div>';
192 $_SESSION[
"commandbackupresult"] = $resultstring;
195 setEventMessages($langs->trans(
"BackupFileSuccessfullyCreated").
'.<br>'.$langs->trans(
"YouCanDownloadBackupFile"),
null,
'mesgs');
197 $resultstring =
'<div class="ok">';
198 $resultstring .= $langs->trans(
"BackupFileSuccessfullyCreated").
'.<br>';
199 $resultstring .= $langs->trans(
"YouCanDownloadBackupFile");
200 $resultstring .=
'<div>';
202 $_SESSION[
"commandbackupresult"] = $resultstring;
221 header(
"Location: dolibarr_export.php".(
GETPOST(
'page_y',
'int') ?
'?page_y='.
GETPOST(
'page_y',
'int') :
''));