From a9830b06509dcf19582c78454d035bef52200483 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Thu, 5 Mar 2009 15:20:34 +0000 Subject: [PATCH] "fixing high minimize memory usage (important for huge number of accounts)" --- phpgwapi/inc/class.accounts_sql.inc.php | 73 +++++++++++++------------ 1 file changed, 38 insertions(+), 35 deletions(-) diff --git a/phpgwapi/inc/class.accounts_sql.inc.php b/phpgwapi/inc/class.accounts_sql.inc.php index 365219c1e9..c249ddbfde 100644 --- a/phpgwapi/inc/class.accounts_sql.inc.php +++ b/phpgwapi/inc/class.accounts_sql.inc.php @@ -1,22 +1,22 @@ complete rewrite in 6/2006 and * earlier to use the new DB functions - * - * This class replaces the former accounts_sql class written by - * Joseph Engo , Dan Kuykendall + * + * This class replaces the former accounts_sql class written by + * Joseph Engo , Dan Kuykendall * and Bettina Gille . * Copyright (C) 2000 - 2002 Joseph Engo * Copyright (C) 2003 Lars Kneschke, Bettina Gille - * + * * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License * @package api * @subpackage accounts @@ -25,7 +25,7 @@ /** * SQL Backend for accounts - * + * * @author Ralf Becker * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License * @package api @@ -51,7 +51,7 @@ class accounts_sql * * @var string */ - var $contacts_table = 'egw_addressbook'; + var $contacts_table = 'egw_addressbook'; /** * Join with the accounts-table used in contacts::search * @@ -94,7 +94,7 @@ class accounts_sql /** * Reads the data of one account - * + * * For performance reasons and because the contacts-object itself depends on the accounts-object, * we directly join with the contacts table for reading! * @@ -104,7 +104,7 @@ class accounts_sql function read($account_id) { if (!(int)$account_id) return false; - + $join = $extra_cols = ''; if ($account_id > 0) { @@ -145,7 +145,7 @@ class accounts_sql /** * Saves / adds the data of one account - * + * * If no account_id is set in data the account is added and the new id is set in $data. * * @param array $data array with account-data @@ -156,12 +156,12 @@ class accounts_sql //echo "

accounts_sql::save(".print_r($data,true).")

\n"; $to_write = $data; unset($to_write['account_passwd']); - + // encrypt password if given or unset it if not if ($data['account_passwd']) { // if password it's not already entcrypted, do so now - if (!preg_match('/^\\{[a-z5]{3,5}\\}.+/i',$data['account_passwd']) && + if (!preg_match('/^\\{[a-z5]{3,5}\\}.+/i',$data['account_passwd']) && !preg_match('/^[0-9a-f]{32}$/',$data['account_passwd'])) // md5 hash { $data['account_passwd'] = $GLOBALS['egw']->auth->encrypt_sql($data['account_passwd']); @@ -180,7 +180,7 @@ class accounts_sql if (!in_array($to_write['account_type'],array('u','g')) || !$this->db->insert($this->table,$to_write,false,__LINE__,__FILE__)) return false; - + if (!(int)$data['account_id']) { $data['account_id'] = $this->db->get_last_insert_id($this->table,'account_id'); @@ -197,7 +197,7 @@ class accounts_sql } return $data['account_id']; } - + /** * Delete one account, deletes also all acl-entries for that account * @@ -207,7 +207,7 @@ class accounts_sql function delete($account_id) { if (!(int)$account_id) return false; - + $contact_id = $this->id2name($account_id,'person_id'); if (!$this->db->delete($this->table,array('account_id' => abs($account_id)),__LINE__,__FILE__)) @@ -252,7 +252,7 @@ class accounts_sql function set_memberships($groups,$account_id) { if (!(int)$account_id) return; - + $acl =& CreateObject('phpgwapi.acl',$account_id); $acl->read_repository(); $acl->delete('phpgw_group',false); @@ -287,7 +287,7 @@ class accounts_sql /** * Set the members of a group - * + * * @param array $members array with uidnumber or uid's * @param int $gid gidnumber of group to set */ @@ -295,7 +295,7 @@ class accounts_sql { //echo "

accounts::set_members(".print_r($members,true).",$gid)

\n"; $GLOBALS['egw']->acl->delete_repository('phpgw_group',$gid,false); - + if (is_array($members)) { foreach($members as $id) @@ -307,11 +307,11 @@ class accounts_sql /** * Searches users and/or groups - * + * * ToDo: implement a search like accounts::search * * @param string $_type='both', 'accounts', 'groups' - * @param int $start=null + * @param int $start=null * @param string $sort='' ASC or DESC * @param string $order='' * @param string $query='' @@ -329,7 +329,7 @@ class accounts_sql ); if (isset($order2contact[$order])) $order = $order2contact[$order]; if ($sort) $order .= ' '.$sort; - + switch($_type) { case 'accounts': @@ -378,13 +378,16 @@ class accounts_sql break; } } - $accounts = array(); + if (!is_object($GLOBALS['egw']->contacts)) throw new exception('No $GLOBALS[egw]->contacts!'); - if (($contacts =& $GLOBALS['egw']->contacts->search($criteria,false,$order,"account_lid,account_type,account_status,$this->table.account_id", + + $accounts = array(); + foreach((array) $GLOBALS['egw']->contacts->search($criteria,"1,n_given,n_family,email,id,created,modified,$this->table.account_id AS account_id", + $order,"account_lid,account_type,account_status", $wildcard,false,'OR',$offset ? array($start,$offset) : is_null($start) ? false : $start, - $filter,$this->contacts_join))) + $filter,$this->contacts_join) as $contact) { - foreach($contacts as $contact) + if ($contact) { $accounts[] = array( 'account_id' => ($contact['account_type'] == 'g' ? -1 : 1) * $contact['account_id'], @@ -411,7 +414,7 @@ class accounts_sql * Please note: * - if a group and an user have the same account_lid the group will be returned (LDAP only) * - if multiple user have the same email address, the returned user is undefined - * + * * @param string $name value to convert * @param string $which='account_lid' type of $name: account_lid (default), account_email, person_id, account_fullname * @param string $account_type u = user, g = group, default null = try both @@ -436,7 +439,7 @@ class accounts_sql case 'person_id': $table = $this->contacts_table; $where['contact_id'] = $name; - break; + break; default: $table = $this->table; $cols .= ',account_type'; @@ -448,16 +451,16 @@ class accounts_sql } else { - $where[] = 'account_id IS NOT NULL'; // otherwise contacts with eg. the same email hide the accounts! + $where[] = 'account_id IS NOT NULL'; // otherwise contacts with eg. the same email hide the accounts! } if (!($row = $this->db->select($table,$cols,$where,__LINE__,__FILE__)->fetch())) return false; - + return ($row['account_type'] == 'g' ? -1 : 1) * $row['account_id']; } - + /** * Convert an numeric account_id to any other value of that account (account_lid, account_email, ...) - * + * * Uses the read method to fetch all data. * * @param int $account_id numerica account_id @@ -486,7 +489,7 @@ class accounts_sql ),array( 'account_id' => abs($account_id), ),__LINE__,__FILE__); - + return $previous_login; } }