ldap_next_reference_basic.phpt 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. --TEST--
  2. ldap_next_reference() - Basic ldap_next_reference test
  3. --CREDITS--
  4. Patrick Allaert <patrickallaert@php.net>
  5. # Belgian PHP Testfest 2009
  6. --SKIPIF--
  7. <?php require_once('skipif.inc'); ?>
  8. <?php require_once('skipifbindfailure.inc'); ?>
  9. --FILE--
  10. <?php
  11. require "connect.inc";
  12. $link = ldap_connect_and_bind($host, $port, $user, $passwd, $protocol_version);
  13. insert_dummy_data($link, $base);
  14. ldap_add($link, "cn=userref,$base", array(
  15. "objectClass" => array("extensibleObject", "referral"),
  16. "cn" => "userref",
  17. "ref" => "cn=userA,$base",
  18. ));
  19. ldap_add($link, "cn=userref2,$base", array(
  20. "objectClass" => array("extensibleObject", "referral"),
  21. "cn" => "userref2",
  22. "ref" => "cn=userB,$base",
  23. ));
  24. ldap_set_option($link, LDAP_OPT_DEREF, LDAP_DEREF_NEVER);
  25. $result = ldap_search($link, "$base", "(cn=*)");
  26. $ref = ldap_first_reference($link, $result);
  27. var_dump($ref2 = ldap_next_reference($link, $ref));
  28. ldap_parse_reference($link, $ref2, $refs);
  29. var_dump($refs);
  30. ?>
  31. ===DONE===
  32. --CLEAN--
  33. <?php
  34. include "connect.inc";
  35. $link = ldap_connect_and_bind($host, $port, $user, $passwd, $protocol_version);
  36. // Referral can only be removed with Manage DSA IT Control
  37. ldap_delete($link, "cn=userref,$base", [['oid' => LDAP_CONTROL_MANAGEDSAIT, 'iscritical' => TRUE]]);
  38. ldap_delete($link, "cn=userref2,$base", [['oid' => LDAP_CONTROL_MANAGEDSAIT, 'iscritical' => TRUE]]);
  39. remove_dummy_data($link, $base);
  40. ?>
  41. --EXPECTF--
  42. resource(%d) of type (ldap result entry)
  43. array(1) {
  44. [0]=>
  45. string(%d) "cn=userB,%s"
  46. }
  47. ===DONE===