Skip to content

Commit

Permalink
MDL-53716 competency: Backup and restore course competency user data
Browse files Browse the repository at this point in the history
  • Loading branch information
Frederic Massart committed Apr 28, 2016
1 parent 6bd3ab0 commit e9114a9
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 15 deletions.
23 changes: 20 additions & 3 deletions backup/moodle2/backup_stepslib.php
Original file line number Diff line number Diff line change
Expand Up @@ -1541,6 +1541,8 @@ class backup_activity_logstores_structure_step extends backup_course_logstores_s
class backup_course_competencies_structure_step extends backup_structure_step {

protected function define_structure() {
$userinfo = $this->get_setting_value('users');

$wrapper = new backup_nested_element('course_competencies');

$settings = new backup_nested_element('settings', array('id'), array('pushratingstouserplans'));
Expand All @@ -1554,18 +1556,33 @@ protected function define_structure() {
$competencies = new backup_nested_element('competencies');
$wrapper->add_child($competencies);

$competency = new backup_nested_element('competency', null, array('idnumber', 'ruleoutcome',
'sortorder', 'frameworkidnumber'));
$competency = new backup_nested_element('competency', null, array('id', 'idnumber', 'ruleoutcome',
'sortorder', 'frameworkid', 'frameworkidnumber'));
$competencies->add_child($competency);

$sql = 'SELECT c.idnumber, cc.ruleoutcome, cc.sortorder, f.idnumber AS frameworkidnumber
$sql = 'SELECT c.id, c.idnumber, cc.ruleoutcome, cc.sortorder, f.id AS frameworkid, f.idnumber AS frameworkidnumber
FROM {' . \core_competency\course_competency::TABLE . '} cc
JOIN {' . \core_competency\competency::TABLE . '} c ON c.id = cc.competencyid
JOIN {' . \core_competency\competency_framework::TABLE . '} f ON f.id = c.competencyframeworkid
WHERE cc.courseid = :courseid
ORDER BY cc.sortorder';
$competency->set_source_sql($sql, array('courseid' => backup::VAR_COURSEID));

$usercomps = new backup_nested_element('user_competencies');
$wrapper->add_child($usercomps);
if ($userinfo) {
$usercomp = new backup_nested_element('user_competency', null, array('userid', 'competencyid',
'proficiency', 'grade'));
$usercomps->add_child($usercomp);

$sql = 'SELECT ucc.userid, ucc.competencyid, ucc.proficiency, ucc.grade
FROM {' . \core_competency\user_competency_course::TABLE . '} ucc
WHERE ucc.courseid = :courseid
AND ucc.grade IS NOT NULL';
$usercomp->set_source_sql($sql, array('courseid' => backup::VAR_COURSEID));
$usercomp->annotate_ids('user', 'userid');
}

return $wrapper;
}
}
Expand Down
70 changes: 58 additions & 12 deletions backup/moodle2/restore_stepslib.php
Original file line number Diff line number Diff line change
Expand Up @@ -3066,10 +3066,15 @@ class restore_course_competencies_structure_step extends restore_structure_step
* @return array
*/
protected function define_structure() {
$userinfo = $this->get_setting_value('users');
$paths = array(
new restore_path_element('course_competency', '/course_competencies/competencies/competency'),
new restore_path_element('course_competency_settings', '/course_competencies/settings')
new restore_path_element('course_competency_settings', '/course_competencies/settings'),
);
if ($userinfo) {
$paths[] = new restore_path_element('user_competency_course',
'/course_competencies/user_competencies/user_competency');
}
return $paths;
}

Expand All @@ -3080,22 +3085,27 @@ protected function define_structure() {
*/
public function process_course_competency_settings($data) {
global $DB;

$data = (object) $data;

// We do not restore the course settings during merge.
$target = $this->get_task()->get_target();
if ($target == backup::TARGET_CURRENT_ADDING || $target == backup::TARGET_EXISTING_ADDING) {
return;
}

$courseid = $this->task->get_courseid();
$exists = \core_competency\course_competency_settings::get_record(array('courseid' => $courseid));
$exists = \core_competency\course_competency_settings::record_exists_select('courseid = :courseid',
array('courseid' => $courseid));

// Now update or insert.
// Strangely the course settings already exist, let's just leave them as is then.
if ($exists) {
$settings = $exists;
$settings->set_pushratingstouserplans($data->pushratingstouserplans);
return $settings->update();
} else {
$data = (object) array('courseid' => $courseid, 'pushratingstouserplans' => $data->pushratingstouserplans);
$settings = new \core_competency\course_competency_settings(0, $data);
$result = $settings->create();
return !empty($result);
$this->log('Course competency settings not restored, existing settings have been found.', backup::LOG_WARNING);
return;
}

$data = (object) array('courseid' => $courseid, 'pushratingstouserplans' => $data->pushratingstouserplans);
$settings = new \core_competency\course_competency_settings(0, $data);
$settings->create();
}

/**
Expand All @@ -3116,6 +3126,7 @@ public function process_course_competency($data) {
if (!$competency) {
return;
}
$this->set_mapping(\core_competency\competency::TABLE, $data->id, $competency->get_id());

$params = array(
'competencyid' => $competency->get_id(),
Expand All @@ -3133,6 +3144,41 @@ public function process_course_competency($data) {
}
}

/**
* Process the user competency course.
*
* @param array $data The data.
*/
public function process_user_competency_course($data) {
global $USER, $DB;
$data = (object) $data;

$data->competencyid = $this->get_mappingid(\core_competency\competency::TABLE, $data->competencyid);
if (!$data->competencyid) {
// This is strange, the competency does not belong to the course.
return;
} else if ($data->grade === null) {
// We do not need to do anything when there is no grade.
return;
}

$data->userid = $this->get_mappingid('user', $data->userid);
$shortname = $DB->get_field('course', 'shortname', array('id' => $this->task->get_courseid()), MUST_EXIST);

// The method add_evidence also sets the course rating.
\core_competency\api::add_evidence($data->userid,
$data->competencyid,
$this->task->get_contextid(),
\core_competency\evidence::ACTION_OVERRIDE,
'evidence_courserestored',
'core_competency',
$shortname,
false,
null,
$data->grade,
$USER->id);
}

/**
* Execute conditions.
*
Expand Down
1 change: 1 addition & 0 deletions lang/en/competency.php
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@
$string['evidence_competencyrule'] = 'The rule of the competency was met.';
$string['evidence_coursecompleted'] = 'The course \'{$a}\' was completed.';
$string['evidence_coursemodulecompleted'] = 'The activity \'{$a}\' was completed.';
$string['evidence_courserestored'] = 'The rating was restored along with the course \'{$a}\'.';
$string['evidence_evidenceofpriorlearninglinked'] = 'The evidence of prior learning \'{$a}\' was linked.';
$string['evidence_evidenceofpriorlearningunlinked'] = 'The evidence of prior learning \'{$a}\' was unlinked.';
$string['evidence_manualoverride'] = 'The competency rating was manually set.';
Expand Down

0 comments on commit e9114a9

Please sign in to comment.