forked from extern/egroupware
fix for negative group-ids, which are not allowed by all dbms in auto-columns:
- egw_accounts.account_id is now again positiv for groups too - mapping to negative group-id is done in the accounts-class now
This commit is contained in:
parent
b5197ce79d
commit
68828494ab
@ -26,7 +26,7 @@
|
||||
/* $Id$ */
|
||||
|
||||
/**
|
||||
* Class for handling user and group accounts
|
||||
* Class for handling user and group accounts in SQL
|
||||
*/
|
||||
class accounts_
|
||||
{
|
||||
@ -38,15 +38,6 @@
|
||||
|
||||
function accounts_()
|
||||
{
|
||||
if (is_object($GLOBALS['egw_setup']))
|
||||
{
|
||||
$this->db = clone($GLOBALS['egw_setup']->db);
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->db = clone($GLOBALS['egw']->db);
|
||||
}
|
||||
$this->db->set_app('phpgwapi'); // to load the right table-definitions for insert, select, update, ...
|
||||
}
|
||||
|
||||
function list_methods($_type='xmlrpc')
|
||||
@ -88,12 +79,10 @@
|
||||
*/
|
||||
function read_repository()
|
||||
{
|
||||
$this->db->select($this->table,'*',array('account_id'=>$this->account_id),__LINE__,__FILE__);
|
||||
$this->db->next_record();
|
||||
$this->db->select($this->table,'*',array('account_id'=>abs($this->account_id)),__LINE__,__FILE__);
|
||||
|
||||
$this->data['userid'] = $this->db->f('account_lid');
|
||||
$this->data['account_id'] = $this->db->f('account_id');
|
||||
$this->data['account_lid'] = $this->db->f('account_lid');
|
||||
$this->data['account_id'] = $this->db->next_record() ? $this->account_id : null;
|
||||
$this->data['account_lid'] = $this->data['userid'] = $this->db->f('account_lid');
|
||||
$this->data['firstname'] = $this->db->f('account_firstname');
|
||||
$this->data['lastname'] = $this->db->f('account_lastname');
|
||||
$this->data['fullname'] = $this->db->f('account_firstname') . ' ' . $this->db->f('account_lastname');
|
||||
@ -125,7 +114,7 @@
|
||||
'account_primary_group' => $this->data['account_primary_group'],
|
||||
'account_email' => $this->data['email'],
|
||||
),array(
|
||||
'account_id' => $this->account_id
|
||||
'account_id' => abs($this->account_id)
|
||||
),__LINE__,__FILE__);
|
||||
}
|
||||
|
||||
@ -135,7 +124,7 @@
|
||||
|
||||
/* Do this last since we are depending upon this record to get the account_lid above */
|
||||
$this->db->lock(Array($this->table));
|
||||
$this->db->delete($this->table,array('account_id'=>$account_id),__LINE__,__FILE__);
|
||||
$this->db->delete($this->table,array('account_id'=>abs($account_id)),__LINE__,__FILE__);
|
||||
$this->db->unlock();
|
||||
}
|
||||
|
||||
@ -216,7 +205,7 @@
|
||||
while ($this->db->next_record())
|
||||
{
|
||||
$accounts[] = Array(
|
||||
'account_id' => $this->db->f('account_id'),
|
||||
'account_id' => ($this->db->f('account_type') == 'g' ? -1 : 1) * $this->db->f('account_id'),
|
||||
'account_lid' => $this->db->f('account_lid'),
|
||||
'account_type' => $this->db->f('account_type'),
|
||||
'account_firstname' => $this->db->f('account_firstname'),
|
||||
@ -239,10 +228,10 @@
|
||||
*/
|
||||
function name2id($name,$which='account_lid')
|
||||
{
|
||||
$this->db->select($this->table,'account_id',array($which=>$name),__LINE__,__FILE__);
|
||||
$this->db->select($this->table,'account_id,account_type',array($which=>$name),__LINE__,__FILE__);
|
||||
if($this->db->next_record())
|
||||
{
|
||||
return (int)$this->db->f('account_id');
|
||||
return ($this->db->f('account_type') == 'g' ? -1 : 1) * $this->db->f('account_id');
|
||||
}
|
||||
return False;
|
||||
}
|
||||
@ -252,7 +241,7 @@
|
||||
*/
|
||||
function id2name($account_id,$which='account_lid')
|
||||
{
|
||||
$this->db->select($this->table,$this->db->name_quote($which),array('account_id'=>$account_id),__LINE__,__FILE__);
|
||||
$this->db->select($this->table,$this->db->name_quote($which),array('account_id'=>abs($account_id)),__LINE__,__FILE__);
|
||||
if($this->db->next_record())
|
||||
{
|
||||
return $this->db->f(0);
|
||||
@ -271,7 +260,7 @@
|
||||
{
|
||||
return $by_id[$account_lid];
|
||||
}
|
||||
$where['account_id'] = $account_lid;
|
||||
$where['account_id'] = abs($account_lid);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -315,7 +304,7 @@
|
||||
if (isset($account_info['account_id']) && (int)$account_info['account_id'] && !$this->id2name($account_info['account_id']))
|
||||
{
|
||||
// only use account_id, if it's not already used
|
||||
$account_data['account_id'] = $account_info['account_id'];
|
||||
$account_data['account_id'] = abs($account_info['account_id']);
|
||||
}
|
||||
$this->db->insert($this->table,$account_data,False,__LINE__,__FILE__);
|
||||
|
||||
@ -323,12 +312,7 @@
|
||||
|
||||
if ($account_info['account_type'] == 'g' && $id > 0) // create negative id for groups
|
||||
{
|
||||
if ($this->db->Type == 'mssql')
|
||||
{
|
||||
$this->db->query("SET identity_update $this->table ON",__LINE__,__FILE__);
|
||||
}
|
||||
$this->db->update($this->table,array('account_id' => -$id),array('account_id' => $id),__LINE__,__FILE__);
|
||||
return -$id;
|
||||
$id = -$id;
|
||||
}
|
||||
return $id;
|
||||
}
|
||||
@ -452,7 +436,7 @@
|
||||
|
||||
function get_account_name($accountid,&$lid,&$fname,&$lname)
|
||||
{
|
||||
$this->db->select($this->table,'account_lid,account_firstname,account_lastname',array('account_id'=>$accountid),__LINE__,__FILE__);
|
||||
$this->db->select($this->table,'account_lid,account_firstname,account_lastname',array('account_id'=>abs($accountid)),__LINE__,__FILE__);
|
||||
if (!$this->db->next_record())
|
||||
{
|
||||
return False;
|
||||
@ -473,14 +457,14 @@
|
||||
*/
|
||||
function update_lastlogin($account_id, $ip)
|
||||
{
|
||||
$this->db->select($this->table,'account_lastlogin',array('account_id'=>$account_id),__LINE__,__FILE__);
|
||||
$this->db->select($this->table,'account_lastlogin',array('account_id'=>abs($account_id)),__LINE__,__FILE__);
|
||||
$previous_login = $this->db->next_record() ? $this->db->f('account_lastlogin') : false;
|
||||
|
||||
$this->db->update($this->table,array(
|
||||
'account_lastloginfrom' => $ip,
|
||||
'account_lastlogin' => time(),
|
||||
),array(
|
||||
'account_id' => $account_id,
|
||||
'account_id' => abs($account_id),
|
||||
),__LINE__,__FILE__);
|
||||
|
||||
return $previous_login;
|
||||
|
@ -14,7 +14,7 @@
|
||||
/* Basic information about this app */
|
||||
$setup_info['phpgwapi']['name'] = 'phpgwapi';
|
||||
$setup_info['phpgwapi']['title'] = 'eGroupWare API';
|
||||
$setup_info['phpgwapi']['version'] = '1.2.001';
|
||||
$setup_info['phpgwapi']['version'] = '1.2.002';
|
||||
$setup_info['phpgwapi']['versions']['current_header'] = '1.28';
|
||||
$setup_info['phpgwapi']['enable'] = 3;
|
||||
$setup_info['phpgwapi']['app_order'] = 1;
|
||||
|
@ -912,8 +912,9 @@
|
||||
$test[] = '1.0.1.029';
|
||||
function phpgwapi_upgrade1_0_1_029()
|
||||
{
|
||||
// convert all positive group id's to negative ones
|
||||
// convert all positive group id's to negative ones, since 1.2.002 except the account_id itself
|
||||
// this allows duplicate id for users and groups in ldap
|
||||
// This update include the next 2 updates and goes direct to version 1.2.002!
|
||||
$GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->config_table,'config_value',array(
|
||||
'config_name' => 'account_repository',
|
||||
'config_app' => 'phpgwapi',
|
||||
@ -946,7 +947,6 @@
|
||||
foreach(array(
|
||||
array('egw_acl','acl_location'),
|
||||
array('egw_acl','acl_account'),
|
||||
array('egw_accounts','account_id',"account_type='g'"),
|
||||
array('egw_accounts','account_primary_group',"account_type='u'"),
|
||||
array('egw_cal_user','cal_user_id',"cal_user_type='u'"),
|
||||
array('egw_wiki_pages','wiki_readable',true),
|
||||
@ -979,7 +979,7 @@
|
||||
//echo "<p>$query</p>\n";
|
||||
$GLOBALS['egw_setup']->db->query($query,__LINE__,__FILE__);
|
||||
}
|
||||
return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.001';
|
||||
return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.002';
|
||||
}
|
||||
|
||||
|
||||
@ -1045,3 +1045,16 @@
|
||||
}
|
||||
return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.001';
|
||||
}
|
||||
|
||||
$test[] = '1.2.001';
|
||||
function phpgwapi_upgrade1_2_001()
|
||||
{
|
||||
// convert groupid's in egw_accounts back to positive, as not all DBMS can deal with neg. id's
|
||||
if ($GLOBALS['egw_setup']->db->Type == 'mssql')
|
||||
{
|
||||
$GLOBALS['egw_setup']->db->query("SET identity_update egw_accounts ON",__LINE__,__FILE__);
|
||||
}
|
||||
$GLOBALS['egw_setup']->db->query("UPDATE egw_accounts SET account_id=-account_id WHERE account_type='g' AND account_id < 0",__LINE__,__FILE__);
|
||||
|
||||
return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.002';
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user