2012-02-08 23:14:28 +01:00
< ? php
class ModelUserUser extends Model {
2012-06-22 15:22:02 +02:00
public function check_uid ( $uid ) {
2012-02-08 23:14:28 +01:00
if ( $uid == " " ) { return 0 ; }
if ( ! is_numeric ( $uid )) { return 0 ; }
if ( $uid < 1 ) { return 0 ; }
return 1 ;
}
2012-06-22 15:22:02 +02:00
public function get_uid_by_name ( $username = '' ) {
2012-02-08 23:14:28 +01:00
if ( $username == " " ){ return - 1 ; }
$query = $this -> 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 " " ;
}
2012-06-22 12:30:55 +02:00
public function get_users_all_email_addresses ( $uid = 0 , $gid = 0 ) {
2012-02-08 23:14:28 +01:00
$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' ]);
}
}
2012-06-22 12:30:55 +02:00
$query = $this -> db -> query ( " SELECT email FROM ` " . TABLE_GROUP_EMAIL . " ` WHERE id=? " , array ( $gid ));
if ( isset ( $query -> rows )) {
foreach ( $query -> rows as $q ) {
if ( ! in_array ( $email , $data )) { array_push ( $data , $q [ 'email' ]); }
}
}
2012-02-08 23:14:28 +01:00
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 ;
}
2012-06-22 15:22:02 +02:00
public function get_emails ( $username = '' ) {
2012-02-08 23:14:28 +01:00
$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 );
}
2012-06-22 15:22:02 +02:00
public function get_emails_by_uid ( $uid = 0 ) {
2012-02-08 23:14:28 +01:00
$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 );
}
2012-06-22 15:22:02 +02:00
public function get_user_by_dn ( $dn = '' ) {
2012-02-08 23:14:28 +01:00
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 ();
}
2012-06-22 12:30:55 +02:00
public function get_user_by_uid ( $uid = 0 ) {
2012-02-08 23:14:28 +01:00
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 ;
}
2012-06-22 15:22:02 +02:00
public function get_user_by_email ( $email = '' ) {
2012-02-08 23:14:28 +01:00
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 ;
}
2012-06-22 15:22:02 +02:00
public function get_users ( $search = '' , $page = 0 , $page_len = 0 , $sort = 'username' , $order = 0 ) {
2012-02-08 23:14:28 +01:00
$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 ; }
2012-06-22 12:30:55 +02:00
$query = $this -> db -> query ( " SELECT " . TABLE_USER . " .uid, gid, isadmin, username, realname, domain, email FROM " . TABLE_USER . " , " . TABLE_EMAIL . " $where_cond group by " . TABLE_USER . " .uid $_order $limit " );
2012-02-08 23:14:28 +01:00
foreach ( $query -> rows as $q ) {
if ( Registry :: get ( 'admin_user' ) == 1 || ( isset ( $q [ 'domain' ]) && $q [ 'domain' ] == $my_domain [ 0 ]) ) {
$users [] = array (
'uid' => $q [ 'uid' ],
2012-06-22 12:30:55 +02:00
'gid' => $q [ 'gid' ],
2012-02-08 23:14:28 +01:00
'username' => $q [ 'username' ],
'realname' => $q [ 'realname' ],
'domain' => isset ( $q [ 'domain' ]) ? $q [ 'domain' ] : " " ,
'email' => $q [ 'email' ],
'isadmin' => $q [ 'isadmin' ]
);
}
}
return $users ;
}
2012-06-22 15:22:02 +02:00
public function count_users ( $search = '' ) {
2012-02-08 23:14:28 +01:00
$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 ;
}
2012-06-22 15:22:02 +02:00
public function get_next_uid () {
2012-02-08 23:14:28 +01:00
$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 ;
}
2012-06-22 15:22:02 +02:00
public function add_user ( $user ) {
2012-02-08 23:14:28 +01:00
LOGGER ( " add user: " . $user [ 'username' ] . " , uid= " . ( int ) $user [ 'uid' ]);
if ( ! isset ( $user [ 'domain' ]) || $user [ 'domain' ] == " " ) { return - 1 ; }
2012-06-22 15:22:02 +02:00
if ( ! isset ( $user [ 'username' ]) || $user [ 'username' ] == " " || $this -> get_uid_by_name ( $user [ 'username' ]) > 0 ) { return - 1 ; }
2012-02-08 23:14:28 +01:00
$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' );
2012-02-10 14:35:07 +01:00
$memcache -> delete ( MEMCACHED_PREFIX . $email );
2012-02-08 23:14:28 +01:00
}
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' ]);
2012-06-22 12:30:55 +02:00
$query = $this -> db -> query ( " INSERT INTO " . TABLE_USER . " (uid, gid, username, realname, password, domain, dn, isadmin) VALUES(?,?,?,?,?,?,?,?) " , array (( int ) $user [ 'uid' ], ( int ) $user [ 'gid' ], $user [ 'username' ], $user [ 'realname' ], $encrypted_password , $user [ 'domain' ], @ $user [ 'dn' ], ( int ) $user [ 'isadmin' ]));
2012-02-08 23:14:28 +01:00
if ( $query -> error == 1 || $this -> db -> countAffected () == 0 ){ return $user [ 'username' ]; }
foreach ( $emails as $email ) {
$email = rtrim ( $email );
2012-06-22 15:22:02 +02:00
$ret = $this -> add_email (( int ) $user [ 'uid' ], $email );
2012-02-08 23:14:28 +01:00
if ( $ret == 0 ) { return - 2 ; }
}
return 1 ;
}
2012-06-22 15:22:02 +02:00
public function add_email ( $uid = 0 , $email = '' ) {
2012-02-08 23:14:28 +01:00
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 ;
}
2012-06-22 15:22:02 +02:00
public function remove_email ( $uid = 0 , $email = '' ) {
2012-02-08 23:14:28 +01:00
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 ;
}
2012-06-22 15:22:02 +02:00
public function update_user ( $user ) {
2012-02-08 23:14:28 +01:00
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 ; }
}
2012-06-22 12:30:55 +02:00
$query = $this -> db -> query ( " UPDATE " . TABLE_USER . " SET username=?, realname=?, domain=?, gid=?, dn=?, isadmin=? WHERE uid=? " , array ( $user [ 'username' ], $user [ 'realname' ], $user [ 'domain' ], $user [ 'gid' ], @ $user [ 'dn' ], $user [ 'isadmin' ], ( int ) $user [ 'uid' ]));
2012-02-08 23:14:28 +01:00
/* 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' );
2012-02-10 14:35:07 +01:00
$memcache -> delete ( MEMCACHED_PREFIX . $email );
2012-02-08 23:14:28 +01:00
}
}
return 1 ;
}
2012-06-22 15:22:02 +02:00
public function delete_user ( $uid ) {
if ( ! $this -> check_uid ( $uid )){ return 0 ; }
2012-02-08 23:14:28 +01:00
$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 ;
}
}
?>