* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License * @version $Id$ */ if (!is_object(@$GLOBALS['egw'])) // called from outside eGW ==> setup { include ('./inc/functions.inc.php'); @set_time_limit(0); // Check header and authentication if (!$GLOBALS['egw_setup']->auth('Config')) { Header('Location: index.php'); exit; } // Does not return unless user is authorized $GLOBALS['egw_setup']->loaddb(); $tpl_root = $GLOBALS['egw_setup']->html->setup_tpl_dir('setup'); $self = 'db_backup.php'; } $db_backup = CreateObject('phpgwapi.db_backup'); $asyncservice = CreateObject('phpgwapi.asyncservice'); // download a backup, has to be before any output !!! if ($_POST['download']) { list($file) = each($_POST['download']); $file = $db_backup->backup_dir.'/'.basename($file); // basename to now allow to change the dir $browser = CreateObject('phpgwapi.browser'); $browser->content_header(basename($file)); fpassthru($f = fopen($file,'rb')); fclose($f); exit; } $setup_tpl = CreateObject('phpgwapi.Template',$tpl_root); $setup_tpl->set_file(array( 'T_head' => 'head.tpl', 'T_footer' => 'footer.tpl', 'T_db_backup' => 'db_backup.tpl', )); $setup_tpl->set_block('T_db_backup','schedule_row','schedule_rows'); $setup_tpl->set_block('T_db_backup','set_row','set_rows'); $setup_tpl->set_var('stage_title',$stage_title = lang('DB backup and restore')); $setup_tpl->set_var('stage_desc',lang('This program lets you backup your database, schedule a backup or restore it.')); $setup_tpl->set_var('error_msg',''); $bgcolor = array('#DDDDDD','#EEEEEE'); if (is_object($GLOBALS['egw_setup']->html)) { $GLOBALS['egw_setup']->html->show_header($stage_title,False,'config',$GLOBALS['egw_setup']->ConfigDomain . '(' . $GLOBALS['egw_domain'][$GLOBALS['egw_setup']->ConfigDomain]['db_type'] . ')'); } else { $setup_tpl->set_block('T_db_backup','setup_header'); $setup_tpl->set_var('setup_header',''); $GLOBALS['egw_info']['flags']['app_header'] = $stage_title; $GLOBALS['egw']->common->phpgw_header(); parse_navbar(); } // create a backup now if($_POST['backup']) { if (is_resource($f = $db_backup->fopen_backup())) { echo '
'.lang('backup started, this might take a few minutes ...')."
\n".str_repeat(' ',4096); $db_backup->backup($f); fclose($f); $setup_tpl->set_var('error_msg',lang('backup finished')); } else { $setup_tpl->set_var('error_msg',$f); } } $setup_tpl->set_var('backup_now_button',''); $setup_tpl->set_var('upload',' '. ''); if ($_POST['upload'] && is_array($_FILES['uploaded']) && !$_FILES['uploaded']['error'] && is_uploaded_file($_FILES['uploaded']['tmp_name'])) { move_uploaded_file($_FILES['uploaded']['tmp_name'],$db_backup->backup_dir.'/'.$_FILES['uploaded']['name']); if (function_exists('md5_file')) // php4.2+ { $md5 = ', md5='.md5_file($db_backup->backup_dir.'/'.$_FILES['uploaded']['name']); } $setup_tpl->set_var('error_msg',lang("succesfully uploaded file %1",$_FILES['uploaded']['name'].', '. sprintf('%3.1lf MB (%d)',$_FILES['uploaded']['size']/(1024*1024),$_FILES['uploaded']['size']).$md5)); } // delete a backup if ($_POST['delete']) { list($file) = each($_POST['delete']); $file = $db_backup->backup_dir.'/'.basename($file); // basename to not allow to change the dir if (unlink($file)) $setup_tpl->set_var('error_msg',lang("backup '%1' deleted",$file)); } // rename a backup if ($_POST['rename']) { list($file) = each($_POST['rename']); $new_name = $_POST['new_name'][$file]; if (!empty($new_name)) { $file = $db_backup->backup_dir.'/'.basename($file); // basename to not allow to change the dir $ext = preg_match('/(\.gz|\.bz2)+$/i',$file,$matches) ? $matches[1] : ''; $new_file = $db_backup->backup_dir.'/'.preg_replace('/(\.gz|\.bz2)+$/i','',basename($new_name)).$ext; if (rename($file,$new_file)) $setup_tpl->set_var('error_msg',lang("backup '%1' renamed to '%2'",basename($file),basename($new_file))); } } // restore a backup if ($_POST['restore']) { list($file) = each($_POST['restore']); $file = $db_backup->backup_dir.'/'.basename($file); // basename to not allow to change the dir if (is_resource($f = $db_backup->fopen_backup($file,true))) { echo ''.lang('restore started, this might take a few minutes ...')."
\n".str_repeat(' ',4096); $db_backup->restore($f); fclose($f); $setup_tpl->set_var('error_msg',lang("backup '%1' restored",$file)); } else { $setup_tpl->set_var('error_msg',$f); } } // create a new scheduled backup if ($_POST['schedule']) { $asyncservice->set_timer($_POST['times'],'db_backup-'.implode(':',$_POST['times']),'admin.admin_db_backup.do_backup',''); } // cancel a scheduled backup if (is_array($_POST['cancel'])) { list($id) = each($_POST['cancel']); $asyncservice->cancel_timer($id); } // list scheduled backups if (($jobs = $asyncservice->read('db_backup-%'))) { foreach($jobs as $job) { $setup_tpl->set_var($job['times']); $setup_tpl->set_var('next_run',date('Y-m-d H:i',$job['next'])); $setup_tpl->set_var('actions',''); $setup_tpl->parse('schedule_rows','schedule_row',true); } } // input-fields to create a new scheduled backup foreach($times=array('year'=>'*','month'=>'*','day'=>'*','dow'=>'2-6','hour'=>3,'min'=>0) as $name => $default) { $setup_tpl->set_var($name,''); } $setup_tpl->set_var('next_run',' '); $setup_tpl->set_var('actions',''); $setup_tpl->parse('schedule_rows','schedule_row',true); // listing the availible backup sets $setup_tpl->set_var('backup_dir',$db_backup->backup_dir); $setup_tpl->set_var('set_rows',''); $handle = @opendir($db_backup->backup_dir); $files = array(); while($handle && ($file = readdir($handle))) { if ($file != '.' && $file != '..') { $files[filectime($db_backup->backup_dir.'/'.$file)] = $file; } } if ($handle) closedir($handle); krsort($files); foreach($files as $ctime => $file) { $size = filesize($db_backup->backup_dir.'/'.$file); $setup_tpl->set_var(array( 'filename' => $file, 'date' => date('Y-m-d H:i',$ctime), 'size' => sprintf('%3.1lf MB (%d)',$size/(1024*1024),$size), 'actions' => ' '."\n". ' '."\n". ' '."\n". '', )); $setup_tpl->parse('set_rows','set_row',true); } $setup_tpl->set_var(array( 'lang_scheduled_backups'=> lang('scheduled backups'), 'lang_year' => lang('year'), 'lang_month' => lang('month'), 'lang_day' => lang('day'), 'lang_dow' => lang('day of week