Source for file ldap_synchro.php
Documentation is available at ldap_synchro.php
exit(); //not yet functional, needs to be revised
==============================================================================
Dokeos - elearning and course management software
Copyright (c) 2008 Dokeos SPRL
Copyright (c) 2007 Mustapha Alouani (supervised by Michel Moreau-Belliard)
For a full list of contributors, see "credits.txt".
The full license can be read in "license.txt".
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
See the GNU General Public License for more details.
Contact: Dokeos, rue du Corbeau, 108, B-1030 Brussels, Belgium, info@dokeos.com
==============================================================================
==============================================================================
==============================================================================
// name of the language file that needs to be included
require ('../inc/global.inc.php');
require_once($libpath. 'formvalidator/FormValidator.class.php');
require_once($libpath. 'usermanager.lib.php');
require_once('../auth/ldap/authldap.php');
// setting the section (for the tabs)
//api_protect_admin_script(); // on vire la secu... qui n'a pas lieu d'etre ici (script de synchro)
$interbreadcrumb[]= array('url' => 'index.php',"name" => get_lang('PlatformAdmin'));
$interbreadcrumb[]= array('url' => api_get_self(),"name" => "Liste des sessions");
// Database Table Definitions
$tbl_session_rel_etape = "session_rel_etape";
$result= api_sql_query("SELECT id, name FROM $tbl_session",__FILE__ ,__LINE__ );
foreach($Sessions as $session){
$id_session = $session['id'];
$name_session = $session['name'];
// 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 = api_sql_query($sql);
// Import des utilisateurs des etapes dans la session
//while($row = Database::fetch_array($result))
$code_ufr = $row['code_ufr'];
$etape = $row['code_etape'];
// edupersonorgunitdn=ou=12CI1,ou=2006,ou=diploma,o=Paris1,dc=univ-paris1,dc=fr
//$sr = @ ldap_search($ds, "ou=people,$LDAPbasedn", "edupersonorgunitdn=ou=$etape,ou=$annee,ou=diploma,$LDAPbasedn");
for ($key = 0; $key < $info["count"]; $key ++ )
$email = $info[$key]["mail"][0];
$username = $dn_array[0]; // uid is first key
$outab[] = $info[$key]["edupersonprimaryaffiliation"][0]; // Ici "student"
// Pour faciliter la gestion on ajoute le code "etape-annee"
$official_code= $etape. "-". $annee;
// Pas de date d'expiration d'etudiant (a recuperer par rapport au shadow expire LDAP)
$expiration_date= '0000-00-00 00:00:00';
// Ajout de l'utilisateur
$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);
$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);
if (isset ($included) && ($included))
// Une fois les utilisateurs importer dans la base des utilisateurs, on peux les affecter a� la session
$result= api_sql_query("SELECT course_code FROM $tbl_session_rel_course " .
"WHERE id_session='$id_session'",__FILE__ ,__LINE__ );
$CourseList[]= $row['course_code'];
foreach($CourseList as $enreg_course)
// On ajoute la relation entre l'utilisateur et le cours
foreach($UserList as $enreg_user)
api_sql_query("INSERT IGNORE INTO $tbl_session_rel_course_rel_user(id_session,course_code,id_user) VALUES('$id_session','$enreg_course','$enreg_user')",__FILE__ ,__LINE__ );
$sql = "SELECT COUNT(id_user) as nbUsers " .
"FROM $tbl_session_rel_course_rel_user " .
"WHERE id_session='$id_session' AND course_code='$enreg_course'";
$sql = "UPDATE $tbl_session_rel_course SET nbr_users=$nbr_users WHERE id_session='$id_session' AND course_code='$enreg_course'";
// 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')";
$sql = "SELECT COUNT(id_user) as nbUsers " .
"FROM $tbl_session_rel_user " .
"WHERE id_session='$id_session'";
$sql = "UPDATE $tbl_session SET nbr_users=$nbr_users WHERE id='$id_session'";
|