You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							537 lines
						
					
					
						
							22 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							537 lines
						
					
					
						
							22 KiB
						
					
					
				| <?php | |
| /** | |
|  * ************************************************************************* | |
|  * *                  Apply	Enrol   				                      ** | |
|  * ************************************************************************* | |
|  * @copyright   emeneo.com                                                ** | |
|  * @link        emeneo.com                                                ** | |
|  * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later  ** | |
|  * ************************************************************************* | |
|  * ************************************************************************ | |
| */ | |
| class enrol_apply_plugin extends enrol_plugin { | |
| 
 | |
| 	/** | |
| 	* Add new instance of enrol plugin with default settings. | |
| 	* @param object $course | |
| 	* @return int id of new instance | |
| 	*/ | |
| 	public function add_default_instance($course) { | |
| 		$fields = $this->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'); | |
| 		} | |
| 
 | |
| 		if ($instance->enrolstartdate != 0 and $instance->enrolstartdate > time()) { | |
| 			//TODO: inform that we can not enrol yet | |
| 			return null; | |
| 		} | |
| 
 | |
| 		if ($instance->enrolenddate != 0 and $instance->enrolenddate < time()) { | |
| 			//TODO: inform that enrolment is not possible any more | |
| 			return null; | |
| 		} | |
| 
 | |
| 		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 self enrolments here | |
| 				return $OUTPUT->notification(get_string('maxenrolledreached', 'enrol_self')); | |
| 			} | |
| 		} | |
| 		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); | |
| 				sendConfirmMailToTeachers($instance, $data, $applydescription); | |
| 				sendConfirmMailToManagers($instance, $data, $applydescription); | |
| 				 | |
| 				// Deprecated fixed by Shiro <gigashiro@gmail.com> | |
| 				//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); | |
| 			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))){ | |
| 			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($apply_setting['sendmailtoteacher']->value == 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 = '<p>'. get_string('coursename', 'enrol_apply') .': '.format_string($course->fullname).'</p>'; | |
| 			$body .= '<p>'. get_string('applyuser', 'enrol_apply') .': '.$USER->firstname.' '.$USER->lastname.'</p>'; | |
| 			$body .= '<p>'. get_string('comment', 'enrol_apply') .': '.$applydescription.'</p>'; | |
| 
 | |
| 			if($show_standard_user_profile){ | |
| 				$body .= '<p><strong>'. get_string('user_profile', 'enrol_apply').'</strong></p>'; | |
| 				$body .= '<p>'. get_string('firstname') .': '.$info->firstname.'</p>'; | |
| 				$body .= '<p>'. get_string('lastname') .': '.$info->lastname.'</p>'; | |
| 				$body .= '<p>'. get_string('email') .': '.$info->email.'</p>'; | |
| 				$body .= '<p>'. get_string('city') .': '.$info->city.'</p>'; | |
| 				$body .= '<p>'. get_string('country') .': '.$info->country.'</p>'; | |
| 				$body .= '<p>'. get_string('preferredlanguage') .': '.$info->lang.'</p>'; | |
| 				$body .= '<p>'. get_string('description') .': '.$info->description_editor['text'].'</p>'; | |
| 
 | |
| 				$body .= '<p>'. get_string('firstnamephonetic') .': '.$info->firstnamephonetic.'</p>'; | |
| 				$body .= '<p>'. get_string('lastnamephonetic') .': '.$info->lastnamephonetic.'</p>'; | |
| 				$body .= '<p>'. get_string('middlename') .': '.$info->middlename.'</p>'; | |
| 				$body .= '<p>'. get_string('alternatename') .': '.$info->alternatename.'</p>'; | |
| 				$body .= '<p>'. get_string('url') .': '.$info->url.'</p>'; | |
| 				$body .= '<p>'. get_string('icqnumber') .': '.$info->icq.'</p>'; | |
| 				$body .= '<p>'. get_string('skypeid') .': '.$info->skype.'</p>'; | |
| 				$body .= '<p>'. get_string('aimid') .': '.$info->aim.'</p>'; | |
| 				$body .= '<p>'. get_string('yahooid') .': '.$info->yahoo.'</p>'; | |
| 				$body .= '<p>'. get_string('msnid') .': '.$info->msn.'</p>'; | |
| 				$body .= '<p>'. get_string('idnumber') .': '.$info->idnumber.'</p>'; | |
| 				$body .= '<p>'. get_string('institution') .': '.$info->institution.'</p>'; | |
| 				$body .= '<p>'. get_string('department') .': '.$info->department.'</p>'; | |
| 				$body .= '<p>'. get_string('phone') .': '.$info->phone1.'</p>'; | |
| 				$body .= '<p>'. get_string('phone2') .': '.$info->phone2.'</p>'; | |
| 				$body .= '<p>'. get_string('address') .': '.$info->address.'</p>'; | |
| 			} | |
| 
 | |
| 			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 .= '<p>'. $key .': '.$value.'</p>'; | |
| 				} | |
| 			} | |
| 
 | |
| 			$body .= '<p>'. html_writer::link(new moodle_url("/enrol/apply/apply.php", array('id'=>$courseid,'enrolid'=>$instanceid)), get_string('applymanage', 'enrol_apply')).'</p>'; | |
| 			$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 = '<p>'. get_string('coursename', 'enrol_apply') .': '.format_string($course->fullname).'</p>'; | |
| 			$body .= '<p>'. get_string('applyuser', 'enrol_apply') .': '.$USER->firstname.' '.$USER->lastname.'</p>'; | |
| 			$body .= '<p>'. get_string('comment', 'enrol_apply') .': '.$applydescription.'</p>'; | |
| 			if($show_standard_user_profile){ | |
| 				$body .= '<p><strong>'. get_string('user_profile', 'enrol_apply').'</strong></p>'; | |
| 				$body .= '<p>'. get_string('firstname') .': '.$info->firstname.'</p>'; | |
| 				$body .= '<p>'. get_string('lastname') .': '.$info->lastname.'</p>'; | |
| 				$body .= '<p>'. get_string('email') .': '.$info->email.'</p>'; | |
| 				$body .= '<p>'. get_string('city') .': '.$info->city.'</p>'; | |
| 				$body .= '<p>'. get_string('country') .': '.$info->country.'</p>'; | |
| 				$body .= '<p>'. get_string('preferredlanguage') .': '.$info->lang.'</p>'; | |
| 				$body .= '<p>'. get_string('description') .': '.$info->description_editor['text'].'</p>'; | |
| 
 | |
| 				$body .= '<p>'. get_string('firstnamephonetic') .': '.$info->firstnamephonetic.'</p>'; | |
| 				$body .= '<p>'. get_string('lastnamephonetic') .': '.$info->lastnamephonetic.'</p>'; | |
| 				$body .= '<p>'. get_string('middlename') .': '.$info->middlename.'</p>'; | |
| 				$body .= '<p>'. get_string('alternatename') .': '.$info->alternatename.'</p>'; | |
| 				$body .= '<p>'. get_string('url') .': '.$info->url.'</p>'; | |
| 				$body .= '<p>'. get_string('icqnumber') .': '.$info->icq.'</p>'; | |
| 				$body .= '<p>'. get_string('skypeid') .': '.$info->skype.'</p>'; | |
| 				$body .= '<p>'. get_string('aimid') .': '.$info->aim.'</p>'; | |
| 				$body .= '<p>'. get_string('yahooid') .': '.$info->yahoo.'</p>'; | |
| 				$body .= '<p>'. get_string('msnid') .': '.$info->msn.'</p>'; | |
| 				$body .= '<p>'. get_string('idnumber') .': '.$info->idnumber.'</p>'; | |
| 				$body .= '<p>'. get_string('institution') .': '.$info->institution.'</p>'; | |
| 				$body .= '<p>'. get_string('department') .': '.$info->department.'</p>'; | |
| 				$body .= '<p>'. get_string('phone') .': '.$info->phone1.'</p>'; | |
| 				$body .= '<p>'. get_string('phone2') .': '.$info->phone2.'</p>'; | |
| 				$body .= '<p>'. get_string('address') .': '.$info->address.'</p>'; | |
| 			} | |
| 
 | |
| 			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 .= '<p>'. $key .': '.$value.'</p>'; | |
| 				} | |
| 			} | |
| 
 | |
| 			$body .= '<p>'. html_writer::link(new moodle_url('/enrol/apply/manage.php'), get_string('applymanage', 'enrol_apply')).'</p>'; | |
| 			$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; | |
| }
 | |
| 
 |