get_instance_defaults(); return $this->add_instance($course, $fields); } public function allow_unenrol(stdClass $instance) { // users with unenrol cap may unenrol other users manually manually return true; } public function get_newinstance_link($courseid) { $context = context_course::instance($courseid, MUST_EXIST); if (!has_capability('moodle/course:enrolconfig', $context) or !has_capability('enrol/apply:config', $context)) { return NULL; } // multiple instances supported - different roles with different password return new moodle_url('/enrol/apply/edit.php', array('courseid'=>$courseid)); } public function enrol_page_hook(stdClass $instance) { global $CFG, $OUTPUT, $SESSION, $USER, $DB; if (isguestuser()) { // can not enrol guest!! return null; } if ($DB->record_exists('user_enrolments', array('userid'=>$USER->id, 'enrolid'=>$instance->id))) { //TODO: maybe we should tell them they are already enrolled, but can not access the course //return null; return $OUTPUT->notification(get_string('notification', 'enrol_apply'), 'notifysuccess'); } require_once("$CFG->dirroot/enrol/apply/locallib.php"); $form = new enrol_apply_enrol_form(NULL, $instance); $instanceid = optional_param('instance', 0, PARAM_INT); if ($instance->id == $instanceid) { if ($data = $form->get_data()) { $userInfo = $data; $applydescription = $userInfo->applydescription; unset($userInfo->applydescription); $userInfo->id = $USER->id; $apply_setting = $DB->get_records_sql("select name,value from ".$CFG->prefix."config_plugins where plugin='enrol_apply'"); $show_standard_user_profile = $show_extra_user_profile = false; if($instance->customint1 != ''){ ($instance->customint1 == 0)?$show_standard_user_profile = true:$show_standard_user_profile = false; }else{ ($apply_setting['show_standard_user_profile']->value == 0)?$show_standard_user_profile = true:$show_standard_user_profile = false; } if($instance->customint2 != ''){ ($instance->customint2 == 0)?$show_extra_user_profile = true:$show_extra_user_profile = false; }else{ ($apply_setting['show_extra_user_profile']->value == 0)?$show_extra_user_profile = true:$show_extra_user_profile = false; } if(!$show_standard_user_profile && $show_extra_user_profile){ profile_save_data($userInfo); $res = $DB->update_record('user',$userInfoProfile); //$res = $DB->update_record('user',$userInfo); } /*elseif($show_standard_user_profile && $show_extra_user_profile){ profile_save_data($userInfo); $res = $DB->update_record('user',$userInfo); }*/ $enrol = enrol_get_plugin('self'); $timestart = time(); if ($instance->enrolperiod) { $timeend = $timestart + $instance->enrolperiod; } else { $timeend = 0; } $roleid = $instance->roleid; if(!$roleid){ $role = $DB->get_record_sql("select * from ".$CFG->prefix."role where archetype='student' limit 1"); $roleid = $role->id; } $this->enrol_user($instance, $USER->id, $roleid, $timestart, $timeend,1); $userenrolment = $DB->get_record('user_enrolments', array('userid' => $USER->id, 'enrolid' => $instance->id), 'id', MUST_EXIST); $applicationinfo = new stdClass(); $applicationinfo->userenrolmentid = $userenrolment->id; $applicationinfo->comment = $applydescription; $DB->insert_record('enrol_apply_applicationinfo', $applicationinfo, false); sendConfirmMailToTeachers($instance, $data, $applydescription); sendConfirmMailToManagers($instance, $data, $applydescription); // Deprecated fixed by Shiro //add_to_log($instance->courseid, 'course', 'enrol', '../enrol/users.php?id='.$instance->courseid, $instance->courseid); //there should be userid somewhere! $context = context_course::instance($instance->courseid); \core\event\user_enrolment_created::create( array( 'objectid' => $instance->id, 'courseid' => $instance->courseid, 'context' => $context, 'relateduserid' => $USER->id, 'other' => array('enrol' => 'apply') ))->trigger(); redirect("$CFG->wwwroot/course/view.php?id=$instance->courseid"); } } //exit; ob_start(); $form->display(); $output = ob_get_clean(); return $OUTPUT->box($output); } public function get_action_icons(stdClass $instance) { global $OUTPUT; if ($instance->enrol !== 'apply') { throw new coding_exception('invalid enrol instance!'); } $context = context_course::instance($instance->courseid); $icons = array(); if (has_capability('enrol/apply:config', $context)) { $editlink = new moodle_url("/enrol/apply/edit.php", array('courseid'=>$instance->courseid, 'id'=>$instance->id)); $icons[] = $OUTPUT->action_icon($editlink, new pix_icon('t/edit', get_string('edit'), 'core', array('class' => 'iconsmall'))); } if (has_capability('enrol/apply:manage', $context)) { $managelink = new moodle_url("/enrol/apply/apply.php", array('id'=>$_GET['id'],'enrolid'=>$instance->id)); $icons[] = $OUTPUT->action_icon($managelink, new pix_icon('i/users', get_string('confirmenrol', 'enrol_apply'), 'core', array('class'=>'iconsmall'))); } if (has_capability("enrol/apply:enrol", $context)) { $enrollink = new moodle_url("/enrol/apply/enroluser.php", array('enrolid'=>$instance->id)); $icons[] = $OUTPUT->action_icon($enrollink, new pix_icon('t/enrolusers', get_string('enrolusers', 'enrol_apply'), 'core', array('class'=>'iconsmall'))); } return $icons; } /** * Is it possible to hide/show enrol instance via standard UI? * * @param stdClass $instance * @return bool */ public function can_hide_show_instance($instance) { $context = context_course::instance($instance->courseid); return has_capability('enrol/apply:config', $context); } /** * Is it possible to delete enrol instance via standard UI? * * @param stdClass $instance * @return bool */ public function can_delete_instance($instance) { $context = context_course::instance($instance->courseid); return has_capability('enrol/apply:config', $context); } /** * Sets up navigation entries. * * @param stdClass $instancesnode * @param stdClass $instance * @return void */ public function add_course_navigation($instancesnode, stdClass $instance) { if ($instance->enrol !== 'apply') { throw new coding_exception('Invalid enrol instance type!'); } $context = context_course::instance($instance->courseid); if (has_capability('enrol/apply:config', $context)) { $managelink = new moodle_url('/enrol/apply/edit.php', array('courseid'=>$instance->courseid, 'id'=>$instance->id)); $instancesnode->add($this->get_instance_name($instance), $managelink, navigation_node::TYPE_SETTING); } } public function get_user_enrolment_actions(course_enrolment_manager $manager, $ue) { $actions = array(); $context = $manager->get_context(); $instance = $ue->enrolmentinstance; $params = $manager->get_moodlepage()->url->params(); $params['ue'] = $ue->id; if ($this->allow_unenrol($instance) && has_capability("enrol/apply:unenrol", $context)) { $url = new moodle_url('/enrol/apply/unenroluser.php', $params); $actions[] = new user_enrolment_action(new pix_icon('t/delete', ''), get_string('unenrol', 'enrol'), $url, array('class'=>'unenrollink', 'rel'=>$ue->id)); } if ($this->allow_manage($instance) && has_capability("enrol/apply:manage", $context)) { $url = new moodle_url('/enrol/apply/editenrolment.php', $params); $actions[] = new user_enrolment_action(new pix_icon('t/edit', ''), get_string('edit'), $url, array('class'=>'editenrollink', 'rel'=>$ue->id)); } return $actions; } /** * Returns defaults for new instances. * @return array */ public function get_instance_defaults() { $fields = array(); $fields['status'] = $this->get_config('status'); $fields['roleid'] = $this->get_config('roleid', 0); $fields['customint1'] = $this->get_config('show_standard_user_profile'); $fields['customint2'] = $this->get_config('show_extra_user_profile'); $fields['customint3'] = $this->get_config('sendmailtoteacher'); $fields['customint4'] = $this->get_config('sendmailtomanager'); return $fields; } } function getAllEnrolment($id = null) { global $DB; if ($id) { $sql = 'SELECT ue.userid,ue.id,u.firstname,u.lastname,u.email,u.picture,c.fullname as course,ue.timecreated,ue.status FROM {course} c JOIN {enrol} e ON e.courseid = c.id JOIN {user_enrolments} ue ON ue.enrolid = e.id JOIN {user} u ON ue.userid = u.id WHERE ue.status != 0 AND e.id = ?'; $userenrolments = $DB->get_records_sql($sql, array($id)); } else { $sql = 'SELECT ue.id,ue.userid,u.firstname,u.lastname,u.email,u.picture,c.fullname as course,ue.timecreated FROM {user_enrolments} ue LEFT JOIN {user} u ON ue.userid = u.id LEFT JOIN {enrol} e ON ue.enrolid = e.id LEFT JOIN {course} c ON e.courseid = c.id WHERE ue.status != 0 AND e.enrol = ?'; $userenrolments = $DB->get_records_sql($sql, array('apply')); } return $userenrolments; } function confirmEnrolment($enrols){ global $DB; global $CFG; foreach ($enrols as $enrol){ @$enroluser->id = $enrol; @$enroluser->status = 0; if($DB->update_record('user_enrolments',$enroluser)){ $userenrolments = $DB->get_record_sql('select * from '.$CFG->prefix.'user_enrolments where id='.$enrol); $role = $DB->get_record_sql("select * from ".$CFG->prefix."role where archetype='student' limit 1"); @$roleAssignments->userid = $userenrolments->userid; @$roleAssignments->roleid = $role->id; @$roleAssignments->contextid = 3; @$roleAssignments->timemodified = time(); @$roleAssignments->modifierid = 2; $DB->insert_record('role_assignments',$roleAssignments); $info = getRelatedInfo($enrol); $DB->delete_records('enrol_apply_applicationinfo', array('userenrolmentid' => $enrol)); sendConfirmMail($info); } } } function waitEnrolment($enrols){ global $DB; global $CFG; foreach ($enrols as $enrol){ @$enroluser->id = $enrol; @$enroluser->status = 2; if($DB->update_record('user_enrolments',$enroluser)){ $info = getRelatedInfo($enrol); sendWaitMail($info); } } } function cancelEnrolment($enrols){ global $DB; foreach ($enrols as $enrol){ $info = getRelatedInfo($enrol); if($DB->delete_records('user_enrolments',array('id'=>$enrol))){ $DB->delete_records('enrol_apply_applicationinfo', array('userenrolmentid' => $enrol)); sendCancelMail($info); } } } function sendCancelMail($info){ global $DB; global $CFG; $apply_setting = $DB->get_records_sql("select name,value from ".$CFG->prefix."config_plugins where plugin='enrol_apply'"); $replace = array('firstname'=>$info->firstname,'content'=>format_string($info->coursename),'lastname'=>$info->lastname,'username'=>$info->username); $body = $apply_setting['cancelmailcontent']->value; $body = updateMailContent($body,$replace); $contact = core_user::get_support_user(); email_to_user($info, $contact, $apply_setting['cancelmailsubject']->value, html_to_text($body), $body); } function sendConfirmMail($info){ global $DB; global $CFG; $apply_setting = $DB->get_records_sql("select name,value from ".$CFG->prefix."config_plugins where plugin='enrol_apply'"); $replace = array('firstname'=>$info->firstname,'content'=>format_string($info->coursename),'lastname'=>$info->lastname,'username'=>$info->username); $body = $apply_setting['confirmmailcontent']->value; $body = updateMailContent($body,$replace); $contact = core_user::get_support_user(); email_to_user($info, $contact, $apply_setting['confirmmailsubject']->value, html_to_text($body), $body); } function sendWaitMail($info){ global $DB; global $CFG; //global $USER; $apply_setting = $DB->get_records_sql("select name,value from ".$CFG->prefix."config_plugins where plugin='enrol_apply'"); $replace = array('firstname'=>$info->firstname,'content'=>format_string($info->coursename),'lastname'=>$info->lastname,'username'=>$info->username); $body = get_config('enrol_apply', 'waitmailcontent'); $body = updateMailContent($body,$replace); $contact = get_admin(); //confirm mail will sent by the admin //$contact = $USER; email_to_user($info, $contact, get_config('enrol_apply', 'waitmailsubject'), html_to_text($body), $body); } function sendConfirmMailToTeachers($instance,$info,$applydescription){ global $DB; global $CFG; global $USER; $courseid = $instance->courseid; $instanceid = $instance->id; $apply_setting = $DB->get_records_sql("select name,value from ".$CFG->prefix."config_plugins where plugin='enrol_apply'"); $show_standard_user_profile = $show_extra_user_profile = false; if($instance->customint1 != ''){ ($instance->customint1 == 0)?$show_standard_user_profile = true:$show_standard_user_profile = false; }else{ ($apply_setting['show_standard_user_profile']->value == 0)?$show_standard_user_profile = true:$show_standard_user_profile = false; } if($instance->customint2 != ''){ ($instance->customint2 == 0)?$show_extra_user_profile = true:$show_extra_user_profile = false; }else{ ($apply_setting['show_extra_user_profile']->value == 0)?$show_extra_user_profile = true:$show_extra_user_profile = false; } if($instance->customint3 == 1){ $course = get_course($courseid); $context = context_course::instance($courseid, MUST_EXIST); $teacherType = $DB->get_record('role',array("shortname"=>"editingteacher")); $teachers = $DB->get_records('role_assignments', array('contextid'=>$context->id,'roleid'=>$teacherType->id)); foreach($teachers as $teacher){ $editTeacher = $DB->get_record('user',array('id'=>$teacher->userid)); $body = '

'. get_string('coursename', 'enrol_apply') .': '.format_string($course->fullname).'

'; $body .= '

'. get_string('applyuser', 'enrol_apply') .': '.$USER->firstname.' '.$USER->lastname.'

'; $body .= '

'. get_string('comment', 'enrol_apply') .': '.$applydescription.'

'; if($show_standard_user_profile){ $body .= '

'. get_string('user_profile', 'enrol_apply').'

'; $body .= '

'. get_string('firstname') .': '.$info->firstname.'

'; $body .= '

'. get_string('lastname') .': '.$info->lastname.'

'; $body .= '

'. get_string('email') .': '.$info->email.'

'; $body .= '

'. get_string('city') .': '.$info->city.'

'; $body .= '

'. get_string('country') .': '.$info->country.'

'; $body .= '

'. get_string('preferredlanguage') .': '.$info->lang.'

'; $body .= '

'. get_string('description') .': '.$info->description_editor['text'].'

'; $body .= '

'. get_string('firstnamephonetic') .': '.$info->firstnamephonetic.'

'; $body .= '

'. get_string('lastnamephonetic') .': '.$info->lastnamephonetic.'

'; $body .= '

'. get_string('middlename') .': '.$info->middlename.'

'; $body .= '

'. get_string('alternatename') .': '.$info->alternatename.'

'; $body .= '

'. get_string('url') .': '.$info->url.'

'; $body .= '

'. get_string('icqnumber') .': '.$info->icq.'

'; $body .= '

'. get_string('skypeid') .': '.$info->skype.'

'; $body .= '

'. get_string('aimid') .': '.$info->aim.'

'; $body .= '

'. get_string('yahooid') .': '.$info->yahoo.'

'; $body .= '

'. get_string('msnid') .': '.$info->msn.'

'; $body .= '

'. get_string('idnumber') .': '.$info->idnumber.'

'; $body .= '

'. get_string('institution') .': '.$info->institution.'

'; $body .= '

'. get_string('department') .': '.$info->department.'

'; $body .= '

'. get_string('phone') .': '.$info->phone1.'

'; $body .= '

'. get_string('phone2') .': '.$info->phone2.'

'; $body .= '

'. get_string('address') .': '.$info->address.'

'; } if($show_extra_user_profile){ require_once($CFG->dirroot.'/user/profile/lib.php'); $user = $DB->get_record('user',array('id'=>$USER->id)); profile_load_custom_fields($user); foreach ($user->profile as $key => $value) { $body .= '

'. $key .': '.$value.'

'; } } $body .= '

'. html_writer::link(new moodle_url("/enrol/apply/apply.php", array('id'=>$courseid,'enrolid'=>$instanceid)), get_string('applymanage', 'enrol_apply')).'

'; $contact = core_user::get_support_user(); $info = $editTeacher; $info->coursename = $course->fullname; email_to_user($info, $contact, get_string('mailtoteacher_suject', 'enrol_apply'), html_to_text($body), $body); } } } function sendConfirmMailToManagers($instance,$info,$applydescription){ global $DB; global $CFG; global $USER; $courseid = $instance->courseid; $apply_setting = $DB->get_records_sql("select name,value from ".$CFG->prefix."config_plugins where plugin='enrol_apply'"); $show_standard_user_profile = $show_extra_user_profile = false; if($instance->customint1 != ''){ ($instance->customint1 == 0)?$show_standard_user_profile = true:$show_standard_user_profile = false; }else{ ($apply_setting['show_standard_user_profile']->value == 0)?$show_standard_user_profile = true:$show_standard_user_profile = false; } if($instance->customint2 != ''){ ($instance->customint2 == 0)?$show_extra_user_profile = true:$show_extra_user_profile = false; }else{ ($apply_setting['show_extra_user_profile']->value == 0)?$show_extra_user_profile = true:$show_extra_user_profile = false; } if($apply_setting['sendmailtomanager']->value == 1){ $course = get_course($courseid); $context = context_system::instance(); $managerType = $DB->get_record('role',array("shortname"=>"manager")); $managers = $DB->get_records('role_assignments', array('contextid'=>$context->id,'roleid'=>$managerType->id)); foreach($managers as $manager){ $userWithManagerRole = $DB->get_record('user',array('id'=>$manager->userid)); $body = '

'. get_string('coursename', 'enrol_apply') .': '.format_string($course->fullname).'

'; $body .= '

'. get_string('applyuser', 'enrol_apply') .': '.$USER->firstname.' '.$USER->lastname.'

'; $body .= '

'. get_string('comment', 'enrol_apply') .': '.$applydescription.'

'; if($show_standard_user_profile){ $body .= '

'. get_string('user_profile', 'enrol_apply').'

'; $body .= '

'. get_string('firstname') .': '.$info->firstname.'

'; $body .= '

'. get_string('lastname') .': '.$info->lastname.'

'; $body .= '

'. get_string('email') .': '.$info->email.'

'; $body .= '

'. get_string('city') .': '.$info->city.'

'; $body .= '

'. get_string('country') .': '.$info->country.'

'; $body .= '

'. get_string('preferredlanguage') .': '.$info->lang.'

'; $body .= '

'. get_string('description') .': '.$info->description_editor['text'].'

'; $body .= '

'. get_string('firstnamephonetic') .': '.$info->firstnamephonetic.'

'; $body .= '

'. get_string('lastnamephonetic') .': '.$info->lastnamephonetic.'

'; $body .= '

'. get_string('middlename') .': '.$info->middlename.'

'; $body .= '

'. get_string('alternatename') .': '.$info->alternatename.'

'; $body .= '

'. get_string('url') .': '.$info->url.'

'; $body .= '

'. get_string('icqnumber') .': '.$info->icq.'

'; $body .= '

'. get_string('skypeid') .': '.$info->skype.'

'; $body .= '

'. get_string('aimid') .': '.$info->aim.'

'; $body .= '

'. get_string('yahooid') .': '.$info->yahoo.'

'; $body .= '

'. get_string('msnid') .': '.$info->msn.'

'; $body .= '

'. get_string('idnumber') .': '.$info->idnumber.'

'; $body .= '

'. get_string('institution') .': '.$info->institution.'

'; $body .= '

'. get_string('department') .': '.$info->department.'

'; $body .= '

'. get_string('phone') .': '.$info->phone1.'

'; $body .= '

'. get_string('phone2') .': '.$info->phone2.'

'; $body .= '

'. get_string('address') .': '.$info->address.'

'; } if($show_extra_user_profile){ require_once($CFG->dirroot.'/user/profile/lib.php'); $user = $DB->get_record('user',array('id'=>$USER->id)); profile_load_custom_fields($user); foreach ($user->profile as $key => $value) { $body .= '

'. $key .': '.$value.'

'; } } $body .= '

'. html_writer::link(new moodle_url('/enrol/apply/manage.php'), get_string('applymanage', 'enrol_apply')).'

'; $contact = core_user::get_support_user(); $info = $userWithManagerRole; $info->coursename = $course->fullname; email_to_user($info, $contact, get_string('mailtoteacher_suject', 'enrol_apply'), html_to_text($body), $body); } } } function getRelatedInfo($enrolid){ global $DB; global $CFG; return $DB->get_record_sql('select u.*,c.fullname as coursename from '.$CFG->prefix.'user_enrolments as ue left join '.$CFG->prefix.'user as u on ue.userid=u.id left join '.$CFG->prefix.'enrol as e on ue.enrolid=e.id left join '.$CFG->prefix.'course as c on e.courseid=c.id where ue.id='.$enrolid); } function updateMailContent($content,$replace){ foreach ($replace as $key=>$val) { $content = str_replace("{".$key."}",$val,$content); } return $content; }