. /** * Self enrol plugin implementation. * * @package enrol_self * @copyright 2010 Petr Skoda {@link http://skodak.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die; require_once("$CFG->libdir/formslib.php"); class enrol_self_enrol_form extends moodleform { protected $instance; public function definition() { $mform = $this->_form; $instance = $this->_customdata; $this->instance = $instance; $plugin = enrol_get_plugin('self'); if ($instance->password) { $heading = $plugin->get_instance_name($instance); $mform->addElement('header', 'selfheader', $heading); $mform->addElement('passwordunmask', 'enrolpassword', get_string('password', 'enrol_self')); } else { // nothing? } $this->add_action_buttons(false, get_string('enrolme', 'enrol_self')); $mform->addElement('hidden', 'id'); $mform->setType('id', PARAM_INT); $mform->setDefault('id', $instance->courseid); $mform->addElement('hidden', 'instance'); $mform->setType('instance', PARAM_INT); $mform->setDefault('instance', $instance->id); } public function validation($data, $files) { global $DB, $CFG; $errors = parent::validation($data, $files); $instance = $this->instance; if ($instance->password) { if ($data['enrolpassword'] !== $instance->password) { if ($instance->customint1) { //TODO: check groups } else { $plugin = enrol_get_plugin('self'); if ($plugin->get_config('showhint')) { $textlib = textlib_get_instance(); $hint = $textlib->substr($instance->password, 0, 1); $errors['enrolpassword'] = get_string('passwordinvalidhint', 'enrol_self', $hint); } else { $errors['enrolpassword'] = get_string('passwordinvalid', 'enrol_self'); } } } } return $errors; } }