Zend_LdapZend_Ldap ist das Basisinterface zum LDAP Server.
Es bietet Verbindungs- und Bindungsmethode sowie Methoden um auf dem LDAP
Baum zu arbeiten.
Zend_Ldap APIMethodeBeschreibungstring filterEscape(string $str)
Escapt einen Wert damit dieser in einem LDAP Filter
entsprechend RFC 2254. Diese Methode ist
deprecated, stattdessen sollte
Zend_Ldap_Dn::checkDn() verwendet werden.
boolean explodeDn($dn, array &$keys = null, array &$vals =
null)
Prüft ob ein angegebener DN $dn fehlerhaft ist. Wenn
$keys oder $keys und
$vals angegeben werden, werden diese Arrays mit den
entsprechenden DN Schlüsseln und Werten gefüllt. Diese Methode ist
deprecated, stattdessen sollte
Zend_Ldap_Dn::checkDn() verwendet werden.
__construct($options)
Constructor. Der $options Parameter ist Optional und kann
ein Array, oder eine Instanz von Zend_Config sein.
Wenn keine Optionen bei der Instanzierung angegeben werden, müssen die
Verbindungsparameter der Instanz übergeben werden indem man
Zend_Ldap::setOptions() verwendet. Die erlaubten
Optionen werden in Zend_Ldap Optionen
apezifiziert.
resource getResource()
Gibt die rohe Ressource der LDAP Erweiterung (ext/ldap)
zurück.
integer getLastErrorCode()
Gibt die LDAP Fehlernummer des letzten
LDAP Kommandos zurück.
string getLastError(integer &$errorCode, array
&$errorMessages)
Gibt die LDAP Fehlermeldung des letzten
LDAP Kommandos zurück. Der optionale
$errorCode Parameter ist auf die LDAP
Fehlernummer gesetzt wenn er angegeben ist. Die verschiedenen
LDAP Funktionen welche Fehler zurückgeben können
unterschiedliche Dinge zurückgeben, sodas Sie alle gesammelt werden wenn
$errorMessages angegeben ist.
Zend_Ldap setOptions($options)
Setzt die LDAP Verbindungs- und Bindungsparameter.
$options kann ein Array oder eine Instanz von
Zend_Config sein. Die erlauben Optionen werden in
Zend_Ldap Optionen
definiert.
array getOptions()Gibt die aktuellen Verbindungs- und Bindungsparameter zurück.string getBaseDn()
Gibt den Basis DN zurück auf welche diese LDAP Verbindung
gebunden ist.
string getCanonicalAccountName(string $acctname, integer $form)
Gibt den kanonischen Account Namen des angegebenen Account Namens
$acctname zurück. $form spezifiziert
das Format
in das der Account Name kanonisiert wird. Siehe Kanonisierung
des Account Namens für weitere Details.
Zend_Ldap disconnect()
Trennt die Verbindung der Zend_Ldap Instanz vom
LDAP Server.
Zend_Ldap connect(string $host, integer $port, boolean $useSsl,
boolean $useStartTls)
Verbindet eine Instanz von Zend_Ldap mit dem
angegebenen LDAP Server. Alle Parameter sind optional,
und werden von den LDAP Verbindungs- und
Bindungsparametern genommen welche der Instanz über den Constructor oder
über Zend_Ldap::setOptions() angegeben wurden, wenn
NULL angegeben wurde.
Zend_Ldap bind(string $username, string $password)
Authentifiziert $username mit
$password beim LDAP Server. Wenn
beide Parameter nicht angegeben werden, dann wird die Verbindung mit den
Anmeldeinformationen durchgeführt welche in den Verbindungs- und
Bindungsparametern angegeben wurden, und ein anonymes Binden wird
ausgeführt. Es ist zu beachten dass hierbei anonymes Binden vom
LDAP Server erlaubt sein muss. Ein leerer String
'' kann als $password zusammen mit einem
Benutzernamen übergeben werden wenn, und nur wenn,
allowEmptyPassword in den Verdinguns- und Bindungsparametern
auf TRUE gesetzt ist.
Zend_Ldap_Collection search(string|Zend_Ldap_Filter_Abstract $filter,
string|Zend_Ldap_Dn $basedn, integer $scope, array $attributes, string
$sort, string $collectionClass)
Durchsucht den LDAP Baum mit dem angegebenen
$filter und den angegebenen Such Parametern.
string|Zend_Ldap_Filter_Abstract $filter
Der Filterstring kann in der Suche verwendet werden, z.B.
(objectClass=posixAccount).
string|Zend_Ldap_Dn $basedn
Die Suchbasis für die Suche. Wenn Sie nicht, oder
NULL angegeben wird, dann wird die
baseDn der Verbindungs- und Bindungs Parameter
verwendet.
integer $scope
Der Suchbereich.
Zend_Ldap::SEARCH_SCOPE_SUB durchsucht
den kompletten Unterbaum inklusive dem
$baseDn Node.
Zend_Ldap::SEARCH_SCOPE_ONE schränkt
die Suche auf ein Level unter $baseDn
ein. Zend_Ldap::SEARCH_SCOPE_BASE
schränkt die Suche auf $baseDn selbst
ein; das kann verwendet werden um effizient einen einzelnen
Eintrag durch deinen DN zu erhalten. Der Standardwert ist
Zend_Ldap::SEARCH_SCOPE_SUB.
array $attributes
Spezifiziert die Attribute welche in den zurückgegebenen
Einträgen enthalten sind. Um alle möglichen Attribute zu
inkludieren (ACL Restriktionen können es verhindern das
bestimmte Attribute von einem angegebenen Benutzer empfangen
werden) kann entweder ein leeres Array
array() oder
array('*') an die Methode übergeben werden.
Bei einigen LDAP Servern kann man
spezielle interne Attribute erhalten wenn man an die Methode
array('*', '+') übergibt.
string $sort
Ob die Sammlung der Ergebnisse nach dem Attribut
$sort sortiert werden soll. Ergebnisse
können nur nach einem einzelnen Attribut sortiert werden,
da dieser Parameter die ext/ldap Funktion
ldap_sort() verwendet.
string $collectionClass
Ob das Ergebnis in ein Objekt vom Typ
$collectionClass eingebettet werden soll.
Standardmäßig wird ein Objekt vom Typ
Zend_Ldap_Collection zurückgegeben.
Die eigene Klasse muß
Zend_Ldap_Collection erweitern und
wird bei der Instanziierung ein
Zend_Ldap_Collection_Iterator_Default
übergeben.
integer count(string|Zend_Ldap_Filter_Abstract
$filter, string|Zend_Ldap_Dn $basedn, integer $scope)
Zählt die Elemente welche durch die angegebenen Such Parameter zurückgegeben
werden. Siehe Zend_Ldap::search() für eine
detailierte Beschreibung der Parameter der Methode.
integer countChildren(string|Zend_Ldap_Dn $dn)
Zählt die direkten Abhängigkeiten (Kinder) des Eintrags, der durch den
angegebenen $dn identifiziert wird.
boolean exists(string|Zend_Ldap_Dn $dn)
Prüft ob der Eintrag, der durch den angegebenen $dn
identifiziert wird, existiert.
array searchEntries(string|Zend_Ldap_Filter_Abstract
$filter, string|Zend_Ldap_Dn $basedn, integer $scope, array
$attributes, string $sort)
Führt eine Such Operation durch und gibt als Ergebnis ein
PHP Array zurück. Das ist notwendigerweise die gleiche
Methode wie Zend_Ldap::search() ausser beim
Rückgabe Typ. Siehe Zend_Ldap::search() für eine
detailierte Beschreibung der Parameter der Methode.
array getEntry(string|Zend_Ldap_Dn $dn, array
$attributes, boolean $throwOnNotFound)
Gibt den LDAP Eintrag zurück der von
$dn mit den in $attributes angegebenen
Attributen identifiziert wird. Wenn $attributes
unterdrückt wird (array()) werden alle Attribute im
Ergebnis ausgegeben. $throwOnNotFound ist standardmäßig
FALSE, so dass die Methode NULL
zurückgibt wemm der spezifizierte Eintrag nicht gefunden wird. Wenn er auf
TRUE gesetzt ist, wird statt dessen eine
Zend_Ldap_Exception geworfen.
void prepareLdapEntryArray(array
&$entry)
Bereitet ein Array für die Verwendung in Modifikations Operationen von
LDAP vor. Diese Methode muß nicht von Endbenutzern
aufgerufen werden da Sie implizit bei jeder Methode die Daten verändert
aufgerufen wird.
Zend_Ldap add(string|Zend_Ldap_Dn $dn, array $entry)
Fügt den Eintrag der durch $dn mit seinen
$entry identifiziert wird im LDAP
Baum hinzu. Wirft eine Zend_Ldap_Exception wenn der
Eintrag nicht hinzugefügt werden konnte.
Zend_Ldap update(string|Zend_Ldap_Dn $dn, array $entry)
Aktualisiert den Eintrag der durch $dn mit seinen
$entry Attributen identifiziert wird im
LDAP Baum. Wirft eine
Zend_Ldap_Exception wenn der Eintrag nicht geändert
werden konnte.
Zend_Ldap save(string|Zend_Ldap_Dn $dn, array $entry)
Speichert den Eintrag der durch $dn mit seinen
$entry Attributen identifiziert wird im
LDAP Baum. Wirft eine
Zend_Ldap_Exception wenn der Eintrag nicht
gespeichert werden konnte. Diese Methode wählt durch eine Suche im
LDAP Baum ob der Eintrag hinzugefügt oder aktualisiert
wird.
Zend_Ldap delete(string|Zend_Ldap_Dn $dn, boolean $recursively)
Löscht den Eintrag der durch $dn identifiziert wird vom
LDAP Baum. Wirft eine
Zend_Ldap_Exception Exception wenn der Eintrag nicht
gelöscht werden kann. $recursively ist standardmäßig
FALSE. Auf TRUE gesetzt wird
das Löschen rekursiv durchgeführt und löscht effektiver Weise den kompletten
Unterbaum. Das Löschen wird fehlschlagen wenn
$recursivelyFALSE ist und der
$dn Eintrag kein Blatteintrag ist.
Zend_Ldap moveToSubtree(string|Zend_Ldap_Dn $from, string|Zend_Ldap_Dn
$to, boolean $recursively, boolean $alwaysEmulate)
Verschiebt den Eintrag der von $from identifiziert wird
auf einen Ort nach $to wobei sein RDN
unverändert bleibt. $recursively spezifiziert ob die
Operation rekursiv ausgeführt wird (standardmäßig
FALSE) so dass der Eintrag $from und
alle seine Untereinträge verschoben werden. Das Verschieben wird
fehlschlagen wenn $recursivelyFALSE
ist und der Eintrag $from kein Blatteintrag ist.
$alwaysEmulate kontrolliert ob die ext/ldap Funktion
ldap_rename() verwendet werden soll wenn Sie
vorhanden ist. Das kann nur für Blatteinträge funktionieren und für Server
und für ext/ldap die diese Funktion unterstützen. Auf
TRUE gesetzt wird immer eine emulierte Rename Operation
verwendet.
Alle Verschiebe-Operationen werden ausgeführt indem die
betreffenden Einträge im LDAP Baum kopiert und
anschließend gelöscht werden. Diese Operationen sind nicht
atomar so dass Fehler während der Operation zu
einem inkonsistenten Status am
LDAP Server führen. Das selbe gilt auch für alle
rekursiven Operationen. Auch diese sind in keiner Weise atomar. Man
sollte das immer beachten.
Zend_Ldap move(string|Zend_Ldap_Dn $from, string|Zend_Ldap_Dn $to,
boolean $recursively, boolean $alwaysEmulate)
Das ist ein Alias für Zend_Ldap::rename().
Zend_Ldap rename(string|Zend_Ldap_Dn $from, string|Zend_Ldap_Dn $to,
boolean $recursively, boolean $alwaysEmulate)
Benennt den Eintrag der von $from bis
$to identifiziert wird um.
$recursively spezifiziert ob die Operation rekursiv
durchgeführt werden soll (standardmäßig FALSE) so das
der Eintrag $from und alle seine Abhängigkeiten
verschoben werden. Das Umbenennen wird fehlschlagen wenn
$recursivelyFALSE ist und der
Eintrag $from kein Blatteintrag ist.
$alwaysEmulate kontrolliert ob die ext/ldap Funktion
ldap_rename() verwendet werden soll wenn Sie
vorhanden ist. Das kann nur für Blatteinträge und für Server funktionieren
und für ext/ldap welches diese Funktion unterstützt. Wird es auf
TRUE gesetzt wird immer die emulierte rename
Operation verwendet.
Zend_Ldap copyToSubtree(string|Zend_Ldap_Dn $from,
string|Zend_Ldap_Dn $to, boolean $recursively)
Kopiert den Eintrag der von $from bis zu einem Ort
unterhalb von $to identifiziert wird und lässt dessen
RDN unverändert. $recursively
spezifiziert ob die Operation rekursiv durchgeführt werden soll
(standardmäßig FALSE) so das der Eintrag
$from und alle seine Abhängigkeiten kopiert werden.
Das Kopieren wird fehlschlagen wenn $recursivelyFALSE ist und der Eintrag $from
kein Blatteintrag ist.
Zend_Ldap copy(string|Zend_Ldap_Dn $from,
string|Zend_Ldap_Dn $to, boolean $recursively)
Kopiert den Eintrag der von $from bis
$to identifiziert wird. $recursively
spezifiziert ob die Operation rekursiv durchgeführt werden soll
(standardmäßig FALSE) so das der Eintrag
$from und alle seine Abhängigkeiten kopiert werden.
Das Kopieren wird fehlschlagen wenn $recursivelyFALSE ist und der Eintrag $from
kein Blatteintrag ist.
Zend_Ldap_Node getNode(string|Zend_Ldap_Dn $dn)
Gibt den $dn Eintrag zurück der in einem
Zend_Ldap_Node gewrappt ist.
Zend_Ldap_Node getBaseNode()
Gibt den Eintrag für den Basis DN $baseDn zurück
der in einer Zend_Ldap_Node gewrappt ist.
Zend_Ldap_Node_RootDse getRootDse()Gibt den RootDSE für den aktuellen Server zurück.Zend_Ldap_Node_Schema getSchema()
Gibt das LDAP Schema für den aktuellen Server zurück.
Zend_Ldap_CollectionZend_Ldap_Collection implementiert Iterator um
das Durchlaufen von Einträgen zu erlauben indem foreach() und
Countable verwendet werden welche in der Lage sind auf
count() zu Antworten. Mit seiner geschützten
_createEntry() Methode bietet es einen einfachen Punkt der
Erweiterung für Entwickler welche die Notwendigkeit für eigene Ergebnisobjekte haben.
API für Zend_Ldap_CollectionMethodeBeschreibung__construct(Zend_Ldap_Collection_Iterator_Interface
$iterator)
Constructor. Der Constructor muß von einem
Zend_Ldap_Collection_Iterator_Interface angeboten
werden welches die echte Iteration der Resultate durchführt.
Zend_Ldap_Collection_Iterator_Default ist die
standardmäßige Implementation für die Interation durch ext/ldap
Ergebnisse.
boolean close()
Schließt den internen Iterator. Wird auch im Destructor aufgerufen.
array toArray()Gibt alle Einträge als Array zurück.array getFirst()
Gibt den ersten Eintrag der Collection zurück, oder
NULL wenn die Collection leer ist.