User.php 25 KB

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