User.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814
  1. <?php
  2. Lib::loadClass('UserProfile');
  3. Lib::loadClass('Router');
  4. Lib::loadClass('DebugExecutionTime');
  5. Lib::loadClass('UI');
  6. class User {
  7. public static function getLogin() {
  8. return V::get('ADM_ACCOUNT', '', $_SESSION);
  9. }
  10. public static function getName() {
  11. return V::get('ADM_ACCOUNT', '', $_SESSION);
  12. }
  13. public static function getID() {
  14. if (V::get('ADM_ID', 0, $_SESSION, 'int') <= 0) {
  15. self::_fetchMoreUserData();
  16. }
  17. return V::get('ADM_ID', '', $_SESSION);
  18. }
  19. public static function getType() {
  20. if (empty($_SESSION['EMPLOYEE_TYPE'])) {
  21. self::_fetchMoreUserData();
  22. }
  23. return V::get('EMPLOYEE_TYPE', '', $_SESSION);
  24. }
  25. public static function getFullName() {
  26. return V::get('ADM_NAME', '', $_SESSION);
  27. }
  28. public static function getInicjaly() {
  29. if (!array_key_exists('ADM_INICJALY_HANDLOWCA', $_SESSION)) {
  30. self::_fetchMoreUserData();
  31. }
  32. return $_SESSION['ADM_INICJALY_HANDLOWCA'];
  33. }
  34. public static function getDefaultAclGroup() {
  35. if (!array_key_exists('DEFAULT_ACL_GROUP', $_SESSION)) {
  36. self::_fetchMoreUserData();
  37. }
  38. return $_SESSION['DEFAULT_ACL_GROUP'];
  39. }
  40. public static function _fetchMoreUserData() {
  41. $db = DB::getDB();
  42. $login = self::getLogin();
  43. if (empty($login)) return false;
  44. $sql = "select `ID`, `INICJALY_HANDLOWCA`, `EMPLOYEE_TYPE`
  45. , `DEFAULT_ACL_GROUP`
  46. from `ADMIN_USERS`
  47. where `ADM_ACCOUNT`='{$login}'
  48. limit 1
  49. ";
  50. $res = $db->query($sql);
  51. if ($r = $db->fetch($res)) {
  52. $_SESSION['ADM_ID'] = $r->ID;
  53. $_SESSION['ADM_INICJALY_HANDLOWCA'] = $r->INICJALY_HANDLOWCA;
  54. $_SESSION['EMPLOYEE_TYPE'] = $r->EMPLOYEE_TYPE;
  55. $_SESSION['DEFAULT_ACL_GROUP'] = $r->DEFAULT_ACL_GROUP;
  56. }
  57. }
  58. public static function logged() {
  59. return (!empty($_SESSION['AUTHORIZE_USER']))? true : false;
  60. }
  61. public static function get( $key ) {
  62. return V::get($key, '', $_SESSION);
  63. }
  64. public static function getGroups() {
  65. $groups = User::_fetchGroups();
  66. return $groups;
  67. }
  68. public static function getGroupsIds() {
  69. $groups = User::_fetchGroups();
  70. return array_keys($groups);
  71. }
  72. public static function _fetchGroups() {
  73. static $_groups;
  74. if (!$_groups) {
  75. $user_id = User::getID();
  76. Lib::loadClass('UsersHelper');
  77. $_groups = UsersHelper::getGroupByUser($user_id);
  78. }
  79. return $_groups;
  80. }
  81. public static function loadProfile($force = false) {
  82. return UserProfile::load($force);
  83. }
  84. public static function saveProfile() {
  85. return UserProfile::save();
  86. }
  87. public static function getProfile($key) {
  88. return UserProfile::get($key);
  89. }
  90. public static function setProfile($key, $val) {
  91. UserProfile::set($key, $val);
  92. }
  93. public static function getProfileColumn($column_name, $key) {
  94. return UserProfile::getColumn($column_name, $key);
  95. }
  96. public static function setProfileColumn($column_name, $key, $value) {
  97. UserProfile::setColumn($column_name, $key, $value);
  98. }
  99. public static function removeProfileColumn($column_name, $key) {
  100. UserProfile::removeColumn($column_name, $key);
  101. }
  102. public static function isAdmin() {
  103. if (in_array(self::get('ADM_ADMIN_LEVEL'), array(0, 1))) {
  104. return true;
  105. }
  106. return false;
  107. }
  108. public static function getRawData() {
  109. $ret = array();
  110. if (self::logged()) {
  111. $ret['id'] = self::getID();
  112. $ret['login'] = self::getName();
  113. $ret['name'] = self::get('ADM_NAME');
  114. $ret['admin_level'] = self::get('ADM_ADMIN_LEVEL');
  115. $ret['opis'] = self::get('ADM_ADMIN_DESC');
  116. }
  117. return $ret;
  118. }
  119. public static function getCurrentUserObject() {
  120. $user = new stdClass();
  121. if (self::logged()) {
  122. $user->ID = $_SESSION['ADM_ID'];
  123. $user->ADM_ACCOUNT = $_SESSION['AUTHORIZE_USER'];
  124. $user->ADM_ACCOUNT = $_SESSION['ADM_ACCOUNT'];
  125. $user->ADM_NAME = $_SESSION['ADM_NAME'];
  126. $user->ADM_TECH_WORKER = $_SESSION['ADM_TECH_WORKER'];
  127. $user->ADM_COMPANY = $_SESSION['ADM_COMPANY'];
  128. $user->ADM_ADMIN_LEVEL = $_SESSION['ADM_ADMIN_LEVEL'];
  129. $user->ADM_PHONE = $_SESSION['ADM_PHONE'];
  130. $user->ADM_ADMIN_EXPIRE = $_SESSION['ADM_ADMIN_EXPIRE'];
  131. $user->ADM_ADMIN_DESC = $_SESSION['ADM_ADMIN_DESC'];
  132. $user->EMPLOYEE_TYPE = $_SESSION['EMPLOYEE_TYPE'];
  133. }
  134. return $user;
  135. }
  136. public static function getAcl() {
  137. static $_acl;
  138. if (!$_acl) {
  139. Lib::loadClass('UserAcl');
  140. $_acl = new UserAcl(self::getID(), $use_cache = true);
  141. $_acl->fetchGroups();
  142. }
  143. return $_acl;
  144. }
  145. public static function reloadAcl() {
  146. IF('123'==V::get('DBG_ACL','',$_GET)){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">SESSION KEYS (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): [';echo implode(',', array_keys($_SESSION));echo']</pre>';}
  147. /*
  148. * [3] => USER_PROFILE
  149. * [29] => CRM_PROCES_USERA_WYKONANE_TESTY-4517
  150. * [30] => TableAjax_Cache
  151. */
  152. IF('123'==V::get('DBG_ACL','',$_GET)){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">CONFIG (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($_SESSION['CONFIG']);echo'</pre>';}
  153. IF('123'==V::get('DBG_ACL','',$_GET)){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">TableAjax_Cache (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($_SESSION['TableAjax_Cache']);echo'</pre>';}
  154. unset($_SESSION['TableAcl_cache']);
  155. unset($_SESSION['Typespecial_Cache']);
  156. unset($_SESSION['ADM_INICJALY_HANDLOWCA']);
  157. unset($_SESSION['EMPLOYEE_TYPE']);
  158. unset($_SESSION['DEFAULT_ACL_GROUP']);
  159. IF('123'==V::get('DBG_ACL','',$_GET)){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">SESSION KEYS (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): [';echo implode(',', array_keys($_SESSION));echo']</pre>';}
  160. $testySesKey = 'CRM_PROCES_USERA_WYKONANE_TESTY-' . User::getID();
  161. if (isset($_SESSION[$testySesKey])) unset($_SESSION[$testySesKey]);
  162. $userAcl = User::getAcl();
  163. $userAcl->fetchAllPerms(true);
  164. }
  165. public static function auth() {
  166. $route = V::get('_route', '', $_REQUEST);
  167. if (!empty($route)) {
  168. Router::handleAuth($route);
  169. } else {
  170. self::authByRequest();
  171. }
  172. if (User::logged() && !V::get('ADM_ACL_LOADED', false, $_SESSION)) {
  173. $userAcl = User::getAcl();
  174. $userAcl->fetchAllPerms();
  175. $_SESSION['ADM_ACL_LOADED'] = true;
  176. }
  177. if (User::logged() && User::isAdmin()) {
  178. if (V::get('DBG_ON', '', $_REQUEST)) {
  179. DBG::activate();
  180. }
  181. }
  182. if (V::get('DBG_OFF', '', $_REQUEST)) {
  183. DBG::deactivate();
  184. }
  185. }
  186. public static function authByRequest() {
  187. $task = V::get('LOGIN', '', $_REQUEST);
  188. $data = array();
  189. $data['errors'] = array();
  190. Lib::loadClass('Config');
  191. $data['ALLOW_GUEST_ACCOUNT'] = (int)Config::get('ALLOW_GUEST_ACCOUNT');
  192. switch ($task) {
  193. case 'LOGIN':
  194. if (!User::logged()) {
  195. $req_ADM_ACCOUNT = (isset($_REQUEST['ADM_ACCOUNT']))? $_REQUEST['ADM_ACCOUNT'] : '';
  196. $req_ADM_PASSWD = (isset($_REQUEST['ADM_PASSWD']))? $_REQUEST['ADM_PASSWD'] : '';
  197. if (empty($req_ADM_ACCOUNT) || empty($req_ADM_PASSWD)) {
  198. $data['errors'][] = "Proszę podać poprawny login i hasło!";
  199. } else {
  200. try {
  201. User::login($req_ADM_ACCOUNT, $req_ADM_PASSWD);
  202. } catch (Exception $e) {
  203. $data['errors'][] = $e->getMessage();
  204. session_destroy();
  205. unset($_SESSION['AUTHORIZE_USER']);
  206. unset($_SESSION['ADM_ACCOUNT']);
  207. Lib::loadClass('UI');
  208. UI::gora();
  209. UI::loadTemplate('logout', $data);
  210. UI::dol();
  211. exit;
  212. }
  213. }
  214. }
  215. break;
  216. case 'LOGOUT':
  217. if (User::logged()) {
  218. $_SESSION = array();
  219. session_destroy();// Remove the server-side session information.
  220. session_write_close();
  221. session_start();
  222. session_regenerate_id(true);
  223. Lib::loadClass('UI');
  224. UI::gora();
  225. UI::loadTemplate('logout', $data);
  226. UI::dol();
  227. exit;
  228. }
  229. break;
  230. case 'PERMS_RELOAD':
  231. if (User::logged()) {
  232. try {
  233. $dbgExecTime = new DebugExecutionTime();
  234. $dbgExecTime->activate();
  235. $dbgExecTime->log('start');
  236. $routeFixCrmProcesInitIdx = Router::getRoute('FixCrmProcesInitIdx');
  237. if ($routeFixCrmProcesInitIdx) {
  238. $routeFixCrmProcesInitIdx->runMethod('callProcedure');
  239. }
  240. $dbgExecTime->log('FixCrmProcesInitIdx::callProcedure');
  241. $fixAllPermsExecTime = $dbgExecTime->getLastExecTime();
  242. User::reloadAcl();
  243. $dbgExecTime->log('User::reloadAcl');
  244. $fixUserPermsExecTime = $dbgExecTime->getLastExecTime();
  245. } catch (Exception $e) {
  246. $data['errors'][] = $e->getMessage();
  247. }
  248. UI::gora();
  249. UI::menu();
  250. ?>
  251. <div class="container">
  252. <div class="alert alert-success" title="<?php echo number_format($fixAllPermsExecTime, 4); ?> s / <?php echo number_format($fixUserPermsExecTime, 4); ?> s">
  253. Zaktualizowano uprawnienia
  254. </div>
  255. </div>
  256. <?php
  257. UI::loadTemplate('defaultPage', $data);
  258. UI::dol();
  259. exit;
  260. }
  261. break;
  262. case 'PASSEDIT':
  263. if (User::logged()) {
  264. $data = array();
  265. if (!empty($_POST)) {
  266. if (empty($_POST['ADM_PASSWD_NEW']) || empty($_POST['ADM_PASSWD'])) {
  267. $data['msg'] = "Proszę podać stare i nowe hasło.";
  268. }
  269. }
  270. if (!empty($_POST['ADM_PASSWD_NEW']) && !empty($_POST['ADM_PASSWD'])) {
  271. $ret = User::changePasswd($_POST['ADM_PASSWD'], $_POST['ADM_PASSWD_NEW']);
  272. if ($ret) {
  273. $data['info'] = "Hasło zostało zmienione";
  274. } else {
  275. $data['error'] = "Nie udało się zmienić hasła";
  276. }
  277. }
  278. UI::gora();
  279. UI::loadTemplate('passedit', $data);
  280. UI::dol();
  281. exit;
  282. }
  283. break;
  284. case 'ANONYMOUS_LOGIN':
  285. if (!User::logged()) {
  286. if ($data['ALLOW_GUEST_ACCOUNT'] != 1) {
  287. $data['errors'][] = "Zablokowane logowaniwe na konto gościa!";
  288. }
  289. else {
  290. $anonim = User::getAnonymousAccount();
  291. if (!$anonim) {
  292. $data['errors'][] = "Konto gościa nie istnieje!";
  293. } else {
  294. try {
  295. User::login($anonim->ADM_ACCOUNT, $anonim->ADM_PASSWD);
  296. } catch (Exception $e) {
  297. $data['errors'][] = $e->getMessage();
  298. }
  299. }
  300. }
  301. }
  302. break;
  303. default:
  304. }
  305. if (!User::logged()) {
  306. Lib::loadClass('UI');
  307. UI::gora();
  308. UI::loadTemplate('login', $data);
  309. UI::dol();
  310. exit;
  311. }
  312. }
  313. public static function kandydatLogin($kandydatId, &$errors = array()) {
  314. $user = self::kandydatLoginByDB($kandydatId, $errors);
  315. if ($user) {
  316. $_SESSION['ADM_ID'] = $user->ID;
  317. $_SESSION['AUTHORIZE_USER'] = $user->ADM_ACCOUNT;
  318. $_SESSION['ADM_ACCOUNT'] = $user->ADM_ACCOUNT;
  319. //$_SESSION['ADM_AREA'] = $user->ADM_AREA;
  320. $_SESSION['ADM_NAME'] = $user->ADM_NAME;
  321. $_SESSION['ADM_TECH_WORKER'] = $user->ADM_TECH_WORKER;
  322. $_SESSION['ADM_COMPANY'] = $user->ADM_COMPANY;
  323. $_SESSION['ADM_ADMIN_LEVEL'] = $user->ADM_ADMIN_LEVEL;
  324. $_SESSION['ADM_PHONE'] = $user->ADM_PHONE;
  325. $_SESSION['ADM_ADMIN_EXPIRE'] = $user->ADM_ADMIN_EXPIRE;
  326. $_SESSION['ADM_ADMIN_DESC'] = $user->ADM_ADMIN_DESC;
  327. $_SESSION['EMPLOYEE_TYPE'] = $user->EMPLOYEE_TYPE;
  328. // save user pass in encrypted form
  329. Lib::loadClass('Crypt');
  330. $_SESSION['ADM_PASS_HASH'] = Crypt::encrypt($pass);
  331. $_SESSION['EMAIL_IMAP_IMPORT_PASSWD_HASH'] = Crypt::encrypt($user->EMAIL_IMAP_IMPORT_PASSWD);
  332. $_SESSION['EMAIL_IMAP_IMPORT_HOST'] = $user->EMAIL_IMAP_IMPORT_HOST;
  333. $_SESSION['EMAIL_IMAP_IMPORT_USERNAME'] = $user->EMAIL_IMAP_IMPORT_USERNAME;
  334. //$keyFromHash = Crypt::decrypt($_SESSION['ADM_PASS_HASH']);
  335. $userAcl = User::getAcl();
  336. $userAcl->fetchAllPerms();
  337. return true;
  338. }
  339. return false;
  340. }
  341. public static function login($login, $pass) {
  342. Lib::loadClass('LDAP');
  343. $ldap = LDAP::getInstance();
  344. if ($ldap != null && $ldap->isConnected()) {
  345. $user = self::loginByLDAP($login, $pass);
  346. } else {
  347. $user = self::loginByDB($login, $pass);
  348. }
  349. if ($user) {
  350. $_SESSION['ADM_ID'] = $user->ID;
  351. $_SESSION['AUTHORIZE_USER'] = $user->ADM_ACCOUNT;
  352. $_SESSION['ADM_ACCOUNT'] = $user->ADM_ACCOUNT;
  353. //$_SESSION['ADM_AREA'] = $user->ADM_AREA;
  354. $_SESSION['ADM_NAME'] = $user->ADM_NAME;
  355. $_SESSION['ADM_TECH_WORKER'] = $user->ADM_TECH_WORKER;
  356. $_SESSION['ADM_COMPANY'] = $user->ADM_COMPANY;
  357. $_SESSION['ADM_ADMIN_LEVEL'] = $user->ADM_ADMIN_LEVEL;
  358. $_SESSION['ADM_PHONE'] = $user->ADM_PHONE;
  359. $_SESSION['ADM_ADMIN_EXPIRE'] = $user->ADM_ADMIN_EXPIRE;
  360. $_SESSION['ADM_ADMIN_DESC'] = $user->ADM_ADMIN_DESC;
  361. $_SESSION['EMPLOYEE_TYPE'] = $user->EMPLOYEE_TYPE;
  362. // save user pass in encrypted form
  363. Lib::loadClass('Crypt');
  364. $_SESSION['ADM_PASS_HASH'] = Crypt::encrypt($pass);
  365. $_SESSION['EMAIL_IMAP_IMPORT_PASSWD_HASH'] = Crypt::encrypt($user->EMAIL_IMAP_IMPORT_PASSWD);
  366. $_SESSION['EMAIL_IMAP_IMPORT_HOST'] = $user->EMAIL_IMAP_IMPORT_HOST;
  367. $_SESSION['EMAIL_IMAP_IMPORT_USERNAME'] = $user->EMAIL_IMAP_IMPORT_USERNAME;
  368. //$keyFromHash = Crypt::decrypt($_SESSION['ADM_PASS_HASH']);
  369. $userAcl = User::getAcl();
  370. $userAcl->fetchAllPerms();
  371. $_SESSION['ADM_ACL_LOADED'] = true;
  372. return true;
  373. }
  374. return false;
  375. }
  376. public static function loginByLDAP($login, $pass) {
  377. $ldapUser = array();
  378. $DBG = false;
  379. Lib::loadClass('LDAP');
  380. $ldap = LDAP::getInstance();
  381. if (!$ldap->isConnected()) {
  382. throw new Exception("Wystąpiły błędy podczas połączenia do bazy LDAP. Spróbuj ponownie za chwilę.");
  383. }
  384. $filter = (false !== strpos($login, '@'))? "(mail={$login})" : "(uid={$login})";
  385. //$filter = "cn=*";// show all ldap accounts
  386. $justthese = array();//array("uid", "givenName", "mail", "*");
  387. 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>';}
  388. $res = $ldap->search($filter, 'cn=users', $justthese);
  389. if ($ldap->count_entries($res) > 0) {
  390. $entry = $ldap->first_entry($res);
  391. if ($entry) {
  392. $ldapUser['user_dn'] = $ldap->get_dn($entry);
  393. $val = $ldap->get_values($entry, 'uid');
  394. $ldapUser['uid'] = $val[0];
  395. $val = $ldap->get_values($entry, 'mail');
  396. $ldapUser['mail'] = $val[0];
  397. $val = $ldap->get_values($entry, 'cn');
  398. $ldapUser['cn'] = $val[0];
  399. } else {
  400. throw new Exception("Login nie istnieje");
  401. }
  402. if($DBG){// test
  403. echo'<pre style="overflow:auto;border:1px solid green;">';
  404. // print number of entries found
  405. echo "Number of entries found: " . $ldap->count_entries($res) . "\n";
  406. while ( $entry ) {
  407. $dn = $ldap->get_dn($entry);
  408. echo "<b>$dn</b>\n";
  409. $attrs = $ldap->get_attributes($entry);
  410. for ( $i=0; $i < $attrs['count']; $i++) {
  411. echo "$attrs[$i]: ";
  412. for ( $j=0; $j < $attrs[$attrs[$i]]['count']; $j++ ) {
  413. echo $attrs[$attrs[$i]][$j] . " ";
  414. }
  415. echo "\n";
  416. }
  417. echo "\n";
  418. $entry = $ldap->next_entry($entry);
  419. }
  420. $ldap->free_result($res);
  421. echo'</pre>';
  422. }// test
  423. }
  424. if (!$ldapUser['user_dn']) {
  425. throw new Exception("Proszę podać poprawny login i hasło!");
  426. }
  427. 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>';}
  428. 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>';}
  429. $ldapbind = $ldap->bind($ldapUser['user_dn'], $pass, $errorMsg);
  430. if (!$ldapbind) {
  431. throw new Exception("Wystąpiły błędy podczas próby logowania. {$errorMsg}");
  432. }
  433. $user = new stdClass();
  434. $user->AUTHORIZE_USER = $ldapUser['uid'];
  435. $user->ADM_ACCOUNT = $ldapUser['uid'];
  436. $user->ADM_NAME = $ldapUser['cn'];
  437. $user->OTHER_INFO = $ldapUser['mail'];
  438. // get ID, ... from DB
  439. $db = DB::getDB();
  440. $sql = "SELECT u.*
  441. from `ADMIN_USERS` as u
  442. where
  443. u.`ADM_ACCOUNT`='{$user->ADM_ACCOUNT}'
  444. and u.`A_STATUS` in('WAITING','NORMAL')
  445. ";
  446. // LIMIT 0, 1;
  447. $res = $db->query($sql);
  448. if (!$res) {
  449. throw new Exception("Wystąpiły błędy podczas próby logowania. Błąd bazy danych.");
  450. }
  451. $num_rows = $db->num_rows($res);
  452. if ($num_rows == 0) {
  453. throw new Exception("Wystąpiły błędy podczas próby logowania. Brak użytkownika w bazie danych.");
  454. }
  455. else if ($num_rows == 1) {
  456. if ($r = $db->fetch($res)) {
  457. $user->ID = $r->ID;
  458. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  459. $user->ADM_COMPANY = $r->ADM_COMPANY;
  460. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  461. $user->ADM_PHONE = $r->ADM_PHONE;
  462. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  463. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  464. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  465. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  466. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  467. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  468. return $user;
  469. }
  470. }
  471. return $user;
  472. }
  473. public static function loginByDB($login, $pass) {
  474. $db = DB::getDB();
  475. $login = $db->_($login);
  476. $pass = $db->_($pass);
  477. $sql = "SELECT u.*
  478. from `ADMIN_USERS` as u
  479. where
  480. u.`ADM_ACCOUNT`='{$login}'
  481. and ( u.`ADM_PASSWD`='{$pass}' or u.`ADM_PASSWD`=md5('{$pass}') )
  482. and u.`A_STATUS` in('WAITING','NORMAL')
  483. LIMIT 0, 1;
  484. ";
  485. $res = $db->query($sql);
  486. if (!$res) {
  487. throw new Exception("Wystąpiły błędy podczas próby logowania. Błąd bazy danych.");
  488. }
  489. $num_rows = $db->num_rows($res);
  490. if ($num_rows == 0) {
  491. throw new Exception("Proszę podać poprawny login i hasło!");
  492. }
  493. else if ($num_rows == 1) {
  494. if ($r = $db->fetch($res)) {
  495. $user = new stdClass();
  496. $user->ID = $r->ID;
  497. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  498. $user->ADM_COMPANY = $r->ADM_COMPANY;
  499. $user->AUTHORIZE_USER = $r->ADM_ACCOUNT;
  500. $user->ADM_ACCOUNT = $r->ADM_ACCOUNT;
  501. $user->ADM_NAME = $r->ADM_NAME;
  502. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  503. $user->ADM_PHONE = $r->ADM_PHONE;
  504. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  505. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  506. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  507. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  508. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  509. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  510. //$user->ADM_AREA = "$r->ADM_AREA";
  511. //$_SESSION['ADM_PASSWD'] = $pass;
  512. return $user;
  513. }
  514. }
  515. return false;
  516. }
  517. public static function kandydatLoginByDB($kandydatId, &$errors) {
  518. $db = DB::getDB();
  519. $kandydatId = (int)$kandydatId;
  520. $sql = "SELECT u.*
  521. from `ADMIN_USERS` as u
  522. where
  523. u.`ID`='{$kandydatId}'
  524. and u.`A_STATUS` in('WAITING','NORMAL')
  525. LIMIT 0, 1;
  526. ";
  527. $res = $db->query($sql);
  528. if (!$res) {
  529. die("Error SQL login!");
  530. }
  531. $num_rows = $db->num_rows($res);
  532. if ($num_rows == 0) {
  533. $errors[] = "Podales zlego uzytkownika lub/i haslo()";
  534. }
  535. else if ($num_rows == 1) {
  536. if ($r = $db->fetch($res)) {
  537. $user = new stdClass();
  538. $user->ID = $r->ID;
  539. $user->ADM_TECH_WORKER = $r->ADM_TECH_WORKER;
  540. $user->ADM_COMPANY = $r->ADM_COMPANY;
  541. $user->AUTHORIZE_USER = $r->ADM_ACCOUNT;
  542. $user->ADM_ACCOUNT = $r->ADM_ACCOUNT;
  543. $user->ADM_NAME = $r->ADM_NAME;
  544. $user->ADM_ADMIN_LEVEL = $r->ADM_ADMIN_LEVEL;
  545. $user->ADM_PHONE = $r->ADM_PHONE;
  546. $user->ADM_ADMIN_EXPIRE = $r->ADM_ADMIN_EXPIRE;
  547. $user->ADM_ADMIN_DESC = $r->ADM_ADMIN_DESC;
  548. $user->EMAIL_IMAP_IMPORT_PASSWD = $r->EMAIL_IMAP_IMPORT_PASSWD;
  549. $user->EMAIL_IMAP_IMPORT_HOST = $r->EMAIL_IMAP_IMPORT_HOST;
  550. $user->EMAIL_IMAP_IMPORT_USERNAME = $r->EMAIL_IMAP_IMPORT_USERNAME;
  551. $user->EMPLOYEE_TYPE = $r->EMPLOYEE_TYPE;
  552. //$user->ADM_AREA = "$r->ADM_AREA";
  553. //$_SESSION['ADM_PASSWD'] = $pass;
  554. return $user;
  555. }
  556. }
  557. return false;
  558. }
  559. public static function changePasswd($oldPass, $newPass) {
  560. $db = DB::getDB();
  561. $newPass = $db->_($newPass);
  562. $oldPass = $db->_($oldPass);
  563. $username = $db->_(self::getName());
  564. $sql = "update `ADMIN_USERS` set
  565. `ADM_PASSWD`=md5('{$newPass}')
  566. where
  567. `ADM_ACCOUNT`='{$username}' and
  568. (`ADM_PASSWD`='{$oldPass}' or `ADM_PASSWD`=md5('{$oldPass}'))
  569. limit 1;
  570. ";
  571. $db->query($sql);
  572. return ($db->affected_rows() > 0);
  573. }
  574. /**
  575. * Check user access.
  576. * @param string $name
  577. * 'menu' - access to view menu
  578. *
  579. * @from [4101] ADM_ADMIN_LEVEL
  580. * Poziom uprawnień - każdy powinien mieć poziom o numerze 3
  581. * kierownicy powinni mieć 2
  582. * a administratorzy 0
  583. * kandydaci poziom 6.
  584. * Poziom 1 umożliwia edycje procesów i zasobów
  585. * poziom 2 umożliwia ocenę testów
  586. * poziom 3 umożliwia widzenie systemu jakości.
  587. */
  588. public static function hasAccess($name) {
  589. switch ($name) {
  590. case 'menu': {
  591. if (User::get('ADM_ADMIN_LEVEL') < 6) {
  592. return true;
  593. }
  594. else {
  595. Lib::loadClass('Config');
  596. $ALLOW_GUEST_ACCOUNT = (int)Config::get('ALLOW_GUEST_ACCOUNT');
  597. if ($ALLOW_GUEST_ACCOUNT && User::getLogin() == 'anonymous') {
  598. return true;
  599. }
  600. }
  601. break;
  602. }
  603. case 'dbg': {
  604. return (0 == User::get('ADM_ADMIN_LEVEL'));
  605. break;
  606. }
  607. case 'procesy': {
  608. if (User::get('ADM_ADMIN_LEVEL') < 4) return true;
  609. break;
  610. }
  611. case 'procesy_admin': {
  612. if (User::get('ADM_ADMIN_LEVEL') < 2) return true;
  613. break;
  614. }
  615. case 'testy': {
  616. if (User::get('ADM_ADMIN_LEVEL') <= 6) return true;
  617. break;
  618. }
  619. case 'testy_wyniki': {
  620. if (User::get('ADM_ADMIN_LEVEL') < 3) return true;
  621. break;
  622. }
  623. case 'testy_wyniki_edit': {
  624. if (User::get('ADM_ADMIN_LEVEL') < 3) return true;
  625. break;
  626. }
  627. case 'testy_wyniki_read': {
  628. if (User::get('ADM_ADMIN_LEVEL') < 3) return true;
  629. break;
  630. }
  631. case 'user_add_group': {
  632. if (User::get('ADM_ADMIN_LEVEL') < 1) return true;
  633. break;
  634. }
  635. default:
  636. }
  637. return false;
  638. }
  639. public static function hasAccessToEditTable($tableName) {
  640. if (empty($tableName)) return;
  641. $userAcl = User::getAcl();
  642. $userAcl->fetchGroups();
  643. Lib::loadClass('ProcesHelper');
  644. $zasobID = ProcesHelper::getZasobTableID($tableName);
  645. if (!$userAcl->hasTableAcl($zasobID)) {
  646. return false;
  647. }
  648. $tblAcl = $userAcl->getTableAcl($zasobID);
  649. if (empty($tblAcl)) {
  650. echo "Brak dostępu do tabeli nr {$zasobID} '{$tableName}'"; return;
  651. //throw new Exception("Brak dostępu do tabeli nr {$zasobID} '{$tableName}'");
  652. }
  653. $tblAcl->init();
  654. return $tblAcl->hasEditPerms();
  655. }
  656. public static function hasGroup($groupName) {
  657. // TODO: find group by name @see self::getGroups() @used in SchemaReaderProcess
  658. return false;
  659. }
  660. public static function getAnonymousAccount() {
  661. $db = DB::getDB();
  662. if (!$db) die("Error DB connection!");
  663. $sql = "select u.*
  664. from `ADMIN_USERS` as u
  665. where
  666. u.`ADM_ACCOUNT`='anonymous'
  667. and u.`EMPLOYEE_TYPE`='Anonymous'
  668. and u.`A_STATUS` in('NORMAL')
  669. order by u.`ID` asc
  670. limit 1
  671. ";
  672. $res = $db->query($sql);
  673. if (!$res) die("Error SQL login!");
  674. $num_rows = $db->num_rows($res);
  675. if ($r = $db->fetch($res)) {
  676. //$_SESSION['ADM_PASSWD'] = $pass;
  677. $user = new stdClass();
  678. $user->ID = "$r->ID";
  679. $user->AUTHORIZE_USER = "$r->ADM_ACCOUNT";
  680. $user->ADM_ACCOUNT = "$r->ADM_ACCOUNT";
  681. $user->ADM_PASSWD = "$r->ADM_PASSWD";
  682. //$user->ADM_AREA = "$r->ADM_AREA";
  683. $user->ADM_NAME = "$r->ADM_NAME";
  684. $user->ADM_TECH_WORKER = "$r->ADM_TECH_WORKER";
  685. $user->ADM_COMPANY = "$r->ADM_COMPANY";
  686. $user->ADM_ADMIN_LEVEL = "$r->ADM_ADMIN_LEVEL";
  687. $user->ADM_PHONE = "$r->ADM_PHONE";
  688. $user->ADM_ADMIN_EXPIRE = "$r->ADM_ADMIN_EXPIRE";
  689. $user->ADM_ADMIN_DESC = "$r->ADM_ADMIN_DESC";
  690. return $user;
  691. }
  692. return false;
  693. }
  694. public static function getLdapGroups() {
  695. $ldapGroups = User::_fetchLdapGroups();
  696. return $ldapGroups;
  697. }
  698. public static function getLdapGroupsNames() {
  699. $ldapGroupsNames = array();
  700. $ldapGroups = User::_fetchLdapGroups();
  701. foreach ($ldapGroups as $kID => $vLDAPGroup) {
  702. $ldapGroupsNames[$kID] = $vLDAPGroup->cn;
  703. }
  704. return $ldapGroupsNames;
  705. }
  706. public static function getLdapGroupsIds() {
  707. $ldapGroups = User::_fetchLdapGroups();
  708. $gidNumbers = array();
  709. if (!empty($ldapGroups)) {
  710. foreach ($ldapGroups as $vLdapGroup) {
  711. $gidNumbers[] = $vLdapGroup->gidNumber;
  712. }
  713. }
  714. return $gidNumbers;
  715. }
  716. public static function _fetchLdapGroups() {
  717. static $_groups;
  718. if (!$_groups) {
  719. $login = User::getLogin();
  720. Lib::loadClass('UsersLdapHelper');
  721. $_groups = UsersLdapHelper::getUserGroups($login, 3);
  722. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">getLDAPGroupByUserName (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($_groups);echo'</pre>';
  723. }
  724. return $_groups;
  725. }
  726. }