User.php 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace Typemill\Models;
  3. class User extends WriteYaml
  4. {
  5. public function getUsers()
  6. {
  7. $userDir = __DIR__ . '/../../settings/users';
  8. /* check if plugins directory exists */
  9. if(!is_dir($userDir)){ return array(); }
  10. /* get all plugins folder */
  11. $users = array_diff(scandir($userDir), array('..', '.'));
  12. $cleanUser = array();
  13. foreach($users as $key => $user)
  14. {
  15. if($user == '.logins'){ continue; }
  16. $cleanUser[] = str_replace('.yaml', '', $user);
  17. }
  18. return $cleanUser;
  19. }
  20. public function getUser($username)
  21. {
  22. $user = $this->getYaml('settings/users', $username . '.yaml');
  23. return $user;
  24. }
  25. public function createUser($params)
  26. {
  27. $userdata = array(
  28. 'username' => $params['username'],
  29. 'email' => $params['email'],
  30. 'password' => $this->generatePassword($params['password']),
  31. 'userrole' => $params['userrole']
  32. );
  33. if($this->updateYaml('settings/users', $userdata['username'] . '.yaml', $userdata))
  34. {
  35. return $userdata['username'];
  36. }
  37. return false;
  38. }
  39. public function updateUser($params)
  40. {
  41. $userdata = $this->getUser($params['username']);
  42. if(isset($params['password']))
  43. {
  44. $params['password'] = $this->generatePassword($params['password']);
  45. }
  46. $update = array_merge($userdata, $params);
  47. $this->updateYaml('settings/users', $userdata['username'] . '.yaml', $update);
  48. return $userdata['username'];
  49. }
  50. public function deleteUser($username)
  51. {
  52. if($this->getUser($username))
  53. {
  54. unlink('settings/users/' . $username . '.yaml');
  55. }
  56. }
  57. public function getUserroles()
  58. {
  59. return array('administrator', 'editor');
  60. }
  61. public function login($username)
  62. {
  63. $user = $this->getUser($username);
  64. if($user)
  65. {
  66. $user['lastlogin'] = time();
  67. unset($user['password']);
  68. $this->updateUser($user);
  69. $_SESSION['user'] = $user['username'];
  70. $_SESSION['role'] = $user['userrole'];
  71. $_SESSION['login'] = $user['lastlogin'];
  72. }
  73. }
  74. public function generatePassword($password)
  75. {
  76. return \password_hash($password, PASSWORD_DEFAULT, ['cost' => 10]);
  77. }
  78. }