| 
							
								 | 
							
							<?php
 | 
						
						
						
						
							 | 
							
								 | 
							
							/* For licensing terms, see /license.txt */
 | 
						
						
						
						
							 | 
							
								 | 
							
							/**
 | 
						
						
						
						
							 | 
							
								 | 
							
							*	@package chamilo.admin
 | 
						
						
						
						
							 | 
							
								 | 
							
							*/
 | 
						
						
						
						
							 | 
							
								 | 
							
							/**
 | 
						
						
						
						
							 | 
							
								 | 
							
							 * Code
 | 
						
						
						
						
							 | 
							
								 | 
							
							 */
 | 
						
						
						
						
							 | 
							
								 | 
							
							exit(); //not yet functional, needs to be revised
 | 
						
						
						
						
							 | 
							
								 | 
							
							// name of the language file that needs to be included
 | 
						
						
						
						
							 | 
							
								 | 
							
							$language_file='admin';
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							$cidReset=true;
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							require('../inc/global.inc.php');
 | 
						
						
						
						
							 | 
							
								 | 
							
							$libpath = api_get_path(LIBRARY_PATH);
 | 
						
						
						
						
							 | 
							
								 | 
							
							require_once('../auth/ldap/authldap.php');
 | 
						
						
						
						
							 | 
							
								 | 
							
							$annee_base=date('Y');
 | 
						
						
						
						
							 | 
							
								 | 
							
							// setting the section (for the tabs)
 | 
						
						
						
						
							 | 
							
								 | 
							
							$this_section = SECTION_PLATFORM_ADMIN;
 | 
						
						
						
						
							 | 
							
								 | 
							
							//api_protect_admin_script(); // on vire la secu... qui n'a pas lieu d'etre ici (script de synchro)
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							// setting breadcrumbs
 | 
						
						
						
						
							 | 
							
								 | 
							
							$interbreadcrumb[]=array('url' => 'index.php',"name" => get_lang('PlatformAdmin'));
 | 
						
						
						
						
							 | 
							
								 | 
							
							$interbreadcrumb[]=array('url' => api_get_self(),"name" => "Liste des sessions");
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							// Database Table Definitions
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_session						= Database::get_main_table(TABLE_MAIN_SESSION);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_session_rel_class				= Database::get_main_table(TABLE_MAIN_SESSION_CLASS);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_session_rel_course				= Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_session_rel_course_rel_user	= Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_course							= Database::get_main_table(TABLE_MAIN_COURSE);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_user							= Database::get_main_table(TABLE_MAIN_USER);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_session_rel_user				= Database::get_main_table(TABLE_MAIN_SESSION_USER);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_class							= Database::get_main_table(TABLE_MAIN_CLASS);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_class_user						= Database::get_main_table(TABLE_MAIN_CLASS_USER);
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							$tbl_session_rel_etape 				= "session_rel_etape";
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							$message="";
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							$result=Database::query("SELECT id, name FROM $tbl_session");
 | 
						
						
						
						
							 | 
							
								 | 
							
							$Sessions=Database::store_result($result);
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							$result=Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
							$users=Database::store_result($result);
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							foreach($Sessions as $session){
 | 
						
						
						
						
							 | 
							
								 | 
							
								$id_session = $session['id'];
 | 
						
						
						
						
							 | 
							
								 | 
							
								$name_session = $session['name'];
 | 
						
						
						
						
							 | 
							
								 | 
							
								$UserList=array();
 | 
						
						
						
						
							 | 
							
								 | 
							
								$UserUpdate=array();
 | 
						
						
						
						
							 | 
							
								 | 
							
								$UserAdd=array();
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
								// Parse des code etape de la session
 | 
						
						
						
						
							 | 
							
								 | 
							
								/*
 | 
						
						
						
						
							 | 
							
								 | 
							
								$sql = "SELECT  id_session, code_etape, etape_description, code_ufr, annee
 | 
						
						
						
						
							 | 
							
								 | 
							
									FROM $tbl_session_rel_etape
 | 
						
						
						
						
							 | 
							
								 | 
							
									WHERE id_session='$id_session'
 | 
						
						
						
						
							 | 
							
								 | 
							
									ORDER BY code_ufr, code_etape";
 | 
						
						
						
						
							 | 
							
								 | 
							
								$result = Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
								*/
 | 
						
						
						
						
							 | 
							
								 | 
							
								$ds = ldap_connect($ldap_host, $ldap_port) or die(get_lang('LDAPConnectionError'));
 | 
						
						
						
						
							 | 
							
								 | 
							
								ldap_set_version($ds);
 | 
						
						
						
						
							 | 
							
								 | 
							
								// Import des utilisateurs des etapes dans la session
 | 
						
						
						
						
							 | 
							
								 | 
							
								if ($ds)
 | 
						
						
						
						
							 | 
							
								 | 
							
								{
 | 
						
						
						
						
							 | 
							
								 | 
							
									$r = false;
 | 
						
						
						
						
							 | 
							
								 | 
							
									$res = ldap_handle_bind($ds, $r);
 | 
						
						
						
						
							 | 
							
								 | 
							
									$UserList=array();
 | 
						
						
						
						
							 | 
							
								 | 
							
									if($result !== false)
 | 
						
						
						
						
							 | 
							
								 | 
							
									{
 | 
						
						
						
						
							 | 
							
								 | 
							
										//while($row = Database::fetch_array($result))
 | 
						
						
						
						
							 | 
							
								 | 
							
										//{
 | 
						
						
						
						
							 | 
							
								 | 
							
											/*
 | 
						
						
						
						
							 | 
							
								 | 
							
											$annee = $row['annee'];
 | 
						
						
						
						
							 | 
							
								 | 
							
											$code_ufr = $row['code_ufr'];
 | 
						
						
						
						
							 | 
							
								 | 
							
											$etape = $row['code_etape'];
 | 
						
						
						
						
							 | 
							
								 | 
							
											*/
 | 
						
						
						
						
							 | 
							
								 | 
							
											// LDAP Query
 | 
						
						
						
						
							 | 
							
								 | 
							
											// edupersonorgunitdn=ou=12CI1,ou=2006,ou=diploma,o=Paris1,dc=univ-paris1,dc=fr
 | 
						
						
						
						
							 | 
							
								 | 
							
											//etapescommented
 | 
						
						
						
						
							 | 
							
								 | 
							
											//$sr = @ ldap_search($ds, "ou=people,$LDAPbasedn", "edupersonorgunitdn=ou=$etape,ou=$annee,ou=diploma,$LDAPbasedn");
 | 
						
						
						
						
							 | 
							
								 | 
							
											$sr = @ ldap_search($ds, $ldap_basedn, '(uid=*)');
 | 
						
						
						
						
							 | 
							
								 | 
							
											$info = ldap_get_entries($ds, $sr);
 | 
						
						
						
						
							 | 
							
								 | 
							
											for ($key = 0; $key < $info["count"]; $key ++)
 | 
						
						
						
						
							 | 
							
								 | 
							
											{
 | 
						
						
						
						
							 | 
							
								 | 
							
												echo "<pre>";
 | 
						
						
						
						
							 | 
							
								 | 
							
												print_r($info[$key]);
 | 
						
						
						
						
							 | 
							
								 | 
							
												echo "</pre>";
 | 
						
						
						
						
							 | 
							
								 | 
							
												$lastname = api_utf8_decode($info[$key]["sn"][0], api_get_system_encoding());
 | 
						
						
						
						
							 | 
							
								 | 
							
												$firstname = api_utf8_decode($info[$key]["givenname"][0], api_get_system_encoding());
 | 
						
						
						
						
							 | 
							
								 | 
							
												$email = $info[$key]["mail"][0];
 | 
						
						
						
						
							 | 
							
								 | 
							
												// Get uid from dn
 | 
						
						
						
						
							 | 
							
								 | 
							
												$dn_array=ldap_explode_dn($info[$key]["dn"],1);
 | 
						
						
						
						
							 | 
							
								 | 
							
												$username = $dn_array[0]; // uid is first key
 | 
						
						
						
						
							 | 
							
								 | 
							
												$outab[] = $info[$key]["edupersonprimaryaffiliation"][0]; // Ici "student"
 | 
						
						
						
						
							 | 
							
								 | 
							
												$val = ldap_get_values_len($ds, $sr, "userPassword");
 | 
						
						
						
						
							 | 
							
								 | 
							
												$password = $val[0];
 | 
						
						
						
						
							 | 
							
								 | 
							
												// Pour faciliter la gestion on ajoute le code "etape-annee"
 | 
						
						
						
						
							 | 
							
								 | 
							
												$official_code=$etape."-".$annee;
 | 
						
						
						
						
							 | 
							
								 | 
							
												$auth_source="ldap";
 | 
						
						
						
						
							 | 
							
								 | 
							
												// Pas de date d'expiration d'etudiant (a recuperer par rapport au shadow expire LDAP)
 | 
						
						
						
						
							 | 
							
								 | 
							
												$expiration_date='0000-00-00 00:00:00';
 | 
						
						
						
						
							 | 
							
								 | 
							
												$active=1;
 | 
						
						
						
						
							 | 
							
								 | 
							
												// Ajout de l'utilisateur
 | 
						
						
						
						
							 | 
							
								 | 
							
												if (UserManager::is_username_available($username)) {
 | 
						
						
						
						
							 | 
							
								 | 
							
													$user_id = UserManager::create_user($firstname,$lastname,$status,$email,$username,$password,$official_code,api_get_setting('platformLanguage'),$phone,$picture_uri,$auth_source,$expiration_date,$active);
 | 
						
						
						
						
							 | 
							
								 | 
							
													$UserAdd[]=$user_id;
 | 
						
						
						
						
							 | 
							
								 | 
							
												} else {
 | 
						
						
						
						
							 | 
							
								 | 
							
													$user = UserManager::get_user_info($username);
 | 
						
						
						
						
							 | 
							
								 | 
							
													$user_id=$user['user_id'];
 | 
						
						
						
						
							 | 
							
								 | 
							
													UserManager::update_user($user_id, $firstname, $lastname, $username, null, null, $email, $status, $official_code, $phone, $picture_uri, $expiration_date, $active);
 | 
						
						
						
						
							 | 
							
								 | 
							
													$UserUpdate[]=$user_id;
 | 
						
						
						
						
							 | 
							
								 | 
							
												}
 | 
						
						
						
						
							 | 
							
								 | 
							
												$UserList[]=$user_id;
 | 
						
						
						
						
							 | 
							
								 | 
							
											}
 | 
						
						
						
						
							 | 
							
								 | 
							
										//}
 | 
						
						
						
						
							 | 
							
								 | 
							
									}
 | 
						
						
						
						
							 | 
							
								 | 
							
									if (isset($included) && ($included))
 | 
						
						
						
						
							 | 
							
								 | 
							
									{
 | 
						
						
						
						
							 | 
							
								 | 
							
										$message .= "> $name_session: ".count($UserAdd)." ".get_lang('Added').' '.get_lang('And').' '.count($UserUpdate).' '.get_lang('Modified').'<br/>';
 | 
						
						
						
						
							 | 
							
								 | 
							
									}
 | 
						
						
						
						
							 | 
							
								 | 
							
									else
 | 
						
						
						
						
							 | 
							
								 | 
							
									{
 | 
						
						
						
						
							 | 
							
								 | 
							
										print "> $name_session: ".count($UserAdd).get_lang('Added').' '.get_lang('And').' '.count($UserUpdate).' '.get_lang('Modified')."\n";
 | 
						
						
						
						
							 | 
							
								 | 
							
									}
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
									// Une fois les utilisateurs importer dans la base des utilisateurs, on peux les affecter a<EFBFBD> la session
 | 
						
						
						
						
							 | 
							
								 | 
							
									$result=Database::query("SELECT course_code FROM $tbl_session_rel_course " .
 | 
						
						
						
						
							 | 
							
								 | 
							
											"WHERE id_session='$id_session'");
 | 
						
						
						
						
							 | 
							
								 | 
							
									$CourseList=array();
 | 
						
						
						
						
							 | 
							
								 | 
							
									while($row=Database::fetch_array($result))
 | 
						
						
						
						
							 | 
							
								 | 
							
									{
 | 
						
						
						
						
							 | 
							
								 | 
							
										$CourseList[]=$row['course_code'];
 | 
						
						
						
						
							 | 
							
								 | 
							
									}
 | 
						
						
						
						
							 | 
							
								 | 
							
									foreach($CourseList as $enreg_course)
 | 
						
						
						
						
							 | 
							
								 | 
							
									{
 | 
						
						
						
						
							 | 
							
								 | 
							
										// On ajoute la relation entre l'utilisateur et le cours
 | 
						
						
						
						
							 | 
							
								 | 
							
										foreach($UserList as $enreg_user)
 | 
						
						
						
						
							 | 
							
								 | 
							
										{
 | 
						
						
						
						
							 | 
							
								 | 
							
											Database::query("INSERT IGNORE INTO $tbl_session_rel_course_rel_user(id_session,course_code,id_user) VALUES('$id_session','$enreg_course','$enreg_user')");
 | 
						
						
						
						
							 | 
							
								 | 
							
										}
 | 
						
						
						
						
							 | 
							
								 | 
							
										$sql = "SELECT COUNT(id_user) as nbUsers " .
 | 
						
						
						
						
							 | 
							
								 | 
							
												"FROM $tbl_session_rel_course_rel_user " .
 | 
						
						
						
						
							 | 
							
								 | 
							
												"WHERE id_session='$id_session' AND course_code='$enreg_course'";
 | 
						
						
						
						
							 | 
							
								 | 
							
										$rs = Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
										list($nbr_users) = Database::fetch_array($rs);
 | 
						
						
						
						
							 | 
							
								 | 
							
										$sql = "UPDATE $tbl_session_rel_course SET nbr_users=$nbr_users WHERE id_session='$id_session' AND course_code='$enreg_course'";
 | 
						
						
						
						
							 | 
							
								 | 
							
										Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
									}
 | 
						
						
						
						
							 | 
							
								 | 
							
									// On ajoute la relation entre l'utilisateur et la session
 | 
						
						
						
						
							 | 
							
								 | 
							
									foreach($UserList as $enreg_user){
 | 
						
						
						
						
							 | 
							
								 | 
							
										$sql = "INSERT IGNORE INTO $tbl_session_rel_user(id_session, id_user) " .
 | 
						
						
						
						
							 | 
							
								 | 
							
												"VALUES('$id_session','$enreg_user')";
 | 
						
						
						
						
							 | 
							
								 | 
							
										Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
									}
 | 
						
						
						
						
							 | 
							
								 | 
							
									$sql = "SELECT COUNT(id_user) as nbUsers " .
 | 
						
						
						
						
							 | 
							
								 | 
							
											"FROM $tbl_session_rel_user " .
 | 
						
						
						
						
							 | 
							
								 | 
							
											"WHERE id_session='$id_session' AND relation_type<>".SESSION_RELATION_TYPE_RRHH."";
 | 
						
						
						
						
							 | 
							
								 | 
							
									$rs = Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
									list($nbr_users) = Database::fetch_array($rs);
 | 
						
						
						
						
							 | 
							
								 | 
							
									$sql = "UPDATE $tbl_session SET nbr_users=$nbr_users WHERE id='$id_session'";
 | 
						
						
						
						
							 | 
							
								 | 
							
									Database::query($sql);
 | 
						
						
						
						
							 | 
							
								 | 
							
								}
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							?>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 |