2004-09-12 01:34:24 +00:00
|
|
|
<?php //$Id$
|
2003-12-01 22:00:00 +00:00
|
|
|
//This file contains all the code needed to execute scheduled backups
|
|
|
|
|
2003-12-12 19:36:52 +00:00
|
|
|
//This function is executed via moodle cron
|
|
|
|
//It prepares all the info and execute backups as necessary
|
|
|
|
function schedule_backup_cron() {
|
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$status = true;
|
|
|
|
|
2003-12-15 00:54:16 +00:00
|
|
|
$emailpending = false;
|
|
|
|
|
2004-05-20 15:17:39 +00:00
|
|
|
//Check for required functions...
|
|
|
|
if(!function_exists('utf8_encode')) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" ERROR: You need to add XML support to your PHP installation!");
|
2004-05-20 15:17:39 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2003-12-14 00:00:28 +00:00
|
|
|
//Get now
|
|
|
|
$now = time();
|
|
|
|
|
|
|
|
//First of all, we have to see if the scheduled is active and detect
|
|
|
|
//that there isn't another cron running
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Checking backup status",'...');
|
2003-12-14 00:00:28 +00:00
|
|
|
$backup_config = backup_get_config();
|
|
|
|
if(!isset($backup_config->backup_sche_active) || !$backup_config->backup_sche_active) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace("INACTIVE");
|
2003-12-14 00:00:28 +00:00
|
|
|
return true;
|
|
|
|
} else if (isset($backup_config->backup_sche_running) && $backup_config->backup_sche_running) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace("RUNNING");
|
2004-01-05 00:27:22 +00:00
|
|
|
//Now check if it's a really running task or something very old looking
|
|
|
|
//for info in backup_logs to unlock status as necessary
|
|
|
|
$timetosee = 1800; //Half an hour looking for activity
|
|
|
|
$timeafter = time() - $timetosee;
|
|
|
|
$numofrec = count_records_select ("backup_log","time > $timeafter");
|
|
|
|
if (!$numofrec) {
|
|
|
|
$timetoseemin = $timetosee/60;
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" No activity in last ".$timetoseemin." minutes. Unlocking status");
|
2004-01-05 00:27:22 +00:00
|
|
|
} else {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Scheduled backup seems to be running. Execution delayed");
|
2004-01-05 00:27:22 +00:00
|
|
|
return true;
|
|
|
|
}
|
2003-12-14 00:00:28 +00:00
|
|
|
} else {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace("OK");
|
2003-12-14 00:00:28 +00:00
|
|
|
//Mark backup_sche_running
|
|
|
|
backup_set_config("backup_sche_running","1");
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now we get the main admin user (we'll use his timezone, mail...)
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Getting admin info");
|
2003-12-14 00:00:28 +00:00
|
|
|
$admin = get_admin();
|
|
|
|
if (!$admin) {
|
|
|
|
$status = false;
|
|
|
|
}
|
|
|
|
|
2004-09-24 19:20:32 +00:00
|
|
|
//Delete old_entries from backup tables
|
|
|
|
if ($status) {
|
|
|
|
mtrace(" Deleting old data");
|
|
|
|
$status = backup_delete_old_data();
|
|
|
|
}
|
|
|
|
|
2003-12-14 00:00:28 +00:00
|
|
|
//Now we get a list of courses in the server
|
|
|
|
if ($status) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Checking courses");
|
2004-11-04 00:10:33 +00:00
|
|
|
//First of all, we delete everything from backup tables related to deleted courses
|
|
|
|
mtrace(" Skipping deleted courses");
|
|
|
|
$skipped = 0;
|
|
|
|
if ($bckcourses = get_records('backup_courses')) {
|
|
|
|
foreach($bckcourses as $bckcourse) {
|
|
|
|
//Search if it exists
|
|
|
|
if (!$exists = get_record('course', 'id', "$bckcourse->courseid")) {
|
|
|
|
//Doesn't exist, so delete from backup tables
|
|
|
|
delete_records('backup_courses', 'courseid', "$bckcourse->courseid");
|
|
|
|
delete_records('backup_log', 'courseid', "$bckcourse->courseid");
|
|
|
|
$skipped++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
mtrace(" $skipped courses");
|
|
|
|
//Now process existing courses
|
2003-12-14 00:00:28 +00:00
|
|
|
$courses = get_records("course");
|
|
|
|
//For each course, we check (insert, update) the backup_course table
|
|
|
|
//with needed data
|
|
|
|
foreach ($courses as $course) {
|
|
|
|
if ($status) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" $course->fullname");
|
2003-12-14 00:00:28 +00:00
|
|
|
//We check if the course exists in backup_course
|
|
|
|
$backup_course = get_record("backup_courses","courseid",$course->id);
|
|
|
|
//If it doesn't exist, create
|
|
|
|
if (!$backup_course) {
|
|
|
|
$temp_backup_course->courseid = $course->id;
|
|
|
|
$newid = insert_record("backup_courses",$temp_backup_course);
|
|
|
|
//And get it from db
|
|
|
|
$backup_course = get_record("backup_courses","id",$newid);
|
|
|
|
}
|
|
|
|
//If it doesn't exist now, error
|
|
|
|
if (!$backup_course) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" ERROR (in backup_courses detection)");
|
2003-12-14 00:00:28 +00:00
|
|
|
$status = false;
|
|
|
|
}
|
|
|
|
//Now we backup every course with nextstarttime < now
|
|
|
|
if ($backup_course->nextstarttime > 0 && $backup_course->nextstarttime < $now) {
|
2003-12-15 00:54:16 +00:00
|
|
|
//We have to send a email because we have included at least one backup
|
|
|
|
$emailpending = true;
|
2004-09-24 19:20:32 +00:00
|
|
|
//Only make the backup if laststatus isn't 2-UNFINISHED (uncontrolled error)
|
|
|
|
if ($backup_course->laststatus != 2) {
|
|
|
|
//Set laststarttime
|
|
|
|
$starttime = time();
|
|
|
|
set_field("backup_courses","laststarttime",$starttime,"courseid",$backup_course->courseid);
|
|
|
|
//Set course status to unfinished, the process will reset it
|
|
|
|
set_field("backup_courses","laststatus","2","courseid",$backup_course->courseid);
|
|
|
|
//Launch backup
|
|
|
|
$course_status = schedule_backup_launch_backup($course,$starttime);
|
|
|
|
//Set lastendtime
|
|
|
|
set_field("backup_courses","lastendtime",time(),"courseid",$backup_course->courseid);
|
|
|
|
//Set laststatus
|
|
|
|
if ($course_status) {
|
|
|
|
set_field("backup_courses","laststatus","1","courseid",$backup_course->courseid);
|
|
|
|
} else {
|
|
|
|
set_field("backup_courses","laststatus","0","courseid",$backup_course->courseid);
|
|
|
|
}
|
2003-12-14 00:00:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now, calculate next execution of the course
|
|
|
|
$nextstarttime = schedule_backup_next_execution ($backup_course,$backup_config,$now,$admin->timezone);
|
|
|
|
//Save it to db
|
2003-12-27 03:14:32 +00:00
|
|
|
set_field("backup_courses","nextstarttime",$nextstarttime,"courseid",$backup_course->courseid);
|
2003-12-14 00:00:28 +00:00
|
|
|
//Print it to screen as necessary
|
|
|
|
$showtime = "undefined";
|
|
|
|
if ($nextstarttime > 0) {
|
|
|
|
$showtime = userdate($nextstarttime,"",$admin->timezone);
|
|
|
|
}
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Next execution: $showtime");
|
2003-12-14 00:00:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Delete old logs
|
|
|
|
if (!empty($CFG->loglifetime)) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Deleting old logs");
|
2003-12-14 00:00:28 +00:00
|
|
|
$loglifetime = $now - ($CFG->loglifetime * 86400);
|
|
|
|
delete_records_select("backup_log", "laststarttime < '$loglifetime'");
|
|
|
|
}
|
|
|
|
|
2004-09-24 19:20:32 +00:00
|
|
|
//Send email to admin if necessary
|
2003-12-15 00:54:16 +00:00
|
|
|
if ($emailpending) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Sending email to admin");
|
2003-12-15 00:54:16 +00:00
|
|
|
$message = "";
|
2004-09-24 19:20:32 +00:00
|
|
|
|
|
|
|
//Get info about the status of courses
|
|
|
|
$count_all = count_records('backup_courses');
|
|
|
|
$count_ok = count_records('backup_courses','laststatus','1');
|
|
|
|
$count_error = count_records('backup_courses','laststatus','0');
|
|
|
|
$count_unfinished = count_records('backup_courses','laststatus','2');
|
|
|
|
|
|
|
|
//Build the message text
|
|
|
|
//Summary
|
|
|
|
$message .= get_string('summary')."\n";
|
|
|
|
$message .= "==================================================\n";
|
|
|
|
$message .= " ".get_string('courses').": ".$count_all."\n";
|
|
|
|
$message .= " ".get_string('ok').": ".$count_ok."\n";
|
|
|
|
$message .= " ".get_string('error').": ".$count_error."\n";
|
|
|
|
$message .= " ".get_string('unfinished').": ".$count_unfinished."\n\n";
|
|
|
|
|
|
|
|
//Reference
|
|
|
|
if ($count_error != 0 || $count_unfinished != 0) {
|
|
|
|
$message .= " ".get_string('backupfailed')."\n\n";
|
|
|
|
$dest_url = $CFG->wwwroot.'/backup/log.php';
|
|
|
|
$message .= " ".get_string('backuptakealook','',$dest_url)."\n\n";
|
|
|
|
//Reset unfinished to error
|
|
|
|
set_field('backup_courses','laststatus','0','laststatus','2');
|
|
|
|
} else {
|
|
|
|
$message .= " ".get_string('backupfinished')."\n";
|
2003-12-15 00:54:16 +00:00
|
|
|
}
|
2004-09-24 19:20:32 +00:00
|
|
|
|
|
|
|
//Build the message subject
|
2003-12-27 04:08:04 +00:00
|
|
|
$site = get_site();
|
2004-09-24 19:20:32 +00:00
|
|
|
$prefix = $site->shortname.": ";
|
|
|
|
if ($count_error != 0 || $count_unfinished != 0) {
|
|
|
|
$prefix .= "[".strtoupper(get_string('error'))."] ";
|
|
|
|
}
|
|
|
|
$subject = $prefix.get_string("scheduledbackupstatus");
|
|
|
|
|
|
|
|
//Send the message
|
|
|
|
email_to_user($admin,$admin,$subject,$message);
|
2003-12-15 00:54:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-12-14 00:00:28 +00:00
|
|
|
//Everything is finished stop backup_sche_running
|
|
|
|
backup_set_config("backup_sche_running","0");
|
|
|
|
|
|
|
|
return $status;
|
|
|
|
}
|
|
|
|
|
|
|
|
//This function executes the ENTIRE backup of a course (passed as parameter)
|
|
|
|
//using all the scheduled backup preferences
|
2003-12-15 00:54:16 +00:00
|
|
|
function schedule_backup_launch_backup($course,$starttime = 0) {
|
2003-12-14 00:00:28 +00:00
|
|
|
|
|
|
|
$preferences = false;
|
|
|
|
$status = false;
|
|
|
|
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Executing backup");
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id,"Start backup course $course->fullname");
|
|
|
|
schedule_backup_log($starttime,$course->id," Phase 1: Checking and counting:");
|
|
|
|
$preferences = schedule_backup_course_configure($course,$starttime);
|
2003-12-29 20:24:45 +00:00
|
|
|
|
2003-12-14 00:00:28 +00:00
|
|
|
if ($preferences) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," Phase 2: Executing and copying:");
|
|
|
|
$status = schedule_backup_course_execute($preferences,$starttime);
|
2003-12-14 00:00:28 +00:00
|
|
|
}
|
2004-09-24 19:20:32 +00:00
|
|
|
|
2003-12-29 20:24:45 +00:00
|
|
|
if ($status && $preferences) {
|
|
|
|
//Only if the backup_sche_keep is set
|
|
|
|
if ($preferences->backup_keep) {
|
|
|
|
schedule_backup_log($starttime,$course->id," Phase 3: Deleting old backup files:");
|
|
|
|
$status = schedule_backup_course_delete_old_files($preferences,$starttime);
|
|
|
|
}
|
|
|
|
}
|
2004-09-24 19:20:32 +00:00
|
|
|
|
2003-12-14 00:00:28 +00:00
|
|
|
if ($status && $preferences) {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" End backup OK");
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id,"End backup course $course->fullname - OK");
|
2003-12-14 00:00:28 +00:00
|
|
|
} else {
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" End backup with ERROR");
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id,"End backup course $course->fullname - ERROR!!");
|
2003-12-14 00:00:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return $status && $preferences;
|
|
|
|
}
|
|
|
|
|
2003-12-15 00:54:16 +00:00
|
|
|
//This function saves to backup_log all the needed process info
|
|
|
|
//to use it later. NOTE: If $starttime = 0 no info in saved
|
|
|
|
function schedule_backup_log($starttime,$courseid,$message) {
|
|
|
|
|
|
|
|
if ($starttime) {
|
|
|
|
$log->courseid = $courseid;
|
|
|
|
$log->time = time();
|
|
|
|
$log->laststarttime = $starttime;
|
|
|
|
$log->info = $message;
|
|
|
|
|
|
|
|
insert_record ("backup_log",$log);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2003-12-14 00:00:28 +00:00
|
|
|
//This function returns the next future GMT time to execute the course based in the
|
|
|
|
//configuration of the scheduled backups
|
|
|
|
function schedule_backup_next_execution ($backup_course,$backup_config,$now,$timezone) {
|
|
|
|
|
|
|
|
$result = -1;
|
|
|
|
|
|
|
|
//Get today's midnight GMT
|
|
|
|
$midnight = usergetmidnight($now,$timezone);
|
|
|
|
|
|
|
|
//Get today's day of week (0=Sunday...6=Saturday)
|
|
|
|
$date = usergetdate($now,$timezone);
|
|
|
|
$dayofweek = $date['wday'];
|
|
|
|
|
|
|
|
//Get number of days (from today) to execute backups
|
|
|
|
$scheduled_days = substr($backup_config->backup_sche_weekdays,$dayofweek).
|
|
|
|
$backup_config->backup_sche_weekdays;
|
|
|
|
$daysfromtoday = strpos($scheduled_days, "1");
|
|
|
|
|
|
|
|
//If some day has been found
|
|
|
|
if ($daysfromtoday !== false) {
|
|
|
|
//Calculate distance
|
|
|
|
$dist = ($daysfromtoday * 86400) + //Days distance
|
|
|
|
($backup_config->backup_sche_hour*3600) + //Hours distance
|
|
|
|
($backup_config->backup_sche_minute*60); //Minutes distance
|
|
|
|
$result = $midnight + $dist;
|
|
|
|
}
|
|
|
|
|
|
|
|
//If that time is past, call the function recursively to obtain the next valid day
|
|
|
|
if ($result > 0 && $result < time()) {
|
|
|
|
$result = schedule_backup_next_execution ($backup_course,$backup_config,$now + 86400,$timezone);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
2003-12-12 19:36:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
//This function implements all the needed code to prepare a course
|
|
|
|
//to be in backup (insert temp info into backup temp tables).
|
2003-12-15 00:54:16 +00:00
|
|
|
function schedule_backup_course_configure($course,$starttime = 0) {
|
2003-12-01 22:00:00 +00:00
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$status = true;
|
|
|
|
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," checking parameters");
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
//Check the required variable
|
|
|
|
if (empty($course->id)) {
|
|
|
|
$status = false;
|
|
|
|
}
|
|
|
|
//Get scheduled backup preferences
|
|
|
|
$backup_config = backup_get_config();
|
|
|
|
|
|
|
|
//Checks backup_config pairs exist
|
|
|
|
if ($status) {
|
|
|
|
if (!isset($backup_config->backup_sche_modules)) {
|
|
|
|
$backup_config->backup_sche_modules = 1;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_withuserdata)) {
|
|
|
|
$backup_config->backup_sche_withuserdata = 1;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_users)) {
|
|
|
|
$backup_config->backup_sche_users = 1;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_logs)) {
|
|
|
|
$backup_config->backup_sche_logs = 0;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_userfiles)) {
|
|
|
|
$backup_config->backup_sche_userfiles = 1;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_coursefiles)) {
|
|
|
|
$backup_config->backup_sche_coursefiles = 1;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_active)) {
|
|
|
|
$backup_config->backup_sche_active = 0;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_weekdays)) {
|
|
|
|
$backup_config->backup_sche_weekdays = "0000000";
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_hour)) {
|
|
|
|
$backup_config->backup_sche_hour = 00;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_minute)) {
|
|
|
|
$backup_config->backup_sche_minute = 00;
|
|
|
|
}
|
|
|
|
if (!isset($backup_config->backup_sche_destination)) {
|
|
|
|
$backup_config->backup_sche_destination = "";
|
|
|
|
}
|
2003-12-29 20:24:45 +00:00
|
|
|
if (!isset($backup_config->backup_sche_keep)) {
|
2003-12-30 03:56:32 +00:00
|
|
|
$backup_config->backup_sche_keep = 1;
|
2003-12-29 20:24:45 +00:00
|
|
|
}
|
2003-12-01 22:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($status) {
|
|
|
|
//Checks for the required files/functions to backup every mod
|
|
|
|
//And check if there is data about it
|
|
|
|
$count = 0;
|
|
|
|
if ($allmods = get_records("modules") ) {
|
|
|
|
foreach ($allmods as $mod) {
|
|
|
|
$modname = $mod->name;
|
|
|
|
$modfile = "$CFG->dirroot/mod/$modname/backuplib.php";
|
|
|
|
$modbackup = $modname."_backup_mods";
|
|
|
|
$modcheckbackup = $modname."_check_backup_mods";
|
|
|
|
if (file_exists($modfile)) {
|
|
|
|
include_once($modfile);
|
|
|
|
if (function_exists($modbackup) and function_exists($modcheckbackup)) {
|
|
|
|
$var = "exists_".$modname;
|
|
|
|
$$var = true;
|
|
|
|
$count++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Check data
|
|
|
|
//Check module info
|
|
|
|
$var = "backup_".$modname;
|
|
|
|
if (!isset($$var)) {
|
|
|
|
$$var = $backup_config->backup_sche_modules;
|
|
|
|
}
|
|
|
|
//Now stores all the mods preferences into an array into preferences
|
|
|
|
$preferences->mods[$modname]->backup = $$var;
|
|
|
|
|
|
|
|
//Check include user info
|
|
|
|
$var = "backup_user_info_".$modname;
|
|
|
|
if (!isset($$var)) {
|
|
|
|
$$var = $backup_config->backup_sche_withuserdata;
|
|
|
|
}
|
|
|
|
//Now stores all the mods preferences into an array into preferences
|
|
|
|
$preferences->mods[$modname]->userinfo = $$var;
|
|
|
|
//And the name of the mod
|
|
|
|
$preferences->mods[$modname]->name = $modname;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Convert other parameters
|
|
|
|
if ($status) {
|
|
|
|
$preferences->backup_users = $backup_config->backup_sche_users;
|
|
|
|
$preferences->backup_logs = $backup_config->backup_sche_logs;
|
|
|
|
$preferences->backup_user_files = $backup_config->backup_sche_userfiles;
|
|
|
|
$preferences->backup_course_files = $backup_config->backup_sche_coursefiles;
|
|
|
|
$preferences->backup_course = $course->id;
|
|
|
|
$preferences->backup_destination = $backup_config->backup_sche_destination;
|
2003-12-29 20:24:45 +00:00
|
|
|
$preferences->backup_keep = $backup_config->backup_sche_keep;
|
2003-12-01 22:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//Calculate the backup string
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," calculating backup name");
|
2003-12-29 20:24:45 +00:00
|
|
|
|
|
|
|
//Calculate the backup word
|
2003-12-01 22:00:00 +00:00
|
|
|
//Take off some characters in the filename !!
|
|
|
|
$takeoff = array(" ", ":", "/", "\\", "|");
|
2003-12-29 20:24:45 +00:00
|
|
|
$backup_word = str_replace($takeoff,"_",strtolower(get_string("backupfilename")));
|
2003-12-01 22:00:00 +00:00
|
|
|
//If non-translated, use "backup"
|
2003-12-29 20:24:45 +00:00
|
|
|
if (substr($backup_word,0,1) == "[") {
|
|
|
|
$backup_word= "backup";
|
2003-12-01 22:00:00 +00:00
|
|
|
}
|
2003-12-29 20:24:45 +00:00
|
|
|
|
|
|
|
//Calculate the date format string
|
|
|
|
$backup_date_format = str_replace(" ","_",get_string("backupnameformat"));
|
2003-12-01 22:00:00 +00:00
|
|
|
//If non-translated, use "%Y%m%d-%H%M"
|
2003-12-29 20:24:45 +00:00
|
|
|
if (substr($backup_date_format,0,1) == "[") {
|
|
|
|
$backup_date_format = "%%Y%%m%%d-%%H%%M";
|
|
|
|
}
|
|
|
|
|
|
|
|
//Calculate the shortname
|
|
|
|
$backup_shortname = clean_filename($course->shortname);
|
|
|
|
if (empty($backup_shortname) or $backup_shortname == '_' ) {
|
|
|
|
$backup_shortname = $course->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Calculate the final backup filename
|
|
|
|
//The backup word
|
|
|
|
$backup_name = $backup_word."-";
|
|
|
|
//The shortname
|
|
|
|
$backup_name .= strtolower($backup_shortname)."-";
|
|
|
|
//The date format
|
|
|
|
$backup_name .= userdate(time(),$backup_date_format,99,false);
|
|
|
|
//The extension
|
|
|
|
$backup_name .= ".zip";
|
|
|
|
|
|
|
|
//Calculate the string to match the keep preference
|
|
|
|
$keep_name = $backup_word."-";
|
|
|
|
//The shortname
|
|
|
|
$keep_name .= strtolower($backup_shortname)."-";
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
$preferences->backup_name = $backup_name;
|
2003-12-29 20:24:45 +00:00
|
|
|
$preferences->keep_name = $keep_name;
|
2003-12-01 22:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//Calculate the backup unique code to allow simultaneus backups (to define
|
|
|
|
//the temp-directory name and records in backup temp tables
|
|
|
|
if ($status) {
|
|
|
|
$backup_unique_code = time();
|
|
|
|
$preferences->backup_unique_code = $backup_unique_code;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Calculate necesary info to backup modules
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," calculating modules data");
|
2003-12-01 22:00:00 +00:00
|
|
|
if ($allmods = get_records("modules") ) {
|
|
|
|
foreach ($allmods as $mod) {
|
|
|
|
$modname = $mod->name;
|
|
|
|
$modbackup = $modname."_backup_mods";
|
|
|
|
//If exists the lib & function
|
|
|
|
$var = "exists_".$modname;
|
|
|
|
if (isset($$var) && $$var) {
|
|
|
|
//Add hidden fields
|
|
|
|
$var = "backup_".$modname;
|
|
|
|
//Only if selected
|
|
|
|
if ($$var == 1) {
|
|
|
|
$var = "backup_user_info_".$modname;
|
|
|
|
//Call the check function to show more info
|
|
|
|
$modcheckbackup = $modname."_check_backup_mods";
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," $modname");
|
2003-12-01 22:00:00 +00:00
|
|
|
$modcheckbackup($course->id,$$var,$backup_unique_code);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now calculate the users
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," calculating users");
|
2003-12-01 22:00:00 +00:00
|
|
|
user_check_backup($course->id,$backup_unique_code,$preferences->backup_users);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now calculate the logs
|
|
|
|
if ($status) {
|
|
|
|
if ($preferences->backup_logs) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," calculating logs");
|
2003-12-01 22:00:00 +00:00
|
|
|
log_check_backup($course->id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now calculate the userfiles
|
|
|
|
if ($status) {
|
|
|
|
if ($preferences->backup_user_files) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," calculating user files");
|
2003-12-01 22:00:00 +00:00
|
|
|
user_files_check_backup($course->id,$preferences->backup_unique_code);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now calculate the coursefiles
|
|
|
|
if ($status) {
|
|
|
|
if ($preferences->backup_course_files) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$course->id," calculating course files");
|
2003-12-01 22:00:00 +00:00
|
|
|
course_files_check_backup($course->id,$preferences->backup_unique_code);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//If everything is ok, return calculated preferences
|
|
|
|
if ($status) {
|
|
|
|
$status = $preferences;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $status;
|
|
|
|
}
|
|
|
|
|
|
|
|
//This function implements all the needed code to backup a course
|
|
|
|
//copying it to the desired destination (default if not specified)
|
2003-12-15 00:54:16 +00:00
|
|
|
function schedule_backup_course_execute($preferences,$starttime = 0) {
|
2003-12-01 22:00:00 +00:00
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$status = true;
|
|
|
|
|
|
|
|
//Another Info to add
|
|
|
|
$preferences->moodle_version = $CFG->version;
|
|
|
|
$preferences->moodle_release = $CFG->release;
|
|
|
|
$preferences->backup_version = $CFG->backup_version;
|
|
|
|
$preferences->backup_release = $CFG->backup_release;
|
|
|
|
|
2004-05-06 22:17:45 +00:00
|
|
|
//Some parts of the backup doesn't know about $preferences, so we
|
|
|
|
//put a copy of it inside that CFG (always global) to be able to
|
|
|
|
//use it. Then, when needed I search for preferences inside CFG
|
|
|
|
//Used to avoid some problems in full_tag() when preferences isn't
|
|
|
|
//set globally (i.e. in scheduled backups)
|
|
|
|
$CFG->backup_preferences = $preferences;
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
//Check for temp and backup and backup_unique_code directory
|
|
|
|
//Create them as needed
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," checking temp structures");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = check_and_create_backup_dir($preferences->backup_unique_code);
|
2004-06-27 22:35:27 +00:00
|
|
|
//Empty backup dir
|
2003-12-01 22:00:00 +00:00
|
|
|
if ($status) {
|
2004-06-27 22:35:27 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," cleaning current dir");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = clear_backup_dir($preferences->backup_unique_code);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Create the moodle.xml file
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," creating backup file");
|
2003-12-01 22:00:00 +00:00
|
|
|
//Obtain the xml file (create and open) and print prolog information
|
|
|
|
$backup_file = backup_open_xml($preferences->backup_unique_code);
|
|
|
|
//Prints general info about backup to file
|
|
|
|
if ($backup_file) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," general info");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_general_info($backup_file,$preferences);
|
|
|
|
} else {
|
|
|
|
$status = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Prints course start (tag and general info)
|
|
|
|
if ($status) {
|
|
|
|
$status = backup_course_start($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Section info
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," sections info");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_course_sections($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//User info
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," user info");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_user_info($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//If we have selected to backup quizzes, backup categories and
|
|
|
|
//questions structure (step 1). See notes on mod/quiz/backuplib.php
|
|
|
|
if ($status and $preferences->mods['quiz']->backup) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," categories & questions");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = quiz_backup_question_categories($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Print logs if selected
|
|
|
|
if ($status) {
|
|
|
|
if ($preferences->backup_logs) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," logs");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_log_info($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Print scales info
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," scales");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_scales_info($backup_file,$preferences);
|
|
|
|
}
|
2004-02-21 01:30:22 +00:00
|
|
|
|
2004-01-29 00:07:25 +00:00
|
|
|
//Print groups info
|
|
|
|
if ($status) {
|
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," groups");
|
|
|
|
$status = backup_groups_info($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
2004-02-21 01:30:22 +00:00
|
|
|
//Print events info
|
|
|
|
if ($status) {
|
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," events");
|
|
|
|
$status = backup_events_info($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
//Module info, this unique function makes all the work!!
|
|
|
|
//db export and module fileis copy
|
|
|
|
if ($status) {
|
|
|
|
$mods_to_backup = false;
|
|
|
|
//Check if we have any mod to backup
|
|
|
|
foreach ($preferences->mods as $module) {
|
|
|
|
if ($module->backup) {
|
|
|
|
$mods_to_backup = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//If we have to backup some module
|
|
|
|
if ($mods_to_backup) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," modules");
|
2003-12-01 22:00:00 +00:00
|
|
|
//Start modules tag
|
|
|
|
$status = backup_modules_start ($backup_file,$preferences);
|
|
|
|
//Iterate over modules and call backup
|
|
|
|
foreach ($preferences->mods as $module) {
|
|
|
|
if ($module->backup and $status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," $module->name");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_module($backup_file,$preferences,$module->name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Close modules tag
|
|
|
|
$status = backup_modules_end ($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Prints course end
|
|
|
|
if ($status) {
|
|
|
|
$status = backup_course_end($backup_file,$preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Close the xml file and xml data
|
|
|
|
if ($backup_file) {
|
|
|
|
backup_close_xml($backup_file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now, if selected, copy user files
|
|
|
|
if ($status) {
|
|
|
|
if ($preferences->backup_user_files) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," copying user files");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_copy_user_files ($preferences);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now, if selected, copy course files
|
|
|
|
if ($status) {
|
|
|
|
if ($preferences->backup_course_files) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," copying course files");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_copy_course_files ($preferences);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now, zip all the backup directory contents
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," zipping files");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = backup_zip ($preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now, copy the zip file to course directory
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," copying backup");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = copy_zip_to_course_dir ($preferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Now, clean temporary data (db and filesystem)
|
|
|
|
if ($status) {
|
2003-12-15 00:54:16 +00:00
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," cleaning temp data");
|
2003-12-01 22:00:00 +00:00
|
|
|
$status = clean_temp_data ($preferences);
|
|
|
|
}
|
|
|
|
|
2004-05-06 22:17:45 +00:00
|
|
|
//Unset CFG->backup_preferences only needed in scheduled backups
|
|
|
|
unset ($CFG->backup_preferences);
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
return $status;
|
|
|
|
}
|
|
|
|
|
2003-12-29 20:24:45 +00:00
|
|
|
//This function deletes old backup files when the "keep" limit has been reached
|
|
|
|
//in the destination directory.
|
|
|
|
function schedule_backup_course_delete_old_files($preferences,$starttime=0) {
|
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$status = true;
|
|
|
|
|
|
|
|
//Calculate the directory to check
|
|
|
|
$dirtocheck = "";
|
|
|
|
//if $preferences->backup_destination isn't empty, then check that directory
|
|
|
|
if (!empty($preferences->backup_destination)) {
|
|
|
|
$dirtocheck = $preferences->backup_destination;
|
|
|
|
//else calculate standard backup directory location
|
|
|
|
} else {
|
|
|
|
$dirtocheck = $CFG->dataroot."/".$preferences->backup_course."/backupdata";
|
|
|
|
}
|
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," checking $dirtocheck");
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" Keeping backup files in $dirtocheck");
|
2003-12-29 20:24:45 +00:00
|
|
|
|
|
|
|
//Get all the files in $dirtocheck
|
|
|
|
$files = get_directory_list($dirtocheck,"",false);
|
|
|
|
//Get all matching files ($preferences->keep_name) from $files
|
|
|
|
$matchingfiles = array();
|
|
|
|
foreach ($files as $file) {
|
|
|
|
if (substr($file, 0, strlen($preferences->keep_name)) == $preferences->keep_name) {
|
|
|
|
$modifieddate = filemtime($dirtocheck."/".$file);
|
|
|
|
$matchingfiles[$modifieddate] = $file;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Sort by key (modified date) to get the oldest first (instead of doing that by name
|
|
|
|
//because it could give us problems in some languages with different format names).
|
|
|
|
ksort($matchingfiles);
|
|
|
|
|
|
|
|
//Count matching files
|
|
|
|
$countmatching = count($matchingfiles);
|
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," found $countmatching backup files");
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" found $countmatching backup files");
|
2003-12-29 20:24:45 +00:00
|
|
|
if ($preferences->backup_keep < $countmatching) {
|
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," keep limit ($preferences->backup_keep) reached. Deleting old files");
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" keep limit ($preferences->backup_keep) reached. Deleting old files");
|
2003-12-29 20:24:45 +00:00
|
|
|
$filestodelete = $countmatching - $preferences->backup_keep;
|
|
|
|
$filesdeleted = 0;
|
|
|
|
foreach ($matchingfiles as $matchfile) {
|
|
|
|
if ($filesdeleted < $filestodelete) {
|
|
|
|
schedule_backup_log($starttime,$preferences->backup_course," $matchfile deleted");
|
2004-08-07 06:02:26 +00:00
|
|
|
mtrace(" $matchfile deleted");
|
2003-12-29 20:24:45 +00:00
|
|
|
$filetodelete = $dirtocheck."/".$matchfile;
|
|
|
|
unlink($filetodelete);
|
|
|
|
$filesdeleted++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $status;
|
|
|
|
}
|
|
|
|
|
2003-12-01 22:00:00 +00:00
|
|
|
?>
|