query($q); $num = mysql_num_rows($ret); if ( $num == 1) { // OK $res = mysql_fetch_array($ret); $this->id = $res['id']; $this->userid = $res['userid']; $this->email = $res['email']; $this->firstname = $res['firstname']; $this->lastname = $res['lastname']; $this->homepage = $res['homepage']; $this->sex = $res['sex']; $this->language = $res['language']; } else { if ( $uid != -1 ) { $this->create($uid); } } } function getFullname() { return $this->firstname." ".$this->lastname; } function getFullnameDisplay() { $fn = $this->getFullname(); if ($fn == "" || $fn == NULL || strlen(trim($fn)) == 0 ){ return $this->username; } return $fn; } function setUsername($un) { $this->username = $un; } function getFirstname() { return $this->firstname; } function setFirstname($val) { $this->firstname = $val; } function getLastname() { return $this->lastname; } function setLastname($val) { $this->lastname = $val; } function getEmail() { return $this->email; } function setEmail($val) { $this->email = $val; } function getSex() { return $this->sex; } function setSex($val) { $this->sex = $val; } function getLanguage() { return $this->language; } function setLanguage($val) { $this->language = $val; } function getHomepage() { return $this->homepage; } function setHomepage($val) { $this->homepage = $val; } function update() { global $kdb; $q = "UPDATE psyhvel_userinfo SET "; $q .= " firstname='".$this->firstname."'"; $q .= ", lastname='".$this->lastname."'"; $q .= ", email='".$this->email."'"; $q .= ", sex='".$this->sex."'"; $q .= ", homepage='".$this->homepage."'"; $q .= ", language='".$this->language."'"; $q .= " WHERE id=".$this->id." AND userid=".$this->userid; $kdb->query($q); } private function create($uid) { global $kdb; $q = "INSERT INTO psyhvel_userinfo (userid, sex, language) values (".$uid.", '".$this->sex."', '".$this->language."')"; $kdb->query($q); } } class User { private $id = -1; private $username = "Anonymous"; private $details = null; private $groups = array(); private $roles = array( 'anonymous' => 1, 'authenticated' => 0, 'member' => 0, 'manager' => 0); function __construct($uname) { if ( !is_int($uname)) { global $kdb; $q = "SELECT * FROM psyhvel_users WHERE uname='".$uname."'"; $ret = $kdb->query($q); $num = mysql_num_rows($ret); if ( $num == 1) { // OK $res = mysql_fetch_array($ret); $this->id = $res['id']; $this->username = $res['uname']; $this->groups = $kdb->getGroupsByUserId($res['id']); $lro = $res['roles']; $this->roles['anonymous'] = 0; $this->roles['authenticated'] = intval($lro[0]); $this->roles['member'] = intval($lro[1]); $this->roles['manager'] = intval($lro[2]); } } elseif ( $uname != -1 && is_int($uname) ) { global $kdb; $q = "SELECT * FROM psyhvel_users WHERE id=".$uname; $ret = $kdb->query($q); $num = mysql_num_rows($ret); if ( $num == 1) { // OK $res = mysql_fetch_array($ret); $this->id = $res['id']; $this->username = $res['uname']; $this->groups = $kdb->getGroupsByUserId($res['id']); $lro = $res['roles']; $this->roles['anonymous'] = 0; $this->roles['authenticated'] = intval($lro[0]); $this->roles['member'] = intval($lro[1]); $this->roles['manager'] = intval($lro[2]); } } } function getUsername() { return $this->username; } function getRoles() { return $this->roles; } function getGroups() { return $this->groups; } function hasAnyRole($required) { global $psyhvel; $lstr = ""; foreach ( $required as $r) { $lstr .= " ".$r; } //$psyhvel->out("debug", "checking permissions, must have:".$lstr); if ( count($required) == 0) { return True; } else if ( count($required) == 1 && !$required[0] ) { return True; } foreach ($required as $r) { if ( array_key_exists($r, $this->roles) ) { if ( $this->roles[$r] == 1) { return True; } } } //$psyhvel->out("debug", "...failed"); return False; } function hasRole($role) { if ( $this->roles[$role] == 1) { return True; } return False; } function getDetails() { if ($this->details == null) { $ud = new UserDetails($this->id); $ud->setUsername($this->username); $this->details = $ud; } return $this->details; } function getId() { return $this->id; } function getUserIdByUname($uname) { global $kdb; $q = "SELECT id FROM psyhvel_users WHERE uname='".$uname."'"; $ret = $kdb->query($q); $num = mysql_num_rows($ret); if ( $num == 1) { // OK $res = mysql_fetch_array($ret); return $res['id']; } return -1; } function getUserById($usid) { global $kdb; $q = "SELECT * FROM psyhvel_users LEFT JOIN userinfo ON psyhvel_users.id=psyhvel_userinfo.userid WHERE psyhvel_users.id=".$usid; $ret = $kdb->query($q); $res = mysql_fetch_array($ret); return $res; } function getUsers() { global $kdb; return $kdb->query("SELECT *, concat(firstname, ' ', lastname) AS fullname FROM psyhvel_users LEFT JOIN psyhvel_userinfo ON psyhvel_users.id=psyhvel_userinfo.userid WHERE approved"); } } $user = new User(-1); if ( isset($_SESSION['userid'])) { $user = new User($_SESSION['userid']); if ( $user->getId() == -1) { session_destroy(); header("Location:index.php"); } } ?>