Name Date Size #Lines LOC

..16-Mar-2021-

CONFLICTSH A D02-Dec-20205 21

README.mdH A D02-Dec-20204.2 KiB147106

bug48441.phptH A D02-Dec-20202.8 KiB168162

bug72021.phptH A D02-Dec-2020321 1513

bug73933.phptH A D02-Dec-2020715 3124

bug77958.phptH A D02-Dec-20201.2 KiB5448

connect.incH A D02-Dec-20203 KiB9083

ldap_add_basic.phptH A D02-Dec-20201.5 KiB8277

ldap_add_error.phptH A D02-Dec-20202.6 KiB115101

ldap_add_ext.phptH A D02-Dec-20201.9 KiB9388

ldap_bind_basic.phptH A D02-Dec-2020440 1917

ldap_bind_error.phptH A D02-Dec-2020759 2823

ldap_bind_ext.phptH A D02-Dec-20201.7 KiB7167

ldap_bind_variation.phptH A D02-Dec-2020449 1917

ldap_compare_basic.phptH A D02-Dec-2020724 3027

ldap_compare_error.phptH A D02-Dec-2020806 3430

ldap_connect_basic.phptH A D02-Dec-2020312 1715

ldap_connect_error.phptH A D02-Dec-2020582 2622

ldap_connect_ldap_conf.phptH A D02-Dec-2020580 2524

ldap_connect_variation.phptH A D02-Dec-2020758 3832

ldap_controls.phptH A D02-Dec-20204.4 KiB161153

ldap_count_entries_basic.phptH A D02-Dec-2020675 2724

ldap_count_references_basic.phptH A D02-Dec-20201.2 KiB3735

ldap_delete_basic.phptH A D02-Dec-2020861 3934

ldap_delete_error.phptH A D02-Dec-2020976 4539

ldap_delete_ext.phptH A D02-Dec-20201.5 KiB7065

ldap_dn2ufn.phptH A D02-Dec-2020536 2922

ldap_err2str_basic.phptH A D02-Dec-2020279 1413

ldap_errno_basic.phptH A D02-Dec-2020592 2926

ldap_error_basic.phptH A D02-Dec-2020615 2926

ldap_escape_all.phptH A D02-Dec-2020226 1511

ldap_escape_both.phptH A D02-Dec-2020261 1511

ldap_escape_dn.phptH A D02-Dec-2020223 1511

ldap_escape_filter.phptH A D02-Dec-2020235 1511

ldap_escape_ignore.phptH A D02-Dec-2020246 1612

ldap_exop.phptH A D02-Dec-20202.3 KiB8173

ldap_exop_passwd.phptH A D02-Dec-20201.2 KiB4338

ldap_exop_passwd_error.phptH A D02-Dec-20201 KiB3933

ldap_exop_refresh.phptH A D02-Dec-20201.1 KiB4238

ldap_exop_whoami.phptH A D02-Dec-2020628 3025

ldap_explode_dn.phptH A D02-Dec-20201.5 KiB8574

ldap_first_attribute_basic.phptH A D02-Dec-2020777 3027

ldap_first_attribute_error.phptH A D02-Dec-2020500 2119

ldap_first_entry_basic.phptH A D02-Dec-2020830 3633

ldap_first_reference_basic.phptH A D02-Dec-20201.2 KiB4139

ldap_free_result_basic.phptH A D02-Dec-2020669 2724

ldap_get_attributes_basic.phptH A D02-Dec-20201,023 5350

ldap_get_dn_basic.phptH A D02-Dec-2020720 3027

ldap_get_entries_basic.phptH A D02-Dec-20201.1 KiB6258

ldap_get_entries_variation.phptH A D02-Dec-2020732 3531

ldap_get_option_basic.phptH A D02-Dec-2020475 2421

ldap_get_option_controls.phptH A D02-Dec-20202.6 KiB111106

ldap_get_option_package_basic.phptH A D02-Dec-2020521 2018

ldap_get_option_variation.phptH A D02-Dec-20202.3 KiB108103

ldap_get_values_len_basic.phptH A D02-Dec-2020777 3532

ldap_get_values_len_error.phptH A D02-Dec-2020863 3026

ldap_list_basic.phptH A D02-Dec-20202.5 KiB149146

ldap_mod_add_basic.phptH A D02-Dec-20201.4 KiB7872

ldap_mod_add_error.phptH A D02-Dec-20201.4 KiB6247

ldap_mod_del_basic.phptH A D02-Dec-2020814 4236

ldap_mod_del_error.phptH A D02-Dec-20201,021 4132

ldap_mod_ext.phptH A D02-Dec-20203.5 KiB171165

ldap_mod_replace_basic.phptH A D02-Dec-20201.1 KiB5852

ldap_mod_replace_error.phptH A D02-Dec-20201,010 3931

ldap_modify_basic.phptH A D02-Dec-20201.5 KiB8276

ldap_modify_batch_basic.phptH A D02-Dec-20202 KiB108102

ldap_modify_batch_error.phptH A D02-Dec-20201.9 KiB8367

ldap_modify_error.phptH A D02-Dec-20201.4 KiB6247

ldap_next_attribute_basic.phptH A D02-Dec-2020942 3734

ldap_next_attribute_error.phptH A D02-Dec-2020889 3128

ldap_next_entry_basic.phptH A D02-Dec-2020925 3936

ldap_next_reference_basic.phptH A D02-Dec-20201.5 KiB4745

ldap_option_reqcert_basic.phptH A D02-Dec-2020614 2319

ldap_option_reqcert_error.phptH A D02-Dec-2020610 2319

ldap_parse_reference_basic.phptH A D02-Dec-20201.2 KiB4442

ldap_parse_result_basic.phptH A D02-Dec-20201.2 KiB4542

ldap_parse_result_controls.phptH A D02-Dec-20201.3 KiB4541

ldap_read_basic.phptH A D02-Dec-20201.1 KiB6360

ldap_read_variation1.phptH A D02-Dec-2020364 2423

ldap_rename_basic.phptH A D02-Dec-20201.3 KiB6158

ldap_rename_error.phptH A D02-Dec-2020376 1715

ldap_rename_ext.phptH A D02-Dec-20201.8 KiB7975

ldap_sasl_bind_basic.phptH A D02-Dec-2020976 3733

ldap_sasl_bind_error.phptH A D02-Dec-20201.8 KiB5744

ldap_search_basic.phptH A D02-Dec-20203.1 KiB193189

ldap_search_error.phptH A D16-Mar-20211.8 KiB6654

ldap_search_overrides.phptH A D02-Dec-20203.7 KiB214210

ldap_search_paged_result_controls.phptH A D02-Dec-20202 KiB9894

ldap_search_sort_controls.phptH A D02-Dec-20204.3 KiB206201

ldap_search_variation1.phptH A D02-Dec-20201,000 5551

ldap_search_variation2.phptH A D02-Dec-20201.3 KiB7975

ldap_search_variation3.phptH A D02-Dec-20201.8 KiB107101

ldap_search_variation4.phptH A D02-Dec-20201 KiB5450

ldap_search_variation5.phptH A D02-Dec-20202 KiB10498

ldap_search_variation6.phptH A D02-Dec-20204 KiB241236

ldap_set_option_basic.phptH A D02-Dec-2020475 2219

ldap_set_option_cafiles_basic.phptH A D02-Dec-2020823 4037

ldap_set_option_ciphersuite_basic.phptH A D02-Dec-2020466 2118

ldap_set_option_crlcheck_basic.phptH A D02-Dec-2020864 3936

ldap_set_option_crlcheck_error.phptH A D02-Dec-2020352 1615

ldap_set_option_error.phptH A D02-Dec-20201.3 KiB4439

ldap_set_option_keepalive_basic.phptH A D02-Dec-2020588 3128

ldap_set_option_reqcert_basic.phptH A D02-Dec-2020707 3734

ldap_set_option_reqcert_error.phptH A D02-Dec-2020380 1615

ldap_set_option_tls_protocol_min_basic.phptH A D02-Dec-2020759 3734

ldap_set_option_variation.phptH A D02-Dec-20202.5 KiB121117

ldap_set_rebind_proc_basic.phptH A D02-Dec-2020800 3328

ldap_set_rebind_proc_error.phptH A D02-Dec-20201.1 KiB4439

ldap_start_tls_basic.phptH A D02-Dec-2020452 1917

ldap_unbind_basic.phptH A D02-Dec-2020407 1916

ldap_unbind_variation.phptH A D02-Dec-2020803 3327

skipif.incH A D02-Dec-202089 65

skipifbindfailure.incH A D02-Dec-2020357 1410

skipifcontrol.incH A D02-Dec-2020459 1412

README.md

1# The ldap extension tests
2
3To ease testing LDAP-Setups we've created a vagrant-setup.
4
5## Prerequisites
6
7You will need [vagrant](https://www.vagrantup.com) on your box.
8
9## Usage
10
11To use it follow these steps:
12
13* Create a `Vagrantfile` with the following content.
14* Go to that directory and run "vagrant up"
15
16```Vagrantfile
17$setup = <<<SETUP
18apt-get update
19
20DEBIAN_FRONTEND=noninteractive aptitude install -q -y slapd ldap-utils
21
22export SLAPPASS=`slappasswd -s password`
23
24echo "dn: olcDatabase={1}hdb,cn=config
25changetype: modify
26replace: olcSuffix
27olcSuffix: dc=nodomain
28-
29replace: olcRootDN
30olcRootDN: dc=admin,dc=nodomain
31-
32replace: olcRootPW
33olcRootPW: ${SLAPPASS}" | ldapmodify -Y EXTERNAL -H ldapi:///
34
35echo "dn: dc=nodomain
36objectClass: dcObject
37objectClass: organization
38o: Example
39dc: example
40
41dn: ou=extldap,dc=nodomain
42objectClass: organizationalUnit
43ou: extldap" | ldapadd -c -x -H ldap://localhost:389 -D "dc=admin,dc=nodomain" -w password
44SETUP
45
46Vagrant.configure(2) do |config|
47  config.vm.box = "ubuntu/trusty64"
48  config.vm.network "private_network", ip: "192.168.33.10"
49  config.vm.provision "shell", inline: $setup
50end
51```
52
53Now you will have a virtual machine up and running on IP-Address `192.168.10.33`
54listening on port 369 for incoming LDAP-connections. The machine is already
55configured to execute the LDAP-Tests.
56
57The next step is to go into the PHP-Source-directory. Configure and make the
58source as appropriate.
59
60Before running the LDAP-Tests you need to set some environment-variables:
61
62```bash
63export LDAP_TEST_PASSWD="password"
64export LDAP_TEST_BASE="ou=extldap,dc=nodomain"
65export LDAP_TEST_USER="dc=admin,dc=nodomain"
66export LDAP_TEST_HOST=192.168.33.10
67```
68
69Now you can run the test-suite by calling `make test`. To test only the
70LDAP-Tests, run `make test TESTS=ext/ldap`.
71
72CAVEAT: The current setup does not (yet) test secure connections.
73
74## Old README
75
76Most tests here rely on the availability of an LDAP server configured with TLS.
77
78### Client/Server configuration
79
80OpenLDAP 2.4.31 has been used with the configuration below.
81
82Notes:
83
841. A self signed certificate can be generated using:
85
86    ```bash
87    openssl req -newkey rsa:1024 -x509 -nodes -out server.pem -keyout server.pem -days 3650
88    ```
89
90    It is used for testing ldap_start_tls(), which also requires
91    `TLS_REQCERT never` in client configuration.
92
932. An empty LDAP structure is required for the tests to be PASSed (except for
94    base and admin)
95
96If you use a debian based distribution, prefer the use of `dpkg-reconfigure`.
97Otherwise you may alter these configuration files:
98
99#### (/etc/openldap/)slapd.conf
100
101```txt
102TLSCACertificateFile /etc/openldap/ssl/server.pem
103TLSCertificateFile /etc/openldap/ssl/server.pem
104TLSCertificateKeyFile /etc/openldap/ssl/server.pem
105TLSVerifyClient never
106
107# hdb is used instead of bdb as it enables the usage of referrals & aliases
108database        hdb
109suffix          "dc=my-domain,dc=com"
110checkpoint      32      30
111rootdn          "cn=Manager,dc=my-domain,dc=com"
112rootpw          secret
113directory       /var/lib/openldap-data
114index   objectClass     eq
115
116authz-regexp
117    uid=Manager,cn=digest-md5,cn=auth
118    cn=Manager,dc=my-domain,dc=com
119```
120
121#### (/etc/openldap/)ldap.conf
122
123```txt
124TLS_REQCERT never
125```
126
127#### Tests configuration
128
129The following environment variables may be defined:
130
131```txt
132LDAP_TEST_HOST (default: localhost)                        Host to connect to
133LDAP_TEST_PORT (default: 389)                              Port to connect to
134LDAP_TEST_BASE (default: dc=my-domain,dc=com)              Base to use. May be the ldap root or a subtree. (ldap_search_variation6 will fail if a subtree is used)
135LDAP_TEST_USER (default: cn=Manager,dc=my-domain,dc=com)   DN used for binding
136LDAP_TEST_SASL_USER (default: Manager)                     SASL user used for SASL binding
137LDAP_TEST_PASSWD (default: secret)                         Password used for plain and SASL binding
138LDAP_TEST_OPT_PROTOCOL_VERSION (default: 3)                Version of LDAP protocol to use
139LDAP_TEST_SKIP_BIND_FAILURE (default: true)                Whether to fail the test or not in case binding fails
140```
141
142## Credits
143
144* Davide Mendolia (idaf1er@gmail.com)
145* Patrick Allaert (patrick.allaert@gmail.com)
146* Côme Bernigaud (mcmic@php.net)
147