dokeos-admin
[ class tree: dokeos-admin ] [ index: dokeos-admin ] [ all elements ]

Source for file ldap_synchro.php

Documentation is available at ldap_synchro.php

  1. <?php //$id: $
  2. exit()//not yet functional, needs to be revised
  3. /*
  4. ==============================================================================
  5.     Dokeos - elearning and course management software
  6.  
  7.     Copyright (c) 2008 Dokeos SPRL
  8.     Copyright (c) 2007 Mustapha Alouani (supervised by Michel Moreau-Belliard)
  9.  
  10.     For a full list of contributors, see "credits.txt".
  11.     The full license can be read in "license.txt".
  12.  
  13.     This program is free software; you can redistribute it and/or
  14.     modify it under the terms of the GNU General Public License
  15.     as published by the Free Software Foundation; either version 2
  16.     of the License, or (at your option) any later version.
  17.  
  18.     See the GNU General Public License for more details.
  19.  
  20.     Contact: Dokeos, rue du Corbeau, 108, B-1030 Brussels, Belgium, info@dokeos.com
  21. ==============================================================================
  22. */
  23. /**
  24. ==============================================================================
  25. *    @package dokeos.admin
  26. ==============================================================================
  27. */
  28.  
  29. // name of the language file that needs to be included
  30. $language_file='admin';
  31.  
  32. $cidReset=true;
  33.  
  34. require('../inc/global.inc.php');
  35. $libpath api_get_path(LIBRARY_PATH);
  36. require_once($libpath.'formvalidator/FormValidator.class.php');
  37. require_once($libpath.'usermanager.lib.php');
  38. require_once('../auth/ldap/authldap.php');
  39. $annee_base=date('Y');
  40. // setting the section (for the tabs)
  41. $this_section SECTION_PLATFORM_ADMIN;
  42. //api_protect_admin_script(); // on vire la secu... qui n'a pas lieu d'etre ici (script de synchro)
  43.  
  44. // setting breadcrumbs
  45. $interbreadcrumb[]=array('url' => 'index.php',"name" => get_lang('PlatformAdmin'));
  46. $interbreadcrumb[]=array('url' => api_get_self(),"name" => "Liste des sessions");
  47.  
  48. // Database Table Definitions
  49. $tbl_session                        Database::get_main_table(TABLE_MAIN_SESSION);
  50. $tbl_session_rel_class                Database::get_main_table(TABLE_MAIN_SESSION_CLASS);
  51. $tbl_session_rel_course                Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
  52. $tbl_session_rel_course_rel_user    Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
  53. $tbl_course                            Database::get_main_table(TABLE_MAIN_COURSE);
  54. $tbl_user                            Database::get_main_table(TABLE_MAIN_USER);
  55. $tbl_session_rel_user                Database::get_main_table(TABLE_MAIN_SESSION_USER);
  56. $tbl_class                            Database::get_main_table(TABLE_MAIN_CLASS);
  57. $tbl_class_user                        Database::get_main_table(TABLE_MAIN_CLASS_USER);
  58.  
  59. $tbl_session_rel_etape                 "session_rel_etape";
  60.  
  61. $message="";
  62.  
  63. $result=api_sql_query("SELECT id, name FROM $tbl_session",__FILE__,__LINE__);
  64. $Sessions=api_store_result($result);
  65.  
  66. $result=api_sql_query($sql,__FILE__,__LINE__);
  67. $users=api_store_result($result);
  68.  
  69. foreach($Sessions as $session){
  70.     $id_session $session['id'];
  71.     $name_session $session['name'];
  72.     $UserList=array();
  73.     $UserUpdate=array();
  74.     $UserAdd=array();
  75.     
  76.     // Parse des code etape de la session
  77.     /*
  78.     $sql = "SELECT  id_session, code_etape, etape_description, code_ufr, annee 
  79.         FROM $tbl_session_rel_etape
  80.         WHERE id_session='$id_session'
  81.         ORDER BY code_ufr, code_etape";
  82.     $result = api_sql_query($sql);
  83.     */
  84.     $ds ldap_connect($ldap_host$ldap_portor die(get_lang('LDAPConnectionError'));
  85.     ldap_set_version($ds);
  86.     // Import des utilisateurs des etapes dans la session
  87.     if ($ds)
  88.     {
  89.         $r false;
  90.         $res ldap_handle_bind($ds$r);
  91.         $UserList=array();
  92.         if($result !== false)
  93.         {
  94.             //while($row = Database::fetch_array($result))
  95.             //{
  96.                 /*
  97.                 $annee = $row['annee'];
  98.                 $code_ufr = $row['code_ufr'];
  99.                 $etape = $row['code_etape'];
  100.                 */
  101.                 // LDAP Query
  102.                 // edupersonorgunitdn=ou=12CI1,ou=2006,ou=diploma,o=Paris1,dc=univ-paris1,dc=fr
  103.                 //etapescommented
  104.                 //$sr = @ ldap_search($ds, "ou=people,$LDAPbasedn", "edupersonorgunitdn=ou=$etape,ou=$annee,ou=diploma,$LDAPbasedn");
  105.                 $sr ldap_search($ds$ldap_basedn'(uid=*)');
  106.                 $info ldap_get_entries($ds$sr);
  107.                 for ($key 0$key $info["count"]$key ++)
  108.                 {
  109.                     echo "<pre>";
  110.                     print_r($info[$key]);
  111.                     echo "</pre>";
  112.                     $lastname iconv('utf-8'api_get_setting('platform_charset')$info[$key]["sn"][0]);
  113.                     $firstname iconv('utf-8'api_get_setting('platform_charset')$info[$key]["givenname"][0]);
  114.                     $email $info[$key]["mail"][0];
  115.                     // Get uid from dn
  116.                     $dn_array=ldap_explode_dn($info[$key]["dn"],1);
  117.                     $username $dn_array[0]// uid is first key
  118.                     $outab[$info[$key]["edupersonprimaryaffiliation"][0]// Ici "student"
  119.                     $val ldap_get_values_len($ds$sr"userPassword");
  120.                     $password $val[0];
  121.                     // Pour faciliter la gestion on ajoute le code "etape-annee"
  122.                     $official_code=$etape."-".$annee;
  123.                     $auth_source="ldap";
  124.                     // Pas de date d'expiration d'etudiant (a recuperer par rapport au shadow expire LDAP)
  125.                     $expiration_date='0000-00-00 00:00:00';
  126.                     $active=1;
  127.                     // Ajout de l'utilisateur
  128.                     if (UserManager::is_username_available($username))
  129.                     {
  130.                         $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);
  131.                         $UserAdd[]=$user_id;
  132.                     }
  133.                     else
  134.                     {
  135.                         $user UserManager::get_user_info($username);
  136.                         $user_id=$user['user_id'];
  137.                         UserManager::update_user($user_id$firstname$lastname$usernamenullnull$email$status$official_code$phone$picture_uri$expiration_date$active);
  138.                         $UserUpdate[]=$user_id;
  139.                     }
  140.                     $UserList[]=$user_id;
  141.                 }
  142.             //}
  143.         }
  144.         if (isset($included&& ($included))
  145.         {
  146.             $message .= "$name_session".count($UserAdd)." ".get_lang('Added').' '.get_lang('And').' '.count($UserUpdate).' '.get_lang('Modified').'<br/>';
  147.         }
  148.         else
  149.         {
  150.             print "$name_session".count($UserAdd).get_lang('Added').' '.get_lang('And').' '.count($UserUpdate).' '.get_lang('Modified')."\n";
  151.         }
  152.         
  153.         // Une fois les utilisateurs importer dans la base des utilisateurs, on peux les affecter a� la session
  154.         $result=api_sql_query("SELECT course_code FROM $tbl_session_rel_course .
  155.                 "WHERE id_session='$id_session'",__FILE__,__LINE__);
  156.         $CourseList=array();
  157.         while($row=Database::fetch_array($result))
  158.         {
  159.             $CourseList[]=$row['course_code'];
  160.         }
  161.         foreach($CourseList as $enreg_course)
  162.         {
  163.             // On ajoute la relation entre l'utilisateur et le cours
  164.             foreach($UserList as $enreg_user)
  165.             {
  166.                 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__);
  167.             }
  168.             $sql "SELECT COUNT(id_user) as nbUsers " .
  169.                     "FROM $tbl_session_rel_course_rel_user .
  170.                     "WHERE id_session='$id_session' AND course_code='$enreg_course'";
  171.             $rs api_sql_query($sql__FILE____LINE__);
  172.             list($nbr_usersDatabase::fetch_array($rs);
  173.             $sql "UPDATE $tbl_session_rel_course SET nbr_users=$nbr_users WHERE id_session='$id_session' AND course_code='$enreg_course'";
  174.             api_sql_query($sql,__FILE__,__LINE__);
  175.         }
  176.         // On ajoute la relation entre l'utilisateur et la session
  177.         foreach($UserList as $enreg_user){
  178.             $sql "INSERT IGNORE INTO $tbl_session_rel_user(id_session, id_user) .
  179.                     "VALUES('$id_session','$enreg_user')";
  180.             api_sql_query($sql,__FILE__,__LINE__);
  181.         }
  182.         $sql "SELECT COUNT(id_user) as nbUsers " .
  183.                 "FROM $tbl_session_rel_user .
  184.                 "WHERE id_session='$id_session'";
  185.         $rs api_sql_query($sql__FILE____LINE__);
  186.         list($nbr_usersDatabase::fetch_array($rs);
  187.         $sql "UPDATE $tbl_session SET nbr_users=$nbr_users WHERE id='$id_session'";
  188.         api_sql_query($sql,__FILE__,__LINE__);
  189.     }
  190. }
  191. ?>

Documentation generated on Thu, 12 Jun 2008 13:54:24 -0500 by phpDocumentor 1.4.1