User.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695
  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 getDefaultAclGroup() {
  34. if (!V::get('DEFAULT_ACL_GROUP', '', $_SESSION)) {
  35. self::_fetchMoreUserData();
  36. }
  37. return $_SESSION['DEFAULT_ACL_GROUP'];
  38. }
  39. public static function _fetchMoreUserData() {
  40. $db = DB::getDB();
  41. $login = self::getLogin();
  42. if (empty($login)) return false;
  43. $sql = "select `ID`, `INICJALY_HANDLOWCA`, `EMPLOYEE_TYPE`
  44. , `DEFAULT_ACL_GROUP`
  45. from `ADMIN_USERS`
  46. where `ADM_ACCOUNT`='{$login}'
  47. limit 1
  48. ";
  49. $res = $db->query($sql);
  50. if ($r = $db->fetch($res)) {
  51. $_SESSION['ADM_ID'] = $r->ID;
  52. $_SESSION['ADM_INICJALY_HANDLOWCA'] = $r->INICJALY_HANDLOWCA;
  53. $_SESSION['EMPLOYEE_TYPE'] = $r->EMPLOYEE_TYPE;
  54. $_SESSION['DEFAULT_ACL_GROUP'] = $r->DEFAULT_ACL_GROUP;
  55. }
  56. }
  57. public static function logged() {
  58. return (!empty($_SESSION['AUTHORIZE_USER']))? true : false;
  59. }
  60. public static function get( $key ) {
  61. return V::get($key, '', $_SESSION);
  62. }
  63. public static function getGroups() {
  64. $groups = User::_fetchGroups();
  65. return $groups;
  66. }
  67. public static function getGroupsIds() {
  68. $groups = User::_fetchGroups();
  69. return array_keys($groups);
  70. }
  71. public static function _fetchGroups() {
  72. static $_groups;
  73. if (!$_groups) {
  74. $user_id = User::getID();
  75. Lib::loadClass('UsersHelper');
  76. $_groups = UsersHelper::get_group_by_user($user_id);
  77. }
  78. return $_groups;
  79. }
  80. public static function loadProfile($force = false) {
  81. return UserProfile::load($force);
  82. }
  83. public static function saveProfile() {
  84. return UserProfile::save();
  85. }
  86. public static function getProfile($key) {
  87. return UserProfile::get($key);
  88. }
  89. public static function setProfile($key, $val) {
  90. UserProfile::set($key, $val);
  91. }
  92. public static function getProfileColumn($column_name, $key) {
  93. return UserProfile::getColumn($column_name, $key);
  94. }
  95. public static function setProfileColumn($column_name, $key, $value) {
  96. UserProfile::setColumn($column_name, $key, $value);
  97. }
  98. public static function removeProfileColumn($column_name, $key) {
  99. UserProfile::removeColumn($column_name, $key);
  100. }
  101. public static function isAdmin() {
  102. if (in_array(self::get('ADM_ADMIN_LEVEL'), array(0, 1))) {
  103. return true;
  104. }
  105. return false;
  106. }
  107. public static function getRawData() {
  108. $ret = array();
  109. if (self::logged()) {
  110. $ret['id'] = self::getID();
  111. $ret['login'] = self::getName();
  112. $ret['name'] = self::get('ADM_NAME');
  113. $ret['admin_level'] = self::get('ADM_ADMIN_LEVEL');
  114. $ret['opis'] = self::get('ADM_ADMIN_DESC');
  115. }
  116. return $ret;
  117. }
  118. public static function getAcl() {
  119. static $_acl;
  120. if (!$_acl) {
  121. Lib::loadClass('UserAcl');
  122. $_acl = new UserAcl(self::getID(), $use_cache = true);
  123. $_acl->fetchGroups();
  124. }
  125. return $_acl;
  126. }
  127. public static function reloadAcl() {
  128. unset($_SESSION['TableAcl_cache']);
  129. unset($_SESSION['Typespecial_Cache']);
  130. unset($_SESSION['ADM_INICJALY_HANDLOWCA']);
  131. unset($_SESSION['EMPLOYEE_TYPE']);
  132. unset($_SESSION['DEFAULT_ACL_GROUP']);
  133. //TODO: not work: unset($_SESSION['CRM_PROCES_USERA_WYKONANE_TESTY-' . User::getID()]);
  134. //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>';
  135. $userAcl = User::getAcl();
  136. $userAcl->fetchAllPerms(true);
  137. }
  138. public static function auth() {
  139. $task = V::get('LOGIN', '', $_REQUEST);
  140. $data = array();
  141. $data['errors'] = array();
  142. Lib::loadClass('Config');
  143. $data['ALLOW_GUEST_ACCOUNT'] = (int)Config::get('ALLOW_GUEST_ACCOUNT');
  144. switch ($task) {
  145. case 'LOGIN':
  146. if (!User::logged()) {
  147. $req_ADM_ACCOUNT = (isset($_REQUEST['ADM_ACCOUNT']))? $_REQUEST['ADM_ACCOUNT'] : '';
  148. $req_ADM_PASSWD = (isset($_REQUEST['ADM_PASSWD']))? $_REQUEST['ADM_PASSWD'] : '';
  149. if (empty($req_ADM_ACCOUNT) || empty($req_ADM_PASSWD)) {
  150. $data['errors'][] = "Proszę podać LOGIN i HASŁO!";
  151. } else {
  152. User::login($req_ADM_ACCOUNT, $req_ADM_PASSWD, $data['errors']);
  153. }
  154. }
  155. break;
  156. case 'LOGOUT':
  157. if (User::logged()) {
  158. session_destroy();
  159. unset($_SESSION['AUTHORIZE_USER']);
  160. unset($_SESSION['ADM_ACCOUNT']);
  161. Lib::loadClass('SE_Layout');
  162. SE_Layout::gora();
  163. SE_Layout::loadTemplate('logout', $data);
  164. SE_Layout::dol();
  165. exit;
  166. }
  167. break;
  168. case 'PERMS_RELOAD':
  169. User::reloadAcl();
  170. break;
  171. case 'PASSEDIT':
  172. if (User::logged()) {
  173. $data = array();
  174. if (!empty($_POST)) {
  175. if (empty($_POST['ADM_PASSWD_NEW']) || empty($_POST['ADM_PASSWD'])) {
  176. $data['msg'] = "Proszę podać stare i nowe hasło.";
  177. }
  178. }
  179. if (!empty($_POST['ADM_PASSWD_NEW']) && !empty($_POST['ADM_PASSWD'])) {
  180. $ret = User::changePasswd($_POST['ADM_PASSWD'], $_POST['ADM_PASSWD_NEW']);
  181. if ($ret) {
  182. $data['info'] = "Hasło zostało zmienione";
  183. } else {
  184. $data['error'] = "Nie udało się zmienić hasła";
  185. }
  186. }
  187. SE_Layout::gora();
  188. SE_Layout::loadTemplate('passedit', $data);
  189. SE_Layout::dol();
  190. exit;
  191. }
  192. break;
  193. case 'ANONYMOUS_LOGIN':
  194. if (!User::logged()) {
  195. if ($data['ALLOW_GUEST_ACCOUNT'] != 1) {
  196. $data['errors'][] = "Zablokowane logowaniwe na konto gościa!";
  197. }
  198. else {
  199. $anonim = User::getAnonymousAccount();
  200. if (!$anonim) {
  201. $data['errors'][] = "Konto gościa nie istnieje!";
  202. } else {
  203. User::login($anonim->ADM_ACCOUNT, $anonim->ADM_PASSWD, $data['errors']);
  204. }
  205. }
  206. }
  207. break;
  208. default:
  209. }
  210. if (!User::logged()) {
  211. Lib::loadClass('SE_Layout');
  212. SE_Layout::gora();
  213. SE_Layout::loadTemplate('login', $data);
  214. SE_Layout::dol();
  215. exit;
  216. }
  217. }
  218. public static function kandydatLogin($kandydatId, &$errors = array()) {
  219. $user = self::kandydatLoginByDB($kandydatId, $errors);
  220. if ($user) {
  221. $_SESSION['ADM_ID'] = $user->ID;
  222. $_SESSION['AUTHORIZE_USER'] = $user->ADM_ACCOUNT;
  223. $_SESSION['ADM_ACCOUNT'] = $user->ADM_ACCOUNT;
  224. //$_SESSION['ADM_AREA'] = $user->ADM_AREA;
  225. $_SESSION['ADM_NAME'] = $user->ADM_NAME;
  226. $_SESSION['ADM_TECH_WORKER'] = $user->ADM_TECH_WORKER;
  227. $_SESSION['ADM_COMPANY'] = $user->ADM_COMPANY;
  228. $_SESSION['ADM_ADMIN_LEVEL'] = $user->ADM_ADMIN_LEVEL;
  229. $_SESSION['ADM_PHONE'] = $user->ADM_PHONE;
  230. $_SESSION['ADM_ADMIN_EXPIRE'] = $user->ADM_ADMIN_EXPIRE;
  231. $_SESSION['ADM_ADMIN_DESC'] = $user->ADM_ADMIN_DESC;
  232. $_SESSION['EMPLOYEE_TYPE'] = $user->EMPLOYEE_TYPE;
  233. // save user pass in encrypted form
  234. Lib::loadClass('Crypt');
  235. $_SESSION['ADM_PASS_HASH'] = Crypt::encrypt($pass);
  236. $_SESSION['EMAIL_IMAP_IMPORT_PASSWD_HASH'] = Crypt::encrypt($user->EMAIL_IMAP_IMPORT_PASSWD);
  237. $_SESSION['EMAIL_IMAP_IMPORT_HOST'] = $user->EMAIL_IMAP_IMPORT_HOST;
  238. $_SESSION['EMAIL_IMAP_IMPORT_USERNAME'] = $user->EMAIL_IMAP_IMPORT_USERNAME;
  239. //$keyFromHash = Crypt::decrypt($_SESSION['ADM_PASS_HASH']);
  240. $userAcl = User::getAcl();
  241. $userAcl->fetchAllPerms();
  242. return true;
  243. }
  244. return false;
  245. }
  246. public static function login($login, $pass, &$errors) {
  247. Lib::loadClass('LDAP');
  248. $ldap = LDAP::getInstance();
  249. if ($ldap != null && $ldap->isConnected()) {
  250. $user = self::loginByLDAP($login, $pass, $errors);
  251. } else {
  252. $user = self::loginByDB($login, $pass, $errors);
  253. }
  254. if ($user) {
  255. $_SESSION['ADM_ID'] = $user->ID;
  256. $_SESSION['AUTHORIZE_USER'] = $user->ADM_ACCOUNT;
  257. $_SESSION['ADM_ACCOUNT'] = $user->ADM_ACCOUNT;
  258. //$_SESSION['ADM_AREA'] = $user->ADM_AREA;
  259. $_SESSION['ADM_NAME'] = $user->ADM_NAME;
  260. $_SESSION['ADM_TECH_WORKER'] = $user->ADM_TECH_WORKER;
  261. $_SESSION['ADM_COMPANY'] = $user->ADM_COMPANY;
  262. $_SESSION['ADM_ADMIN_LEVEL'] = $user->ADM_ADMIN_LEVEL;
  263. $_SESSION['ADM_PHONE'] = $user->ADM_PHONE;
  264. $_SESSION['ADM_ADMIN_EXPIRE'] = $user->ADM_ADMIN_EXPIRE;
  265. $_SESSION['ADM_ADMIN_DESC'] = $user->ADM_ADMIN_DESC;
  266. $_SESSION['EMPLOYEE_TYPE'] = $user->EMPLOYEE_TYPE;
  267. // save user pass in encrypted form
  268. Lib::loadClass('Crypt');
  269. $_SESSION['ADM_PASS_HASH'] = Crypt::encrypt($pass);
  270. $_SESSION['EMAIL_IMAP_IMPORT_PASSWD_HASH'] = Crypt::encrypt($user->EMAIL_IMAP_IMPORT_PASSWD);
  271. $_SESSION['EMAIL_IMAP_IMPORT_HOST'] = $user->EMAIL_IMAP_IMPORT_HOST;
  272. $_SESSION['EMAIL_IMAP_IMPORT_USERNAME'] = $user->EMAIL_IMAP_IMPORT_USERNAME;
  273. //$keyFromHash = Crypt::decrypt($_SESSION['ADM_PASS_HASH']);
  274. $userAcl = User::getAcl();
  275. $userAcl->fetchAllPerms();
  276. return true;
  277. }
  278. return false;
  279. }
  280. public static function loginByLDAP($login, $pass, &$errors) {
  281. $ldapUser = array();
  282. $DBG = false;
  283. Lib::loadClass('LDAP');
  284. $ldap = LDAP::getInstance();
  285. if (!$ldap->isConnected()) {
  286. $errors[] = 'Error: Could not connect to LDAP server!';
  287. return false;
  288. }
  289. $filter = (false !== strpos($login, '@'))? "(mail={$login})" : "(uid={$login})";
  290. //$filter = "cn=*";// show all ldap accounts
  291. $justthese = array();//array("uid", "givenName", "mail", "*");
  292. 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>';}
  293. $res = $ldap->search($filter, 'cn=users', $justthese);
  294. if ($ldap->count_entries($res) > 0) {
  295. $entry = $ldap->first_entry($res);
  296. if ($entry) {
  297. $ldapUser['user_dn'] = $ldap->get_dn($entry);
  298. $val = $ldap->get_values($entry, 'uid');
  299. $ldapUser['uid'] = $val[0];
  300. $val = $ldap->get_values($entry, 'mail');
  301. $ldapUser['mail'] = $val[0];
  302. $val = $ldap->get_values($entry, 'cn');
  303. $ldapUser['cn'] = $val[0];
  304. } else {
  305. $errors[] = 'Login nie istnieje';
  306. return false;
  307. }
  308. if($DBG){// test
  309. echo'<pre style="overflow:auto;border:1px solid green;">';
  310. // print number of entries found
  311. echo "Number of entries found: " . $ldap->count_entries($res) . "\n";
  312. while ( $entry ) {
  313. $dn = $ldap->get_dn($entry);
  314. echo "<b>$dn</b>\n";
  315. $attrs = $ldap->get_attributes($entry);
  316. for ( $i=0; $i < $attrs['count']; $i++) {
  317. echo "$attrs[$i]: ";
  318. for ( $j=0; $j < $attrs[$attrs[$i]]['count']; $j++ ) {
  319. echo $attrs[$attrs[$i]][$j] . " ";
  320. }
  321. echo "\n";
  322. }
  323. echo "\n";
  324. $entry = $ldap->next_entry($entry);
  325. }
  326. $ldap->free_result($res);
  327. echo'</pre>';
  328. }// test
  329. }
  330. if (!$ldapUser['user_dn']) {
  331. $errors[] = 'Error: login nie istnieje w bazie LDAP!';
  332. return false;
  333. }
  334. 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>';}
  335. 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>';}
  336. $ldapbind = $ldap->bind($ldapUser['user_dn'], $pass, $errorMsg);
  337. if (!$ldapbind) {
  338. $errors[] = 'Error: LDAP authorization failed!' . '<p>' . $errorMsg . '</p>';
  339. return false;
  340. }
  341. $user = new stdClass();
  342. $user->AUTHORIZE_USER = $ldapUser['uid'];
  343. $user->ADM_ACCOUNT = $ldapUser['uid'];
  344. $user->ADM_NAME = $ldapUser['cn'];
  345. $user->OTHER_INFO = $ldapUser['mail'];
  346. // get ID, ... from DB
  347. $db = DB::getDB();
  348. $sql = "SELECT u.*
  349. from `ADMIN_USERS` as u
  350. where
  351. u.`ADM_ACCOUNT`='{$user->ADM_ACCOUNT}'
  352. and u.`A_STATUS` in('WAITING','NORMAL')
  353. ";
  354. // LIMIT 0, 1;
  355. $res = $db->query($sql);
  356. if (!$res) {
  357. die("Error SQL login!");
  358. }
  359. $num_rows = $db->num_rows($res);
  360. if ($num_rows == 0) {
  361. $errors[] = 'Error: brak uzytkownika w bazie danych!';
  362. return false;
  363. }
  364. else if ($num_rows == 1) {
  365. if ($r = $db->fetch($res)) {
  366. $user->ID = $r->ID;
  367. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  368. $user->ADM_COMPANY = $r->ADM_COMPANY;
  369. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  370. $user->ADM_PHONE = $r->ADM_PHONE;
  371. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  372. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  373. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  374. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  375. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  376. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  377. return $user;
  378. }
  379. }
  380. return $user;
  381. }
  382. public static function loginByDB($login, $pass, &$errors) {
  383. $db = DB::getDB();
  384. $login = $db->_($login);
  385. $pass = $db->_($pass);
  386. $sql = "SELECT u.*
  387. from `ADMIN_USERS` as u
  388. where
  389. u.`ADM_ACCOUNT`='{$login}'
  390. and ( u.`ADM_PASSWD`='{$pass}' or u.`ADM_PASSWD`=md5('{$pass}') )
  391. and u.`A_STATUS` in('WAITING','NORMAL')
  392. LIMIT 0, 1;
  393. ";
  394. $res = $db->query($sql);
  395. if (!$res) {
  396. die("Error SQL login!");
  397. }
  398. $num_rows = $db->num_rows($res);
  399. if ($num_rows == 0) {
  400. $errors[] = "Podales zlego uzytkownika lub/i haslo()";
  401. }
  402. else if ($num_rows == 1) {
  403. if ($r = $db->fetch($res)) {
  404. $user = new stdClass();
  405. $user->ID = $r->ID;
  406. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  407. $user->ADM_COMPANY = $r->ADM_COMPANY;
  408. $user->AUTHORIZE_USER = $r->ADM_ACCOUNT;
  409. $user->ADM_ACCOUNT = $r->ADM_ACCOUNT;
  410. $user->ADM_NAME = $r->ADM_NAME;
  411. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  412. $user->ADM_PHONE = $r->ADM_PHONE;
  413. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  414. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  415. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  416. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  417. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  418. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  419. //$user->ADM_AREA = "$r->ADM_AREA";
  420. //$_SESSION['ADM_PASSWD'] = $pass;
  421. return $user;
  422. }
  423. }
  424. return false;
  425. }
  426. public static function kandydatLoginByDB($kandydatId, &$errors) {
  427. $db = DB::getDB();
  428. $kandydatId = (int)$kandydatId;
  429. $sql = "SELECT u.*
  430. from `ADMIN_USERS` as u
  431. where
  432. u.`ID`='{$kandydatId}'
  433. and u.`A_STATUS` in('WAITING','NORMAL')
  434. LIMIT 0, 1;
  435. ";
  436. $res = $db->query($sql);
  437. if (!$res) {
  438. die("Error SQL login!");
  439. }
  440. $num_rows = $db->num_rows($res);
  441. if ($num_rows == 0) {
  442. $errors[] = "Podales zlego uzytkownika lub/i haslo()";
  443. }
  444. else if ($num_rows == 1) {
  445. if ($r = $db->fetch($res)) {
  446. $user = new stdClass();
  447. $user->ID = $r->ID;
  448. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  449. $user->ADM_COMPANY = $r->ADM_COMPANY;
  450. $user->AUTHORIZE_USER = $r->ADM_ACCOUNT;
  451. $user->ADM_ACCOUNT = $r->ADM_ACCOUNT;
  452. $user->ADM_NAME = $r->ADM_NAME;
  453. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  454. $user->ADM_PHONE = $r->ADM_PHONE;
  455. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  456. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  457. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  458. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  459. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  460. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  461. //$user->ADM_AREA = "$r->ADM_AREA";
  462. //$_SESSION['ADM_PASSWD'] = $pass;
  463. return $user;
  464. }
  465. }
  466. return false;
  467. }
  468. public static function changePasswd($oldPass, $newPass) {
  469. $db = DB::getDB();
  470. $newPass = $db->_($newPass);
  471. $oldPass = $db->_($oldPass);
  472. $username = $db->_(self::getName());
  473. $sql = "update `ADMIN_USERS` set
  474. `ADM_PASSWD`=md5('{$newPass}')
  475. where
  476. `ADM_ACCOUNT`='{$username}' and
  477. (`ADM_PASSWD`='{$oldPass}' or `ADM_PASSWD`=md5('{$oldPass}'))
  478. limit 1;
  479. ";
  480. $db->query($sql);
  481. return ($db->affected_rows() > 0);
  482. }
  483. /**
  484. * Check user access.
  485. * @param string $name
  486. * 'menu' - access to view menu
  487. *
  488. * @from [4101] ADM_ADMIN_LEVEL
  489. * Poziom uprawnień - każdy powinien mieć poziom o numerze 3
  490. * kierownicy powinni mieć 2
  491. * a administratorzy 0
  492. * kandydaci poziom 6.
  493. * Poziom 1 umożliwia edycje procesów i zasobów
  494. * poziom 2 umożliwia ocenę testów
  495. * poziom 3 umożliwia widzenie systemu jakości.
  496. */
  497. public static function hasAccess($name) {
  498. switch ($name) {
  499. case 'menu': {
  500. if (User::get('ADM_ADMIN_LEVEL') < 6) {
  501. return true;
  502. }
  503. else {
  504. Lib::loadClass('Config');
  505. $ALLOW_GUEST_ACCOUNT = (int)Config::get('ALLOW_GUEST_ACCOUNT');
  506. if ($ALLOW_GUEST_ACCOUNT && User::getLogin() == 'anonymous') {
  507. return true;
  508. }
  509. }
  510. break;
  511. }
  512. case 'dbg': {
  513. return (0 == User::get('ADM_ADMIN_LEVEL'));
  514. break;
  515. }
  516. case 'procesy': {
  517. if (User::get('ADM_ADMIN_LEVEL') < 4) return true;
  518. break;
  519. }
  520. case 'procesy_admin': {
  521. if (User::get('ADM_ADMIN_LEVEL') < 2) return true;
  522. break;
  523. }
  524. case 'testy': {
  525. if (User::get('ADM_ADMIN_LEVEL') <= 6) return true;
  526. break;
  527. }
  528. case 'testy_wyniki': {
  529. if (User::get('ADM_ADMIN_LEVEL') < 3) return true;
  530. break;
  531. }
  532. case 'testy_wyniki_edit': {
  533. if (User::get('ADM_ADMIN_LEVEL') < 3) return true;
  534. break;
  535. }
  536. case 'testy_wyniki_read': {
  537. if (User::get('ADM_ADMIN_LEVEL') < 3) return true;
  538. break;
  539. }
  540. case 'user_add_group': {
  541. if (User::get('ADM_ADMIN_LEVEL') < 1) return true;
  542. break;
  543. }
  544. default:
  545. }
  546. return false;
  547. }
  548. public static function hasGroup($groupName) {
  549. // TODO: find group by name @see self::getGroups() @used in SchemaReaderProcess
  550. return false;
  551. }
  552. public static function getAnonymousAccount() {
  553. $db = DB::getDB();
  554. if (!$db) die("Error DB connection!");
  555. $sql = "select u.*
  556. from `ADMIN_USERS` as u
  557. where
  558. u.`ADM_ACCOUNT`='anonymous'
  559. and u.`EMPLOYEE_TYPE`='Anonymous'
  560. and u.`A_STATUS` in('NORMAL')
  561. order by u.`ID` asc
  562. limit 1
  563. ";
  564. $res = $db->query($sql);
  565. if (!$res) die("Error SQL login!");
  566. $num_rows = $db->num_rows($res);
  567. if ($r = $db->fetch($res)) {
  568. //$_SESSION['ADM_PASSWD'] = $pass;
  569. $user = new stdClass();
  570. $user->ID = "$r->ID";
  571. $user->AUTHORIZE_USER = "$r->ADM_ACCOUNT";
  572. $user->ADM_ACCOUNT = "$r->ADM_ACCOUNT";
  573. $user->ADM_PASSWD = "$r->ADM_PASSWD";
  574. //$user->ADM_AREA = "$r->ADM_AREA";
  575. $user->ADM_NAME = "$r->ADM_NAME";
  576. $user->ADM_TECH_WORKER = "$r->ADM_TECH_WORKER";
  577. $user->ADM_COMPANY = "$r->ADM_COMPANY";
  578. $user->ADM_ADMIN_LEVEL = "$r->ADM_ADMIN_LEVEL";
  579. $user->ADM_PHONE = "$r->ADM_PHONE";
  580. $user->ADM_ADMIN_EXPIRE = "$r->ADM_ADMIN_EXPIRE";
  581. $user->ADM_ADMIN_DESC = "$r->ADM_ADMIN_DESC";
  582. return $user;
  583. }
  584. return false;
  585. }
  586. public static function getLdapGroups() {
  587. $ldapGroups = User::_fetchLdapGroups();
  588. return $ldapGroups;
  589. }
  590. public static function getLdapGroupsNames() {
  591. $ldapGroupsNames = array();
  592. $ldapGroups = User::_fetchLdapGroups();
  593. foreach ($ldapGroups as $kID => $vLDAPGroup) {
  594. $ldapGroupsNames[$kID] = $vLDAPGroup->cn;
  595. }
  596. return $ldapGroupsNames;
  597. }
  598. public static function getLdapGroupsIds() {
  599. $ldapGroups = User::_fetchLdapGroups();
  600. $gidNumbers = array();
  601. if (!empty($ldapGroups)) {
  602. foreach ($ldapGroups as $vLdapGroup) {
  603. $gidNumbers[] = $vLdapGroup->gidNumber;
  604. }
  605. }
  606. return $gidNumbers;
  607. }
  608. public static function _fetchLdapGroups() {
  609. static $_groups;
  610. if (!$_groups) {
  611. $login = User::getLogin();
  612. Lib::loadClass('UsersLdapHelper');
  613. $_groups = UsersLdapHelper::getUserGroups($login, 3);
  614. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">getLDAPGroupByUserName (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($_groups);echo'</pre>';
  615. }
  616. return $_groups;
  617. }
  618. }