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') :
''));
dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $note='', $entity=1)
Insert a parameter (key,value) into database (delete old key then insert it again).
Class to manage utility methods.
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='')
Set event messages in dol_events session object.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
if(!function_exists('utf8_encode')) if(!function_exists('utf8_decode')) getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1)
Clean a string to use it as a file name.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname from a POST of a form.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_sanitizePathName($str, $newstr='_', $unaccent=1)
Clean a string to use it as a path name.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
if(!defined('NOREQUIREMENU')) if(!function_exists("llxHeader")) top_httphead($contenttype='text/html', $forcenocache=0)
Show HTTP header.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.