id) // | // | // | // |------------------------------|---------------------------------------------| // | | // | | // | exercise_submissions // | (UL,pk->id,fk->exerciseid,files) // | | // | | // | | // | |---------------------| |------------------------------| | // | | | | | | // exercise_elements exercise_grades exercise_assessments // (CL,pk->id,fk->exerciseid) (UL,pk->id,fk->assessmentid) (UL,pk->id,fk->submissionid) // | ( fk->elementno ) // | // | // exercise_rubrics // (CL,pk->id,fk->elementno) // // Meaning: pk->primary key field of the table // fk->foreign key to link with parent // nt->nested field (recursive data) // CL->course level info // UL->user level info // files->table may have files) // //----------------------------------------------------------- //This function executes all the backup procedure about this mod function exercise_backup_mods($bf,$preferences) { global $CFG; $status = true; //Iterate over exercise table $exercises = get_records ("exercise","course",$preferences->backup_course,"id"); if ($exercises) { foreach ($exercises as $exercise) { //Start mod fwrite ($bf,start_tag("MOD",3,true)); //Print exercise data fwrite ($bf,full_tag("ID",4,false,$exercise->id)); fwrite ($bf,full_tag("MODTYPE",4,false,"exercise")); fwrite ($bf,full_tag("NAME",4,false,$exercise->name)); fwrite ($bf,full_tag("NELEMENTS",4,false,$exercise->nelements)); fwrite ($bf,full_tag("PHASE",4,false,$exercise->phase)); fwrite ($bf,full_tag("GRADINGSTRATEGY",4,false,$exercise->gradingstrategy)); fwrite ($bf,full_tag("USEMAXIMUM",4,false,$exercise->usemaximum)); fwrite ($bf,full_tag("ANONYMOUS",4,false,$exercise->anonymous)); fwrite ($bf,full_tag("MAXBYTES",4,false,$exercise->maxbytes)); fwrite ($bf,full_tag("DEADLINE",4,false,$exercise->deadline)); fwrite ($bf,full_tag("GRADE",4,false,$exercise->grade)); fwrite ($bf,full_tag("TIMEMODIFIED",4,false,$exercise->timemodified)); fwrite ($bf,full_tag("TEACHERWEIGHT",4,false,$exercise->teacherweight)); fwrite ($bf,full_tag("GRADINGWEIGHT",4,false,$exercise->gradingweight)); fwrite ($bf,full_tag("SHOWLEAGUETABLE",4,false,$exercise->showleaguetable)); //Now we backup exercise elements $status = backup_exercise_elements($bf,$preferences,$exercise->id); //Now we backup any teacher submissions (these are an integral part of the exercise) $status = backup_exercise_submissions($bf, $preferences, $exercise->id); //End mod $status =fwrite ($bf,end_tag("MOD",3,true)); //we need to backup the teacher files (the exercise descriptions) $status = backup_exercise_teacher_files($bf, $preferences, $exercise->id); //if we've selected to backup users info, then backup files too if ($status) { if ($preferences->mods["exercise"]->userinfo) { $status = backup_exercise_student_files($bf,$preferences, $exercise->id); } } } } return $status; } //Backup exercise_elements contents (executed from exercise_backup_mods) function backup_exercise_elements ($bf,$preferences,$exercise) { global $CFG; $status = true; $exercise_elements = get_records("exercise_elements","exerciseid",$exercise,"id"); //If there is exercise_elements if ($exercise_elements) { //Write start tag $status =fwrite ($bf,start_tag("ELEMENTS",4,true)); //Iterate over each element foreach ($exercise_elements as $element) { //Start element $status =fwrite ($bf,start_tag("ELEMENT",5,true)); //Print element contents fwrite ($bf,full_tag("ELEMENTNO",6,false,$element->elementno)); fwrite ($bf,full_tag("DESCRIPTION",6,false,$element->description)); fwrite ($bf,full_tag("SCALE",6,false,$element->scale)); fwrite ($bf,full_tag("MAXSCORE",6,false,$element->maxscore)); fwrite ($bf,full_tag("WEIGHT",6,false,$element->weight)); //Now we backup exercise rubrics $status = backup_exercise_rubrics($bf,$preferences,$exercise,$element->elementno); //End element $status =fwrite ($bf,end_tag("ELEMENT",5,true)); } //Write end tag $status =fwrite ($bf,end_tag("ELEMENTS",4,true)); } return $status; } //Backup exercise_rubrics contents (executed from backup_exercise_elements) function backup_exercise_rubrics ($bf,$preferences,$exercise,$elementno) { global $CFG; $status = true; $exercise_rubrics = get_records_sql("SELECT * from {$CFG->prefix}exercise_rubrics r WHERE r.exerciseid = '$exercise' and r.elementno = '$elementno' ORDER BY r.elementno"); //If there is exercise_rubrics if ($exercise_rubrics) { //Write start tag $status =fwrite ($bf,start_tag("RUBRICS",6,true)); //Iterate over each element foreach ($exercise_rubrics as $rubric) { //Start rubric $status =fwrite ($bf,start_tag("RUBRIC",7,true)); //Print rubric contents fwrite ($bf,full_tag("RUBRICNO",8,false,$rubric->rubricno)); fwrite ($bf,full_tag("DESCRIPTION",8,false,$rubric->description)); //End rubric $status =fwrite ($bf,end_tag("RUBRIC",7,true)); } //Write end tag $status =fwrite ($bf,end_tag("RUBRICS",6,true)); } return $status; } //Backup exercise_submissions contents (executed from exercise_backup_mods) function backup_exercise_submissions ($bf,$preferences,$exerciseid) { global $CFG; $status = true; $exercise_submissions = get_records_select("exercise_submissions","exerciseid = $exerciseid AND isexercise = 1"); //If there is submissions if ($exercise_submissions) { //Write start tag $status =fwrite ($bf,start_tag("SUBMISSIONS",4,true)); //Iterate over each submission foreach ($exercise_submissions as $submission) { //Start submission $status =fwrite ($bf,start_tag("SUBMISSION",5,true)); //Print submission contents fwrite ($bf,full_tag("ID",6,false,$submission->id)); fwrite ($bf,full_tag("USERID",6,false,$submission->userid)); fwrite ($bf,full_tag("TITLE",6,false,$submission->title)); fwrite ($bf,full_tag("TIMECREATED",6,false,$submission->timecreated)); fwrite ($bf,full_tag("RESUBMIT",6,false,$submission->resubmit)); fwrite ($bf,full_tag("MAILED",6,false,$submission->mailed)); fwrite ($bf,full_tag("ISEXERCISE",6,false,$submission->isexercise)); //Now we backup any exercise assessments (if student data required) if ($preferences->mods["exercise"]->userinfo) { $status = backup_exercise_assessments($bf,$preferences,$exerciseid,$submission->id); } //End submission $status =fwrite ($bf,end_tag("SUBMISSION",5,true)); } //if we've selected to backup users info, then backup the student submisions if ($preferences->mods["exercise"]->userinfo) { $exercise_submissions = get_records_select("exercise_submissions","exerciseid = $exerciseid AND isexercise = 0"); //If there is submissions if ($exercise_submissions) { //Iterate over each submission foreach ($exercise_submissions as $submission) { //Start submission $status =fwrite ($bf,start_tag("SUBMISSION",5,true)); //Print submission contents fwrite ($bf,full_tag("ID",6,false,$submission->id)); fwrite ($bf,full_tag("USERID",6,false,$submission->userid)); fwrite ($bf,full_tag("TITLE",6,false,$submission->title)); fwrite ($bf,full_tag("TIMECREATED",6,false,$submission->timecreated)); fwrite ($bf,full_tag("RESUBMIT",6,false,$submission->resubmit)); fwrite ($bf,full_tag("MAILED",6,false,$submission->mailed)); fwrite ($bf,full_tag("ISEXERCISE",6,false,$submission->isexercise)); fwrite ($bf,full_tag("LATE",6,false,$submission->late)); //Now we backup any exercise assessments $status = backup_exercise_assessments($bf,$preferences,$exerciseid,$submission->id); //End submission $status =fwrite ($bf,end_tag("SUBMISSION",5,true)); } } } //Write end tag $status =fwrite ($bf,end_tag("SUBMISSIONS",4,true)); } return $status; } //Backup exercise_student_submissions contents (executed from exercise_backup_mods) function backup_exercise_student_submissions ($bf,$preferences,$exerciseid) { global $CFG; $status = true; return $status; } //Backup exercise_assessments contents (executed from backup_exercise_submissions) function backup_exercise_assessments ($bf,$preferences,$exercise,$submission) { global $CFG; $status = true; //NOTE: I think that the exerciseid can go out (submissionid is a good unique fk), but mantain it, as is in db !! $exercise_assessments = get_records_sql("SELECT * from {$CFG->prefix}exercise_assessments a WHERE a.exerciseid = '$exercise' and a.submissionid = '$submission' ORDER BY a.id"); //If there is exercise_assessments if ($exercise_assessments) { //Write start tag $status =fwrite ($bf,start_tag("ASSESSMENTS",6,true)); //Iterate over each assessment foreach ($exercise_assessments as $wor_ass) { //Start assessment $status =fwrite ($bf,start_tag("ASSESSMENT",7,true)); //Print assessment contents fwrite ($bf,full_tag("ID",8,false,$wor_ass->id)); fwrite ($bf,full_tag("USERID",8,false,$wor_ass->userid)); fwrite ($bf,full_tag("TIMECREATED",8,false,$wor_ass->timecreated)); fwrite ($bf,full_tag("TIMEGRADED",8,false,$wor_ass->timegraded)); fwrite ($bf,full_tag("GRADE",8,false,$wor_ass->grade)); fwrite ($bf,full_tag("GRADINGGRADE",8,false,$wor_ass->gradinggrade)); fwrite ($bf,full_tag("MAILED",8,false,$wor_ass->mailed)); fwrite ($bf,full_tag("GENERALCOMMENT",8,false,$wor_ass->generalcomment)); fwrite ($bf,full_tag("TEACHERCOMMENT",8,false,$wor_ass->teachercomment)); //Now we backup exercise grades $status = backup_exercise_grades($bf,$preferences,$exercise,$wor_ass->id); //End assessment $status =fwrite ($bf,end_tag("ASSESSMENT",7,true)); } //Write end tag $status =fwrite ($bf,end_tag("ASSESSMENTS",6,true)); } return $status; } //Backup exercise_grades contents (executed from backup_exercise_assessments) function backup_exercise_grades ($bf,$preferences,$exercise,$assessmentid) { global $CFG; $status = true; //NOTE: I think that the exerciseid can go out (assessmentid is a good unique fk), but mantain it, as is in db !! $exercise_grades = get_records_sql("SELECT * from {$CFG->prefix}exercise_grades g WHERE g.exerciseid = '$exercise' and g.assessmentid = '$assessmentid' ORDER BY g.elementno"); //If there is exercise_grades if ($exercise_grades) { //Write start tag $status =fwrite ($bf,start_tag("GRADES",8,true)); //Iterate over each grade foreach ($exercise_grades as $wor_gra) { //Start grade $status =fwrite ($bf,start_tag("GRADE",9,true)); //Print grade contents fwrite ($bf,full_tag("ELEMENTNO",10,false,$wor_gra->elementno)); fwrite ($bf,full_tag("FEEDBACK",10,false,$wor_gra->feedback)); fwrite ($bf,full_tag("GRADE_VALUE",10,false,$wor_gra->grade)); //End comment $status =fwrite ($bf,end_tag("GRADE",9,true)); } //Write end tag $status =fwrite ($bf,end_tag("GRADES",8,true)); } return $status; } //Backup the teacher's exercise files (they are an integral part of the exercise) function backup_exercise_teacher_files($bf,$preferences, $exerciseid) { global $CFG; $status = true; //First we check to moddata exists and create it as necessary //in temp/backup/$backup_code dir $status = check_and_create_moddata_dir($preferences->backup_unique_code); //in temp/backup/$backup_code/moddate create the exercise diretory $status = check_dir_exists("$CFG->dataroot/temp/backup/$preferences->backup_unique_code/moddata/exercise", true); if ($status) { //Now copy the submission dirs if ($submissions = get_records_select("exercise_submissions", "exerciseid = $exerciseid AND isexercise = 1")) { foreach ($submissions as $submission) { //Only if it exists !! Thanks to Daniel Miksik. if (is_dir("{$CFG->dataroot}/$preferences->backup_course/{$CFG->moddata}/exercise/$submission->id")) { // create directory // $status = check_dir_exists("$CFG->dataroot/temp/backup/$preferences->backup_unique_code/moddata/exercise", true); // copy all the files in the directory $status = backup_copy_file("{$CFG->dataroot}/$preferences->backup_course/{$CFG->moddata}/exercise/$submission->id", "{$CFG->dataroot}/temp/backup/$preferences->backup_unique_code/moddata/exercise/$submission->id"); } } } } return $status; } //Backup students' exercise files because we've selected to backup user info //and files are user info's level function backup_exercise_student_files($bf,$preferences, $exerciseid) { global $CFG; $status = true; //First we check to moddata exists and create it as necessary //in temp/backup/$backup_code dir $status = check_and_create_moddata_dir($preferences->backup_unique_code); if ($status) { //Now copy the submission dirs if ($submissions = get_records_select("exercise_submissions", "exerciseid = $exerciseid AND isexercise = 0")) { foreach ($submissions as $submission) { //Only if it exists !! Thanks to Daniel Miksik. if (is_dir("{$CFG->dataroot}/$preferences->backup_course/$CFG->moddata/exercise/$submission->id")) { $status = backup_copy_file("{$CFG->dataroot}/$preferences->backup_course/{$CFG->moddata}/exercise/$submission->id", "{$CFG->dataroot}/temp/backup/$preferences->backup_unique_code/moddata/exercise/$submission->id"); } } } } return $status; } //Return an array of info (name,value) function exercise_check_backup_mods($course,$user_data=false,$backup_unique_code) { //First the course data $info[0][0] = get_string("modulenameplural","exercise"); if ($ids = exercise_ids ($course)) { $info[0][1] = count($ids); } else { $info[0][1] = 0; } //Now, if requested, the user_data if ($user_data) { $info[1][0] = get_string("submissions","exercise"); if ($ids = exercise_submission_ids_by_course ($course)) { $info[1][1] = count($ids); } else { $info[1][1] = 0; } } return $info; } // INTERNAL FUNCTIONS. BASED IN THE MOD STRUCTURE //Returns an array of exercise id function exercise_ids ($course) { global $CFG; return get_records_sql ("SELECT w.id, w.course FROM {$CFG->prefix}exercise w WHERE w.course = '$course'"); } //Returns an array of exercise_submissions id function exercise_submission_ids_by_course ($course) { global $CFG; return get_records_sql ("SELECT s.id , s.exerciseid FROM {$CFG->prefix}exercise_submissions s, {$CFG->prefix}exercise w WHERE w.course = '$course' AND s.exerciseid = w.id"); } ?>