mirror of
https://github.com/php/php-src.git
synced 2024-09-21 18:07:23 +00:00
69a8b63ecf
* Deprecate ldap_connect with two parameters ldap_connect should be called with an LDAP-URI as parameter and not with 2 parameters as that allows much more flexibility like differentiating between ldap and ldaps or setting multiple ldap-servers. This change requires one to add null as second parameter in case the underlying library is Oracle and one wants to add wallet-details. * Modify all ldap-tests to use ldap_connect right All tests are using ldap_connect now with an URI and not with host and port as two separarte parameters. * Verify deprecation of ldap_connect w/h 2 params This adds a test to verify that calling ldap_connect with 2 parameters triggers a deprecation notice * Remove empty test `ldap_control_paged_result()` is removed as of PHP 8.0.0, so this test needs to be removed as well. Co-authored-by: Christoph M. Becker <cmbecker69@gmx.de> Co-authored-by: Tim Düsterhus <timwolla@googlemail.com>
84 lines
1.9 KiB
PHP
84 lines
1.9 KiB
PHP
--TEST--
|
|
ldap_modify_batch() - Batch modify operations that should fail
|
|
--CREDITS--
|
|
Patrick Allaert <patrickallaert@php.net>
|
|
Ondřej Hošek <ondra.hosek@gmail.com>
|
|
--EXTENSIONS--
|
|
ldap
|
|
--SKIPIF--
|
|
<?php require_once('skipifbindfailure.inc'); ?>
|
|
--FILE--
|
|
<?php
|
|
require "connect.inc";
|
|
|
|
$link = ldap_connect_and_bind($uri, $user, $passwd, $protocol_version);
|
|
|
|
$addGivenName = array(
|
|
array(
|
|
"attrib" => "givenName",
|
|
"modtype" => LDAP_MODIFY_BATCH_ADD,
|
|
"values" => array("Jack")
|
|
)
|
|
);
|
|
|
|
// DN not found
|
|
var_dump(ldap_modify_batch($link, "cn=not-found,$base", $addGivenName));
|
|
|
|
// Invalid DN
|
|
var_dump(ldap_modify_batch($link, "weirdAttribute=val", $addGivenName));
|
|
|
|
// prepare
|
|
$entry = array(
|
|
"objectClass" => array(
|
|
"top",
|
|
"dcObject",
|
|
"organization"),
|
|
"dc" => "my-domain",
|
|
"o" => "my-domain",
|
|
);
|
|
|
|
ldap_add($link, "dc=my-domain,$base", $entry);
|
|
|
|
// invalid domain
|
|
$mods = array(
|
|
array(
|
|
"attrib" => "dc",
|
|
"modtype" => LDAP_MODIFY_BATCH_REPLACE,
|
|
"values" => array("Wrong Domain")
|
|
)
|
|
);
|
|
|
|
var_dump(ldap_modify_batch($link, "dc=my-domain,$base", $mods));
|
|
|
|
// invalid attribute
|
|
$mods = array(
|
|
array(
|
|
"attrib" => "weirdAttribute",
|
|
"modtype" => LDAP_MODIFY_BATCH_ADD,
|
|
"values" => array("weirdVal", "anotherWeirdval")
|
|
)
|
|
);
|
|
|
|
var_dump(ldap_modify_batch($link, "dc=my-domain,$base", $mods));
|
|
?>
|
|
--CLEAN--
|
|
<?php
|
|
require "connect.inc";
|
|
|
|
$link = ldap_connect_and_bind($uri, $user, $passwd, $protocol_version);
|
|
|
|
ldap_delete($link, "dc=my-domain,$base");
|
|
?>
|
|
--EXPECTF--
|
|
Warning: ldap_modify_batch(): Batch Modify: No such object in %s on line %d
|
|
bool(false)
|
|
|
|
Warning: ldap_modify_batch(): Batch Modify: Invalid DN syntax in %s on line %d
|
|
bool(false)
|
|
|
|
Warning: ldap_modify_batch(): Batch Modify: Naming violation in %s on line %d
|
|
bool(false)
|
|
|
|
Warning: ldap_modify_batch(): Batch Modify: Undefined attribute type in %s on line %d
|
|
bool(false)
|