. /** * Completion data for a specific user, course and critieria * * @package core_completion * @category completion * @copyright 2009 Catalyst IT Ltd * @author Aaron Barnes * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); require_once($CFG->libdir.'/completion/data_object.php'); /** * Completion data for a specific user, course and critieria * * @package core_completion * @category completion * @copyright 2009 Catalyst IT Ltd * @author Aaron Barnes * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class completion_criteria_completion extends data_object { /* @var string Database table that stores completion type criteria */ public $table = 'course_completion_crit_compl'; /* @var array Array of required table fields, must start with 'id'. */ public $required_fields = array('id', 'userid', 'course', 'criteriaid', 'gradefinal', 'rpl', 'deleted', 'unenroled', 'timecompleted'); /* @var array Array of unique fields, used in where clauses */ public $unique_fields = array('userid', 'course', 'criteriaid'); /* @var int User ID */ public $userid; /* @var int course ID */ public $course; /* @var int The id of the course completion criteria this completion references */ public $criteriaid; /* @var float The final grade for the user in the course (if completing a grade criteria) */ public $gradefinal; /* @var string Record of prior learning, leave blank if none */ public $rpl; /* @var bool Course deleted flag */ public $deleted; /* @var int Timestamp of user unenrolment (if completing a unenrol criteria) */ public $unenroled; /* @var int Timestamp of course criteria completion {@link completion_criteria_completion::mark_complete()} */ public $timecompleted; /* @var completion_criterria Associated criteria object */ private $_criteria; /** * Finds and returns a data_object instance based on params. * * @param array $params associative arrays varname=>value * @return data_object instance of data_object or false if none found. */ public static function fetch($params) { $params['deleted'] = null; return self::fetch_helper('course_completion_crit_compl', __CLASS__, $params); } /** * Finds and returns all data_object instances based on params. * * @param array $params associative arrays varname=>value * @return array array of data_object insatnces or false if none found. */ public static function fetch_all($params) {} /** * Return status of this criteria completion * * @return bool */ public function is_complete() { return (bool) $this->timecompleted; } /** * Mark this criteria complete for the associated user * * This method creates a course_completion_crit_compl record */ public function mark_complete() { // Create record $this->timecompleted = time(); // Save record if ($this->id) { $this->update(); } else { $this->insert(); } // Mark course completion record as started (if not already) $cc = array( 'course' => $this->course, 'userid' => $this->userid ); $ccompletion = new completion_completion($cc); $ccompletion->mark_inprogress($this->timecompleted); } /** * Attach a preloaded criteria object to this object * * @param $criteria object completion_criteria */ public function attach_criteria(completion_criteria $criteria) { $this->_criteria = $criteria; } /** * Return the associated criteria with this completion * If nothing attached, load from the db * * @return completion_criteria */ public function get_criteria() { if (!$this->_criteria) { global $DB; $params = array( 'id' => $this->criteriaid ); $record = $DB->get_record('course_completion_criteria', $params); $this->attach_criteria(completion_criteria::factory((array) $record)); } return $this->_criteria; } /** * Return criteria status text for display in reports {@link completion_criteria::get_status()} * * @return string */ public function get_status() { return $this->_criteria->get_status($this); } }