Updated somewhat for all ldap using custom attrs

This commit is contained in:
Miles Lott 2001-05-09 13:01:46 +00:00
parent 6a09bbe3f3
commit c9d36a283d

View File

@ -112,15 +112,13 @@
$this->data["homedirectory"] = $allValues[0]["homedirectory"][0]; $this->data["homedirectory"] = $allValues[0]["homedirectory"][0];
$this->data["loginshell"] = $allValues[0]["loginshell"][0]; $this->data["loginshell"] = $allValues[0]["loginshell"][0];
} }
$this->db->query("select * from phpgw_accounts where account_id='" . $this->data["account_id"] . "'",__LINE__,__FILE__);
$this->db->next_record();
$this->data["lastlogin"] = $this->db->f("account_lastlogin"); $this->data['lastlogin'] = $allValues[0]['phpgwlastlogin'][0];
$this->data["lastloginfrom"] = $this->db->f("account_lastloginfrom"); $this->data['lastloginfrom'] = $allValues[0]['phpgwlastloginfrom'][0];
$this->data["lastpasswd_change"] = $this->db->f("account_lastpwd_change"); $this->data['lastpasswd_change'] = $allValues[0]['phpgwlastpasswdchange'][0];
$this->data["status"] = $this->db->f("account_status"); $this->data['status'] = $allValues[0]['phpgwaccountstatus'][0];
$this->data["account_type"] = $this->db->f("account_type"); $this->data['type'] = $allValues[0]['phpgwaccounttype'][0];
$this->data['expires'] = -1; $this->data['expires'] = $allValues[0]['phpgwexpires'][0];
return $this->data; return $this->data;
} }
@ -143,9 +141,15 @@
} }
$allValues = ldap_get_entries($ds, $sri); $allValues = ldap_get_entries($ds, $sri);
$entry["cn"] = sprintf("%s %s", $this->data["firstname"], $this->data["lastname"]); $entry['cn'] = sprintf("%s %s", $this->data['firstname'], $this->data['lastname']);
$entry["sn"] = $this->data["lastname"]; $entry['sn'] = $this->data['lastname'];
$entry["givenname"] = $this->data["firstname"]; $entry['givenname'] = $this->data['firstname'];
$entry['phpgwlastlogin'] = $this->data['lastlogin'];
$entry['phpgwlastloginfrom'] = $this->data['lastloginfrom'];
$entry['phpgwlastpasswdchange'] = $this->data['lastpasswd_change'];
$entry['phpgwaccountstatus'] = $this->data['status'];
$entry['phpgwaccounttype'] = $this->data['type'];
$entry['phpgwexpires'] = $this->data['expires'];
if ($phpgw_info["server"]["ldap_extra_attributes"]) if ($phpgw_info["server"]["ldap_extra_attributes"])
{ {
@ -294,12 +298,6 @@
} }
} }
} }
$this->db->query("UPDATE phpgw_accounts SET account_lid='" . $this->data['account_lid']
. "', account_firstname='" . $this->data['firstname']
. "', account_lastname='" . $this->data['lastname']
. "', account_status='" . $this->data['status']
. "' where account_id='" . $this->account_id . "'",__LINE__,__FILE__);
} }
function isin_array($needle,$haystack=array()) function isin_array($needle,$haystack=array())
@ -563,41 +561,43 @@
$this->acct_type = $account_type; $this->acct_type = $account_type;
//echo '<br>in create for account_lid: "'.$account_lid.'"'; //echo '<br>in create for account_lid: "'.$account_lid.'"';
if (empty($account_id) || !$account_id) if (empty($account_info['id']) || !$account_info['id'])
{ {
$account_id = $this->get_nextid(); $account_id = $this->get_nextid();
//echo '<br>using'.$account_id;exit; //echo '<br>using'.$account_id;exit;
} }
$entry['userpasswd'] = $account_info['passwd'];
$this->db->query("insert into phpgw_accounts (account_id, account_lid, account_type, account_pwd, " $entry['phpgwlastlogin'] = $account_info['lastlogin'];
. "account_firstname, account_lastname, account_status) values ('" . $account_id . "','" . $account_lid $entry['phpgwlastloginfrom'] = $account_info['lastloginfrom'];
. "','" . $account_type . "','" . md5($account_pwd) . "', '" . $account_firstname $entry['phpgwlastpasswdchange'] = $account_info['lastpasswd_change'];
. "','" . $account_lastname . "','" . $account_status . "')",__LINE__,__FILE__); $entry['phpgwaccountstatus'] = $account_info['status'];
$entry['phpgwaccounttype'] = $account_info['type'];
$entry['phpgwexpires'] = $account_info['expires'];
if ($account_type == "g") if ($account_type == "g")
{ {
$sri = ldap_search($ds, $phpgw_info["server"]["ldap_group_context"], "cn=$account_lid"); $sri = ldap_search($ds, $phpgw_info["server"]["ldap_group_context"], "cn=" . $account_info['lid']);
} }
else else
{ {
$sri = ldap_search($ds, $phpgw_info["server"]["ldap_context"], "uid=$account_lid"); $sri = ldap_search($ds, $phpgw_info["server"]["ldap_context"], "uid=" . $account_info['lid']);
} }
$allValues = ldap_get_entries($ds, $sri); $allValues = ldap_get_entries($ds, $sri);
if ($phpgw_info["server"]["ldap_extra_attributes"] && $account_type != 'g') if ($phpgw_info["server"]["ldap_extra_attributes"] && $account_info['account_type'] != 'g')
{ {
if ($account_home) if ($account_home)
{ {
$entry["homedirectory"] = $account_home; $entry["homedirectory"] = $account_info['homedirectory'];
} }
else else
{ {
$entry["homedirectory"] = $phpgw_info["server"]["ldap_account_home"].SEP.$account_lid; $entry["homedirectory"] = $phpgw_info["server"]["ldap_account_home"].SEP.$account_info['lid'];
} }
if ($account_shell) if ($account_shell)
{ {
$entry["loginshell"] = $account_shell; $entry["loginshell"] = $account_info['loginshell'];
} }
else else
{ {
@ -643,10 +643,16 @@
$tmpentry["objectclass"][1] = 'person'; $tmpentry["objectclass"][1] = 'person';
$tmpentry["objectclass"][2] = 'organizationalPerson'; $tmpentry["objectclass"][2] = 'organizationalPerson';
$tmpentry["objectclass"][3] = 'inetOrgPerson'; $tmpentry["objectclass"][3] = 'inetOrgPerson';
$tmpentry["userpassword"] = $phpgw->common->encrypt_password($account_pwd); $tmpentry["userpassword"] = $phpgw->common->encrypt_password($account_info['passwd']);
//$tmpentry["objectclass"][4] = 'account'; Causes problems with some LDAP servers //$tmpentry["objectclass"][4] = 'account'; Causes problems with some LDAP servers
$tmpentry["objectclass"][5] = 'posixAccount'; $tmpentry["objectclass"][5] = 'posixAccount';
$tmpentry["objectclass"][6] = 'shadowAccount'; $tmpentry["objectclass"][6] = 'shadowAccount';
$tmpentry['phpgwlastlogin'] = $account_info['lastlogin'];
$tmpentry['phpgwlastloginfrom'] = $account_info['lastloginfrom'];
$tmpentry['phpgwlastpasswdchange'] = $account_info['lastpasswd_change'];
$tmpentry['phpgwaccountstatus'] = $account_info['status'];
$tmpentry['phpgwaccounttype'] = $account_info['account_type'];
$tmpentry['phpgwexpires'] = $account_info['expires'];
} }
ldap_modify($ds, $allValues[0]["dn"], $tmpentry); ldap_modify($ds, $allValues[0]["dn"], $tmpentry);
} }
@ -660,18 +666,18 @@
unset($entry["loginshell"]); unset($entry["loginshell"]);
$entry["objectclass"][0] = 'top'; $entry["objectclass"][0] = 'top';
$entry["objectclass"][1] = 'posixGroup'; $entry["objectclass"][1] = 'posixGroup';
$entry["cn"] = $account_lid; $entry["cn"] = $account_info['lid'];
$entry["gidnumber"] = $account_id; $entry["gidnumber"] = $account_id;
$entry["userpassword"] = $phpgw->common->encrypt_password($account_pwd); $entry["userpassword"] = $phpgw->common->encrypt_password($account_info['passwd']);
$entry["description"] = 'phpgw-created group'; $entry["description"] = 'phpgw-created group';
} }
else else
{ {
$dn = 'uid=' . $account_lid . ',' . $phpgw_info["server"]["ldap_context"]; $dn = 'uid=' . $account_lid . ',' . $phpgw_info["server"]["ldap_context"];
$entry["cn"] = sprintf("%s %s", $account_firstname, $account_lastname); $entry["cn"] = sprintf("%s %s", $account_firstname, $account_lastname);
$entry["sn"] = $account_lastname; $entry["sn"] = $account_info['lastname'];
$entry["givenname"] = $account_firstname; $entry["givenname"] = $account_info['firstname'];
$entry["uid"] = $account_lid; $entry["uid"] = $account_info['lid'];
$entry["uidnumber"] = $account_id; $entry["uidnumber"] = $account_id;
if ($phpgw_info["server"]["ldap_group_id"]) if ($phpgw_info["server"]["ldap_group_id"])
{ {
@ -681,7 +687,7 @@
{ {
$entry["gidnumber"] = $account_id; $entry["gidnumber"] = $account_id;
} }
$entry["userpassword"] = $phpgw->common->encrypt_password($account_pwd); $entry["userpassword"] = $phpgw->common->encrypt_password($account_info['passwd']);
$entry["objectclass"][0] = 'top'; $entry["objectclass"][0] = 'top';
$entry["objectclass"][1] = 'person'; $entry["objectclass"][1] = 'person';
$entry["objectclass"][2] = 'organizationalPerson'; $entry["objectclass"][2] = 'organizationalPerson';