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.
164 lines
6.2 KiB
164 lines
6.2 KiB
<?php
|
|
/* For licensing terms, see /license.txt */
|
|
/**
|
|
* @package chamilo.admin
|
|
*/
|
|
/**
|
|
* Code
|
|
*/
|
|
exit(); //not yet functional, needs to be revised
|
|
|
|
$cidReset=true;
|
|
|
|
require_once __DIR__.'/../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]);
|
|
$firstname = api_utf8_decode($info[$key]["givenname"][0]);
|
|
$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='';
|
|
$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 = api_get_user_info_from_username($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 la session
|
|
$result=Database::query("SELECT c_id FROM $tbl_session_rel_course WHERE session_id='$id_session'");
|
|
$CourseList=array();
|
|
while($row=Database::fetch_array($result)) {
|
|
$CourseList[]= $row['c_id'];
|
|
}
|
|
|
|
foreach ($CourseList as $enreg_course) {
|
|
// On ajoute la relation entre l'utilisateur et le cours
|
|
foreach ($UserList as $enreg_user) {
|
|
$sql = "INSERT IGNORE INTO $tbl_session_rel_course_rel_user(session_id,c_id,user_id)
|
|
VALUES('$id_session','$enreg_course','$enreg_user')";
|
|
Database::query($sql);
|
|
}
|
|
$sql = "SELECT COUNT(user_id) as nbUsers " .
|
|
"FROM $tbl_session_rel_course_rel_user " .
|
|
"WHERE session_id='$id_session' AND c_id='$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 session_id='$id_session' AND c_id = '$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(session_id, user_id, registered_at) " .
|
|
"VALUES('$id_session','$enreg_user', '" . api_get_utc_datetime() . "')";
|
|
Database::query($sql);
|
|
}
|
|
$sql = "SELECT COUNT(user_id) as nbUsers " .
|
|
"FROM $tbl_session_rel_user " .
|
|
"WHERE session_id='$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);
|
|
}
|
|
}
|
|
|