db->query("SELECT uid FROM " . TABLE_USER . " WHERE username=?", array($username)); if(isset($query->row['uid'])){ return $query->row['uid']; } return -1; } public function get_uid_by_email($email = '') { $query = $this->db->query("SELECT uid FROM " . TABLE_EMAIL . " WHERE email=?", array($email)); if(isset($query->row['uid'])){ return $query->row['uid']; } return -1; } public function get_username_by_email($email = '') { $query = $this->db->query("SELECT username FROM " . TABLE_USER . ", " . TABLE_EMAIL . " WHERE " . TABLE_USER . ".uid=" . TABLE_EMAIL . ".uid AND email=?", array($email)); if(isset($query->row['username'])){ return $query->row['username']; } return ""; } public function get_users_all_email_addresses($uid = 0, $gid = 0) { $data = array(); $uids = $uid; if($uid > 0) { $query = $this->db->query("SELECT gid FROM " . TABLE_EMAIL_LIST . " WHERE uid=?", array((int)$uid)); if(isset($query->rows)) { foreach ($query->rows as $q) { if(is_numeric($q['gid']) && $q['gid'] > 0) { $uids .= "," . $q['gid']; } } } $query = $this->db->query("SELECT email FROM " . TABLE_EMAIL . " WHERE uid IN ($uids)"); foreach ($query->rows as $q) { array_push($data, $q['email']); } } $query = $this->db->query("SELECT `" . TABLE_GROUP_EMAIL . "`.email FROM `" . TABLE_GROUP_EMAIL . "`, `" . TABLE_GROUP_USER . "` WHERE `" . TABLE_GROUP_EMAIL . "`.id=`" . TABLE_GROUP_USER . "`.id and `" . TABLE_GROUP_USER . "`.uid=?", array($uid) ); if(isset($query->rows)) { foreach ($query->rows as $q) { if(!in_array($email, $data)) { array_push($data, $q['email']); } } } return $data; } public function get_additional_uids($uid = 0) { $data = array(); if($uid > 0) { $query = $this->db->query("SELECT gid FROM " . TABLE_EMAIL_LIST . " WHERE uid=?", array((int)$uid)); if(isset($query->rows)) { foreach ($query->rows as $q) { array_push($data, $q['gid']); } } } return $data; } public function get_emails($username = '') { $emails = ""; $query = $this->db->query("SELECT " . TABLE_EMAIL . ".email AS email FROM " . TABLE_EMAIL . "," . TABLE_USER . " WHERE " . TABLE_EMAIL . ".uid=" . TABLE_USER . ".uid AND " . TABLE_USER . ".username=?", array($username)); foreach ($query->rows as $q) { $emails .= $q['email'] . "\n"; } return preg_replace("/\n$/", "", $emails); } public function get_emails_by_uid($uid = 0) { $emails = ""; $query = $this->db->query("SELECT email FROM " . TABLE_EMAIL . " WHERE uid=?", array((int)$uid)); foreach ($query->rows as $q) { $emails .= $q['email'] . "\n"; } return preg_replace("/\n$/", "", $emails); } public function get_user_by_dn($dn = '') { if($dn == '') { return array(); } $query = $this->db->query("SELECT * FROM " . TABLE_USER . " WHERE dn=?", array($dn)); if($query->num_rows == 1) { return $query->row; } return array(); } public function get_user_by_uid($uid = 0) { if(!is_numeric($uid) || (int)$uid < 0){ return array(); } $query = $this->db->query("SELECT * FROM " . TABLE_USER . " WHERE uid=?", array((int)$uid)); return $query->row; } public function get_user_by_email($email = '') { if($email == '') { return array(); } $query = $this->db->query("SELECT * FROM " . TABLE_USER . "," . TABLE_EMAIL . " WHERE " . TABLE_USER . ".uid=" . TABLE_EMAIL . ".uid AND email=?", array($email)); return $query->row; } public function get_users($search = '', $page = 0, $page_len = 0, $sort = 'username', $order = 0) { $where_cond = " WHERE " . TABLE_USER . ".uid=" . TABLE_EMAIL . ".uid "; $_order = ""; $users = array(); $my_domain = array(); $limit = ""; $from = (int)$page * (int)$page_len; $search = preg_replace("/\s{1,}/", "", $search); if($search){ $where_cond .= " AND email like '%" . $this->db->escape($search) . "%' "; } /* sort order */ if($order == 0) { $order = "ASC"; } else { $order = "DESC"; } $_order = "ORDER BY $sort $order"; if($page_len > 0) { $limit = " LIMIT " . (int)$from . ", " . (int)$page_len; } $query = $this->db->query("SELECT " . TABLE_USER . ".uid, isadmin, username, realname, domain, email FROM " . TABLE_USER . "," . TABLE_EMAIL . " $where_cond group by " . TABLE_USER . ".uid $_order $limit"); foreach ($query->rows as $q) { if(Registry::get('admin_user') == 1 || (isset($q['domain']) && $q['domain'] == $my_domain[0]) ) { $users[] = array( 'uid' => $q['uid'], 'username' => $q['username'], 'realname' => $q['realname'], 'domain' => isset($q['domain']) ? $q['domain'] : "", 'email' => $q['email'], 'isadmin' => $q['isadmin'] ); } } return $users; } public function count_users($search = '') { $where_cond = ""; if($search){ $where_cond .= " WHERE email like '%" . $this->db->escape($search) . "%' "; } $query = $this->db->query("SELECT COUNT(*) AS num, uid FROM " . TABLE_EMAIL . " $where_cond group by uid"); return $query->num_rows; } public function get_domains() { $data = array(); $query = $this->db->query("SELECT DISTINCT mapped AS domain FROM " . TABLE_DOMAIN); foreach ($query->rows as $q) { array_push($data, $q['domain']); } return $data; } public function get_email_domains() { $data = array(); $query = $this->db->query("SELECT domain FROM " . TABLE_DOMAIN); foreach ($query->rows as $q) { array_push($data, $q['domain']); } return $data; } public function get_next_uid() { $query = $this->db->query("SELECT MAX(uid) AS last_id FROM " . TABLE_USER); if(isset($query->row['last_id']) && $query->row['last_id'] > 0) { return (int)$query->row['last_id'] + 1; } return 1; } public function add_user($user) { LOGGER("add user: " . $user['username'] . ", uid=" . (int)$user['uid']); if(!isset($user['domain']) || $user['domain'] == "") { return -1; } if(!isset($user['username']) || $user['username'] == "" || $this->get_uid_by_name($user['username']) > 0) { return -1; } $emails = explode("\n", $user['email']); foreach ($emails as $email) { $email = rtrim($email); $query = $this->db->query("SELECT COUNT(*) AS count FROM " . TABLE_EMAIL . " WHERE email=?", array($email)); /* remove from memcached */ if(MEMCACHED_ENABLED) { $memcache = Registry::get('memcache'); $memcache->delete(MEMCACHED_PREFIX . $email); } if($query->row['count'] > 0) { return $email; } } $query = $this->db->query("SELECT COUNT(*) AS count FROM " . TABLE_USER . " WHERE username=?", array($user['username'])); if($query->row['count'] > 0) { return $user['username']; } $encrypted_password = crypt($user['password']); $query = $this->db->query("INSERT INTO " . TABLE_USER . " (uid, username, realname, password, domain, dn, isadmin) VALUES(?,?,?,?,?,?,?)", array((int)$user['uid'], $user['username'], $user['realname'], $encrypted_password, $user['domain'], @$user['dn'], (int)$user['isadmin'])); if($query->error == 1 || $this->db->countAffected() == 0){ return $user['username']; } foreach ($emails as $email) { $email = rtrim($email); $ret = $this->add_email((int)$user['uid'], $email); if($ret == 0) { return -2; } } $this->update_group_settings((int)$user['uid'], $user['group']); return 1; } public function add_email($uid = 0, $email = '') { if($uid < 1 || $email == ""){ return 0; } $query = $this->db->query("INSERT INTO " . TABLE_EMAIL . " (uid, email) VALUES(?,?)", array((int)$uid, $email)); $rc = $this->db->countAffected(); LOGGER("add email: $email, uid=$uid (rc=$rc)"); return $rc; } public function remove_email($uid = 0, $email = '') { if((int)$uid < 1 || $email == ""){ return 0; } $query = $this->db->query("DELETE FROM " . TABLE_EMAIL . " WHERE uid=? AND email=?", array((int)$uid, $email)); $rc = $this->db->countAffected(); LOGGER("remove email: $email, uid=$uid (rc=$rc)"); return $rc; } public function update_user($user) { LOGGER("update user: " . $user['username'] . ", uid=" . (int)$user['uid']); $emails = explode("\n", $user['email']); foreach ($emails as $email) { $email = rtrim($email); $query = $this->db->query("SELECT COUNT(*) AS count FROM " . TABLE_EMAIL . " WHERE uid!=? AND email=?", array((int)$user['uid'], $email)); if($query->row['count'] > 0) { return $email; } } /* update password field if we have to */ if(strlen($user['password']) >= MIN_PASSWORD_LENGTH) { $query = $this->db->query("UPDATE " . TABLE_USER . " SET password=? WHERE uid=?", array(crypt($user['password']), (int)$user['uid'])); if($this->db->countAffected() != 1) { return 0; } } $query = $this->db->query("UPDATE " . TABLE_USER . " SET username=?, realname=?, domain=?, dn=?, isadmin=? WHERE uid=?", array($user['username'], $user['realname'], $user['domain'], @$user['dn'], $user['isadmin'], (int)$user['uid'])); /* first, remove all his email addresses */ $query = $this->db->query("DELETE FROM " . TABLE_EMAIL . " WHERE uid=?", array((int)$user['uid'])); /* then add all the emails we have from the CGI post input */ foreach ($emails as $email) { $email = rtrim($email); $query = $this->db->query("INSERT INTO " . TABLE_EMAIL . " (uid, email) VALUES(?,?)", array((int)$user['uid'], $email)); /* remove from memcached */ if(MEMCACHED_ENABLED) { $memcache = Registry::get('memcache'); $memcache->delete(MEMCACHED_PREFIX . $email); } } $this->update_group_settings((int)$user['uid'], $user['group']); return 1; } private function update_group_settings($uid = -1, $group = '') { $__g = array(); if($uid <= 0 || $group == '') { return 0; } $query = $this->db->query("DELETE FROM `" . TABLE_GROUP_USER . "` WHERE uid=?", array($uid)); $query = $this->db->query("SELECT id, groupname FROM `" . TABLE_GROUP . "`"); $groups = array(); foreach ($query->rows as $q) { $groups[$q['groupname']] = $q['id']; } $group = explode("\n", $group); foreach($group as $g) { $g = rtrim($g); if(!isset($__g[$groups[$g]])) { $query = $this->db->query("INSERT INTO `" . TABLE_GROUP_USER . "` (id, uid) VALUES(?,?)", array($groups[$g], (int)$uid)); $__g[$groups[$g]] = 1; } } return 1; } public function delete_user($uid) { if(!$this->check_uid($uid)){ return 0; } $query = $this->db->query("DELETE FROM " . TABLE_EMAIL . " WHERE uid=?", array((int)$uid)); $query = $this->db->query("DELETE FROM " . TABLE_USER . " WHERE uid=?", array((int)$uid)); LOGGER("remove user: uid=$uid"); return 1; } } ?>