User.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556
  1. <?php
  2. require_once dirname(__FILE__) . '/' . 'Lib.php';
  3. Lib::loadClass('V');
  4. Lib::loadClass('UserProfile');
  5. class User {
  6. public static function getLogin() {
  7. return V::get('ADM_ACCOUNT', '', $_SESSION);
  8. }
  9. public static function getName() {
  10. return V::get('ADM_ACCOUNT', '', $_SESSION);
  11. }
  12. public static function getID() {
  13. if (V::get('ADM_ID', 0, $_SESSION, 'int') <= 0) {
  14. self::_fetchMoreUserData();
  15. }
  16. return V::get('ADM_ID', '', $_SESSION);
  17. }
  18. public static function getType() {
  19. if (!empty($_SESSION['EMPLOYEE_TYPE'])) {
  20. self::_fetchMoreUserData();
  21. }
  22. return V::get('EMPLOYEE_TYPE', '', $_SESSION);
  23. }
  24. public static function getFullName() {
  25. return V::get('ADM_NAME', '', $_SESSION);
  26. }
  27. public static function getInicjaly() {
  28. if (!V::get('ADM_INICJALY_HANDLOWCA', '', $_SESSION)) {
  29. self::_fetchMoreUserData();
  30. }
  31. return $_SESSION['ADM_INICJALY_HANDLOWCA'];
  32. }
  33. public static function _fetchMoreUserData() {
  34. $db = DB::getDB();
  35. $login = self::getLogin();
  36. if (empty($login)) return false;
  37. $sql = "select `ID`, `INICJALY_HANDLOWCA`, `EMPLOYEE_TYPE` from `ADMIN_USERS` where `ADM_ACCOUNT`='{$login}' limit 1 ";
  38. $res = $db->query($sql);
  39. if ($r = $db->fetch($res)) {
  40. $_SESSION['ADM_ID'] = $r->ID;
  41. $_SESSION['ADM_INICJALY_HANDLOWCA'] = $r->INICJALY_HANDLOWCA;
  42. $_SESSION['EMPLOYEE_TYPE'] = $r->EMPLOYEE_TYPE;
  43. }
  44. }
  45. public static function logged() {
  46. return (!empty($_SESSION['AUTHORIZE_USER']))? true : false;
  47. }
  48. public static function get( $key ) {
  49. return V::get($key, '', $_SESSION);
  50. }
  51. public static function getGroups() {
  52. $groups = User::_fetchGroups();
  53. return $groups;
  54. }
  55. public static function getGroupsIds() {
  56. $groups = User::_fetchGroups();
  57. return array_keys($groups);
  58. }
  59. public static function _fetchGroups() {
  60. static $_groups;
  61. if (!$_groups) {
  62. $user_id = User::getID();
  63. Lib::loadClass('UsersHelper');
  64. $_groups = UsersHelper::get_group_by_user($user_id);
  65. }
  66. return $_groups;
  67. }
  68. public static function loadProfile($force = false) {
  69. return UserProfile::load($force);
  70. }
  71. public static function saveProfile() {
  72. return UserProfile::save();
  73. }
  74. public static function getProfile($key) {
  75. return UserProfile::get($key);
  76. }
  77. public static function setProfile($key, $val) {
  78. UserProfile::set($key, $val);
  79. }
  80. public static function getProfileColumn($column_name, $key) {
  81. return UserProfile::getColumn($column_name, $key);
  82. }
  83. public static function setProfileColumn($column_name, $key, $value) {
  84. UserProfile::setColumn($column_name, $key, $value);
  85. }
  86. public static function removeProfileColumn($column_name, $key) {
  87. UserProfile::removeColumn($column_name, $key);
  88. }
  89. public static function isAdmin() {
  90. if (in_array(self::get('ADM_ADMIN_LEVEL'), array(0, 1))) {
  91. return true;
  92. }
  93. return false;
  94. }
  95. public static function getRawData() {
  96. $ret = array();
  97. if (self::logged()) {
  98. $ret['id'] = self::getID();
  99. $ret['login'] = self::getName();
  100. $ret['name'] = self::get('ADM_NAME');
  101. $ret['admin_level'] = self::get('ADM_ADMIN_LEVEL');
  102. $ret['opis'] = self::get('ADM_ADMIN_DESC');
  103. }
  104. return $ret;
  105. }
  106. public static function getAcl() {
  107. static $_acl;
  108. if (!$_acl) {
  109. Lib::loadClass('UserAcl');
  110. $_acl = new UserAcl(self::getID(), $use_cache = true);
  111. }
  112. return $_acl;
  113. }
  114. public static function auth() {
  115. $task = V::get('LOGIN', '', $_REQUEST);
  116. $data = array();
  117. $data['errors'] = array();
  118. Lib::loadClass('Config');
  119. $data['ALLOW_GUEST_ACCOUNT'] = (int)Config::get('ALLOW_GUEST_ACCOUNT');
  120. switch ($task) {
  121. case 'LOGIN':
  122. if (!User::logged()) {
  123. $req_ADM_ACCOUNT = (isset($_REQUEST['ADM_ACCOUNT']))? $_REQUEST['ADM_ACCOUNT'] : '';
  124. $req_ADM_PASSWD = (isset($_REQUEST['ADM_PASSWD']))? $_REQUEST['ADM_PASSWD'] : '';
  125. if (empty($req_ADM_ACCOUNT) || empty($req_ADM_PASSWD)) {
  126. $data['errors'][] = "Proszę podać LOGIN i HASŁO!";
  127. } else {
  128. User::login($req_ADM_ACCOUNT, $req_ADM_PASSWD, $data['errors']);
  129. }
  130. }
  131. break;
  132. case 'LOGOUT':
  133. if (User::logged()) {
  134. session_destroy();
  135. unset($_SESSION['AUTHORIZE_USER']);
  136. unset($_SESSION['ADM_ACCOUNT']);
  137. Lib::loadClass('SE_Layout');
  138. SE_Layout::gora();
  139. SE_Layout::loadTemplate('logout', $data);
  140. SE_Layout::dol();
  141. exit;
  142. }
  143. break;
  144. case 'PERMS_RELOAD':
  145. unset($_SESSION['TableAcl_cache']);
  146. unset($_SESSION['Typespecial_Cache']);
  147. //TODO: not work: unset($_SESSION['CRM_PROCES_USERA_WYKONANE_TESTY-' . User::getID()]);
  148. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;display:none">ses (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($_SESSION);echo'</pre>';
  149. $userAcl = User::getAcl();
  150. $userAcl->fetchAllPerms(true);
  151. break;
  152. case 'PASSEDIT':
  153. if (User::logged()) {
  154. $data = array();
  155. if (!empty($_POST)) {
  156. if (empty($_POST['ADM_PASSWD_NEW']) || empty($_POST['ADM_PASSWD'])) {
  157. $data['msg'] = "Proszę podać stare i nowe hasło.";
  158. }
  159. }
  160. if (!empty($_POST['ADM_PASSWD_NEW']) && !empty($_POST['ADM_PASSWD'])) {
  161. $ret = User::changePasswd($_POST['ADM_PASSWD'], $_POST['ADM_PASSWD_NEW']);
  162. if ($ret) {
  163. $data['info'] = "Hasło zostało zmienione";
  164. } else {
  165. $data['error'] = "Nie udało się zmienić hasła";
  166. }
  167. }
  168. SE_Layout::gora();
  169. SE_Layout::loadTemplate('passedit', $data);
  170. SE_Layout::dol();
  171. exit;
  172. }
  173. break;
  174. case 'ANONYMOUS_LOGIN':
  175. if (!User::logged()) {
  176. if ($data['ALLOW_GUEST_ACCOUNT'] != 1) {
  177. $data['errors'][] = "Zablokowane logowaniwe na konto gościa!";
  178. }
  179. else {
  180. $anonim = User::getAnonymousAccount();
  181. if (!$anonim) {
  182. $data['errors'][] = "Konto gościa nie istnieje!";
  183. } else {
  184. User::login($anonim->ADM_ACCOUNT, $anonim->ADM_PASSWD, $data['errors']);
  185. }
  186. }
  187. }
  188. break;
  189. default:
  190. }
  191. if (!User::logged()) {
  192. Lib::loadClass('SE_Layout');
  193. SE_Layout::gora();
  194. SE_Layout::loadTemplate('login', $data);
  195. SE_Layout::dol();
  196. exit;
  197. }
  198. }
  199. public static function login($login, $pass, &$errors) {
  200. Lib::loadClass('LDAP');
  201. $ldap = LDAP::getInstance();
  202. if ($ldap != null && $ldap->isConnected()) {
  203. $user = self::loginByLDAP($login, $pass, $errors);
  204. } else {
  205. $user = self::loginByDB($login, $pass, $errors);
  206. }
  207. if ($user) {
  208. $_SESSION['ADM_ID'] = $user->ID;
  209. $_SESSION['AUTHORIZE_USER'] = $user->ADM_ACCOUNT;
  210. $_SESSION['ADM_ACCOUNT'] = $user->ADM_ACCOUNT;
  211. //$_SESSION['ADM_AREA'] = $user->ADM_AREA;
  212. $_SESSION['ADM_NAME'] = $user->ADM_NAME;
  213. $_SESSION['ADM_TECH_WORKER'] = $user->ADM_TECH_WORKER;
  214. $_SESSION['ADM_COMPANY'] = $user->ADM_COMPANY;
  215. $_SESSION['ADM_ADMIN_LEVEL'] = $user->ADM_ADMIN_LEVEL;
  216. $_SESSION['ADM_PHONE'] = $user->ADM_PHONE;
  217. $_SESSION['ADM_ADMIN_EXPIRE'] = $user->ADM_ADMIN_EXPIRE;
  218. $_SESSION['ADM_ADMIN_DESC'] = $user->ADM_ADMIN_DESC;
  219. $_SESSION['EMPLOYEE_TYPE'] = $user->EMPLOYEE_TYPE;
  220. // save user pass in encrypted form
  221. Lib::loadClass('Crypt');
  222. $_SESSION['ADM_PASS_HASH'] = Crypt::encrypt($pass);
  223. $_SESSION['EMAIL_IMAP_IMPORT_PASSWD_HASH'] = Crypt::encrypt($user->EMAIL_IMAP_IMPORT_PASSWD);
  224. $_SESSION['EMAIL_IMAP_IMPORT_HOST'] = $user->EMAIL_IMAP_IMPORT_HOST;
  225. $_SESSION['EMAIL_IMAP_IMPORT_USERNAME'] = $user->EMAIL_IMAP_IMPORT_USERNAME;
  226. //$keyFromHash = Crypt::decrypt($_SESSION['ADM_PASS_HASH']);
  227. $userAcl = User::getAcl();
  228. $userAcl->fetchAllPerms();
  229. return true;
  230. }
  231. return false;
  232. }
  233. public static function loginByLDAP($login, $pass, &$errors) {
  234. $ldapUser = array();
  235. $DBG = false;
  236. Lib::loadClass('LDAP');
  237. $ldap = LDAP::getInstance();
  238. if (!$ldap->isConnected()) {
  239. $errors[] = 'Error: Could not connect to LDAP server!';
  240. return false;
  241. }
  242. $filter = (false !== strpos($login, '@'))? "(mail={$login})" : "(uid={$login})";
  243. //$filter = "cn=*";// show all ldap accounts
  244. $justthese = array();//array("uid", "givenName", "mail", "*");
  245. if($DBG){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">ldap_search (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('ldaprdn'=>$ldap->getBaseDN(), 'filter'=>$filter, 'justthese'=>$justthese));echo'</pre>';}
  246. $res = $ldap->search($filter, 'cn=users', $justthese);
  247. if ($ldap->count_entries($res) > 0) {
  248. $entry = $ldap->first_entry($res);
  249. if ($entry) {
  250. $ldapUser['user_dn'] = $ldap->get_dn($entry);
  251. $val = $ldap->get_values($entry, 'uid');
  252. $ldapUser['uid'] = $val[0];
  253. $val = $ldap->get_values($entry, 'mail');
  254. $ldapUser['mail'] = $val[0];
  255. $val = $ldap->get_values($entry, 'cn');
  256. $ldapUser['cn'] = $val[0];
  257. } else {
  258. $errors[] = 'Login nie istnieje';
  259. return false;
  260. }
  261. if($DBG){// test
  262. echo'<pre style="overflow:auto;border:1px solid green;">';
  263. // print number of entries found
  264. echo "Number of entries found: " . $ldap->count_entries($res) . "\n";
  265. while ( $entry ) {
  266. $dn = $ldap->get_dn($entry);
  267. echo "<b>$dn</b>\n";
  268. $attrs = $ldap->get_attributes($entry);
  269. for ( $i=0; $i < $attrs['count']; $i++) {
  270. echo "$attrs[$i]: ";
  271. for ( $j=0; $j < $attrs[$attrs[$i]]['count']; $j++ ) {
  272. echo $attrs[$attrs[$i]][$j] . " ";
  273. }
  274. echo "\n";
  275. }
  276. echo "\n";
  277. $entry = $ldap->next_entry($entry);
  278. }
  279. $ldap->free_result($res);
  280. echo'</pre>';
  281. }// test
  282. }
  283. if (!$ldapUser['user_dn']) {
  284. $errors[] = 'Error: login nie istnieje w bazie LDAP!';
  285. return false;
  286. }
  287. if($DBG){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">LDAP user (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($ldapUser);echo'</pre>';}
  288. if($DBG){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">ldap_bind (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('ldaprdn'=>$ldapUser['user_dn'], 'pass'=>'***'));echo'</pre>';}
  289. $ldapbind = $ldap->bind($ldapUser['user_dn'], $pass, $errorMsg);
  290. if (!$ldapbind) {
  291. $errors[] = 'Error: LDAP authorization failed!' . '<p>' . $errorMsg . '</p>';
  292. return false;
  293. }
  294. $user = new stdClass();
  295. $user->AUTHORIZE_USER = $ldapUser['uid'];
  296. $user->ADM_ACCOUNT = $ldapUser['uid'];
  297. $user->ADM_NAME = $ldapUser['cn'];
  298. $user->OTHER_INFO = $ldapUser['mail'];
  299. // get ID, ... from DB
  300. $db = DB::getDB();
  301. $sql = "SELECT u.*
  302. from `ADMIN_USERS` as u
  303. where
  304. u.`ADM_ACCOUNT`='{$user->ADM_ACCOUNT}'
  305. and u.`A_STATUS` in('WAITING','NORMAL')
  306. ";
  307. // LIMIT 0, 1;
  308. $res = $db->query($sql);
  309. if (!$res) {
  310. die("Error SQL login!");
  311. }
  312. $num_rows = $db->num_rows($res);
  313. if ($num_rows == 0) {
  314. $errors[] = 'Error: brak uzytkownika w bazie danych!';
  315. return false;
  316. }
  317. else if ($num_rows == 1) {
  318. if ($r = $db->fetch($res)) {
  319. $user->ID = $r->ID;
  320. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  321. $user->ADM_COMPANY = $r->ADM_COMPANY;
  322. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  323. $user->ADM_PHONE = $r->ADM_PHONE;
  324. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  325. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  326. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  327. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  328. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  329. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  330. return $user;
  331. }
  332. }
  333. return $user;
  334. }
  335. public static function loginByDB($login, $pass, &$errors) {
  336. $db = DB::getDB();
  337. $login = $db->_($login);
  338. $pass = $db->_($pass);
  339. $sql = "SELECT u.*
  340. from `ADMIN_USERS` as u
  341. where
  342. u.`ADM_ACCOUNT`='{$login}'
  343. and ( u.`ADM_PASSWD`='{$pass}' or u.`ADM_PASSWD`=md5('{$pass}') )
  344. and u.`A_STATUS` in('WAITING','NORMAL')
  345. LIMIT 0, 1;
  346. ";
  347. $res = $db->query($sql);
  348. if (!$res) {
  349. die("Error SQL login!");
  350. }
  351. $num_rows = $db->num_rows($res);
  352. if ($num_rows == 0) {
  353. $errors[] = "Podales zlego uzytkownika lub/i haslo()";
  354. }
  355. else if ($num_rows == 1) {
  356. if ($r = $db->fetch($res)) {
  357. $user = new stdClass();
  358. $user->ID = $r->ID;
  359. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  360. $user->ADM_COMPANY = $r->ADM_COMPANY;
  361. $user->AUTHORIZE_USER = $r->ADM_ACCOUNT;
  362. $user->ADM_ACCOUNT = $r->ADM_ACCOUNT;
  363. $user->ADM_NAME = $r->ADM_NAME;
  364. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  365. $user->ADM_PHONE = $r->ADM_PHONE;
  366. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  367. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  368. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  369. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  370. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  371. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  372. //$user->ADM_AREA = "$r->ADM_AREA";
  373. //$_SESSION['ADM_PASSWD'] = $pass;
  374. return $user;
  375. }
  376. }
  377. return false;
  378. }
  379. public static function changePasswd($oldPass, $newPass) {
  380. $db = DB::getDB();
  381. $newPass = $db->_($newPass);
  382. $oldPass = $db->_($oldPass);
  383. $username = $db->_(self::getName());
  384. $sql = "update `ADMIN_USERS` set
  385. `ADM_PASSWD`=md5('{$newPass}')
  386. where
  387. `ADM_ACCOUNT`='{$username}' and
  388. (`ADM_PASSWD`='{$oldPass}' or `ADM_PASSWD`=md5('{$oldPass}'))
  389. limit 1;
  390. ";
  391. $db->query($sql);
  392. return ($db->affected_rows() > 0);
  393. }
  394. /**
  395. * Check user access.
  396. * @param string $name
  397. * 'menu' - access to view menu
  398. */
  399. public static function hasAccess($name) {
  400. switch ($name) {
  401. case 'menu': {
  402. if (User::get('ADM_ADMIN_LEVEL') < 6) {
  403. return true;
  404. }
  405. else {
  406. Lib::loadClass('Config');
  407. $ALLOW_GUEST_ACCOUNT = (int)Config::get('ALLOW_GUEST_ACCOUNT');
  408. if ($ALLOW_GUEST_ACCOUNT && User::getLogin() == 'anonymous') {
  409. return true;
  410. }
  411. }
  412. break;
  413. }
  414. case 'dbg': {
  415. return (0 == User::get('ADM_ADMIN_LEVEL'));
  416. break;
  417. }
  418. default:
  419. }
  420. return false;
  421. }
  422. public static function getAnonymousAccount() {
  423. $db = DB::getDB();
  424. if (!$db) die("Error DB connection!");
  425. $sql = "select u.*
  426. from `ADMIN_USERS` as u
  427. where
  428. u.`ADM_ACCOUNT`='anonymous'
  429. and u.`EMPLOYEE_TYPE`='Anonymous'
  430. and u.`A_STATUS` in('NORMAL')
  431. order by u.`ID` asc
  432. limit 1
  433. ";
  434. $res = $db->query($sql);
  435. if (!$res) die("Error SQL login!");
  436. $num_rows = $db->num_rows($res);
  437. if ($r = $db->fetch($res)) {
  438. //$_SESSION['ADM_PASSWD'] = $pass;
  439. $user = new stdClass();
  440. $user->ID = "$r->ID";
  441. $user->AUTHORIZE_USER = "$r->ADM_ACCOUNT";
  442. $user->ADM_ACCOUNT = "$r->ADM_ACCOUNT";
  443. $user->ADM_PASSWD = "$r->ADM_PASSWD";
  444. //$user->ADM_AREA = "$r->ADM_AREA";
  445. $user->ADM_NAME = "$r->ADM_NAME";
  446. $user->ADM_TECH_WORKER = "$r->ADM_TECH_WORKER";
  447. $user->ADM_COMPANY = "$r->ADM_COMPANY";
  448. $user->ADM_ADMIN_LEVEL = "$r->ADM_ADMIN_LEVEL";
  449. $user->ADM_PHONE = "$r->ADM_PHONE";
  450. $user->ADM_ADMIN_EXPIRE = "$r->ADM_ADMIN_EXPIRE";
  451. $user->ADM_ADMIN_DESC = "$r->ADM_ADMIN_DESC";
  452. return $user;
  453. }
  454. return false;
  455. }
  456. public static function getLdapGroups() {
  457. $ldapGroups = User::_fetchLdapGroups();
  458. return $ldapGroups;
  459. }
  460. public static function getLdapGroupsNames() {
  461. $ldapGroupsNames = array();
  462. $ldapGroups = User::_fetchLdapGroups();
  463. foreach ($ldapGroups as $kID => $vLDAPGroup) {
  464. $ldapGroupsNames[$kID] = $vLDAPGroup->cn;
  465. }
  466. return $ldapGroupsNames;
  467. }
  468. public static function getLdapGroupsIds() {
  469. $ldapGroups = User::_fetchLdapGroups();
  470. $gidNumbers = array();
  471. if (!empty($ldapGroups)) {
  472. foreach ($ldapGroups as $vLdapGroup) {
  473. $gidNumbers[] = $vLdapGroup->gidNumber;
  474. }
  475. }
  476. return $gidNumbers;
  477. }
  478. public static function _fetchLdapGroups() {
  479. static $_groups;
  480. if (!$_groups) {
  481. $login = User::getLogin();
  482. Lib::loadClass('UsersLdapHelper');
  483. $_groups = UsersLdapHelper::getUserGroups($login, 3);
  484. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">getLDAPGroupByUserName (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($_groups);echo'</pre>';
  485. }
  486. return $_groups;
  487. }
  488. }