egroupware/admin/inc/accounts_ldap.inc.php

116 lines
3.6 KiB
PHP
Raw Normal View History

<?php
/**************************************************************************\
* phpGroupWare - administration *
* http://www.phpgroupware.org *
* -------------------------------------------- *
* This program is free software; you can redistribute it and/or modify it *
* under the terms of the GNU General Public License as published by the *
* Free Software Foundation; either version 2 of the License, or (at your *
* option) any later version. *
\**************************************************************************/
/* $Id$ */
// Sections of code where taking from slapda http://www.jeremias.net/projects/sldapa by
// Jason Jeremias <jason@jeremias.net>
$ldap = ldap_connect($phpgw_info["server"]["ldap_host"]);
if (! ldap_bind($ldap, $phpgw_info["server"]["ldap_root_dn"], $phpgw_info["server"]["ldap_root_pw"])) {
echo "<p><b>Error binding to LDAP server. Check your config</b>";
exit;
}
function account_read($method,$start,$sort,$order)
{
}
function account_add($account_info)
{
global $phpgw_info, $ldap;
2000-10-20 07:51:27 +02:00
if ($phpgw_info["server"]["ldap_encryption_type"] == "DES") {
$salt = randomstring(2);
$userpassword = descryptpass($account_info["passwd"], $salt);
}
if ($phpgw_info["server"]["ldap_encryption_type"] == "MD5") {
$salt = randomstring(9);
$userpassword = md5cryptpass($account_info["passwd"], $salt);
}
// Create our entry
$entry["uid"] = $uid;
$entry["uidNumber"] = $uidnumber;
$entry["gidNumber"] = $gidnumber;
$entry["userpassword"] = $userpassword;
$entry["loginShell"] = $ushell;
$entry["homeDirectory"] = $homedir;
$entry["cn"] = sprintf("%s %s", $givenname, $sn);
$entry["sn"] = $sn;
$entry["givenname"] = $givenname;
$entry["company"] = $company;
$entry["title"] = $title;
$entry["mail"] = $mail;
$entry["telephonenumber"] = $telephonenumber;
$entry["homephone"] = $homephone;
$entry["pagerphone"] = $pagerphone;
$entry["cellphone"] = $cellphone;
$entry["streetaddress"] = $streetaddress;
$entry["locality"] = $locality;
$entry["st"] = $st;
$entry["postalcode"] = $postalcode;
$entry["countryname"] = $countryname;
$entry["homeurl"] = $homeurl;
$entry["description"] = $description;
$entry["objectclass"][0] = "account";
$entry["objectclass"][1] = "posixAccount";
$entry["objectclass"][2] = "shadowAccount";
$entry["objectclass"][3] = "inetOrgperson";
$entry["objectclass"][4] = "person;
$entry["objectclass"][5] = "top";
/* $dn=sprintf("cn=%s %s, %s", $givenname, $sn, $BASEDN);*/
$dn=sprintf("uid=%s, %s", $uid, $BASEDN);
// add the entries
if (ldap_add($ldap, $dn, $entry)) {
$cd = 28;
} else {
$cd = 99; // Come out with a code for this
}
@ldap_close($ldap);
return $cd;
}
function account_edit($account_info)
{
}
function account_delete($account_id)
{
global $ldap;
$searchline = getSearchLine($searchstring);
$result = ldap_search($ldap, $BASEDN, $searchline);
$entry = ldap_get_entries($ldap, $result);
$numentries = $entry["count"];
@ldap_delete($ldap, $button);
}
function account_exsists($loginid)
{
}
function account_close()
{
@ldap_close($ldap);
}