. /** * Self enrol plugin implementation. * * @package enrol_ilbead * @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_ilbead_enrol_form extends moodleform { protected $instance; protected $toomany = false; /** * Overriding this function to get unique form id for multiple ilbead enrolments. * * @return string form identifier */ protected function get_form_identifier() { $formid = $this->_customdata->id.'_'.get_class($this); return $formid; } public function definition() { global $DB; global $USER; $mform = $this->_form; $instance = $this->_customdata; $this->instance = $instance; $plugin = enrol_get_plugin('ilbead'); $heading = $plugin->get_instance_name($instance); $mform->addElement('header', 'ilbeadheader', $heading); if (trim($instance->customtext2) !== '') { $instance->customtext2 = unserialize($instance->customtext2); $message = format_text($instance->customtext2['text'], $instance->customtext2['format']); $mform->addElement('static', 'notice', '', $message); } if ($instance->customint3 > 0) { // Max enrol limit specified. $count = $DB->count_records('user_enrolments', array('enrolid'=>$instance->id)); if ($count >= $instance->customint3) { // Bad luck, no more ilbead enrolments here. $this->toomany = true; $mform->addElement('static', 'notice', '', get_string('maxenrolledreached', 'enrol_ilbead')); return; } } if ($instance->password) { // Change the id of ilbead enrolment key input as there can be multiple ilbead enrolment methods. $mform->addElement('passwordunmask', 'enrolpassword', get_string('password', 'enrol_ilbead'), array('id' => 'enrolpassword_'.$instance->id)); } else { $mform->addElement('static', 'nokey', '', get_string('nopassword', 'enrol_ilbead')); } $this->add_action_buttons(false, get_string('enrolme', 'enrol_ilbead')); $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 ($this->toomany) { $errors['notice'] = get_string('error'); return $errors; } if ($instance->password) { if ($data['enrolpassword'] !== $instance->password) { if ($instance->customint1) { $groups = $DB->get_records('groups', array('courseid'=>$instance->courseid), 'id ASC', 'id, enrolmentkey'); $found = false; foreach ($groups as $group) { if (empty($group->enrolmentkey)) { continue; } if ($group->enrolmentkey === $data['enrolpassword']) { $found = true; break; } } if (!$found) { // We can not hint because there are probably multiple passwords. $errors['enrolpassword'] = get_string('passwordinvalid', 'enrol_ilbead'); } } else { $plugin = enrol_get_plugin('ilbead'); if ($plugin->get_config('showhint')) { $hint = textlib::substr($instance->password, 0, 1); $errors['enrolpassword'] = get_string('passwordinvalidhint', 'enrol_ilbead', $hint); } else { $errors['enrolpassword'] = get_string('passwordinvalid', 'enrol_ilbead'); } } } } return $errors; } }