summaryrefslogtreecommitdiffstats
path: root/apps/user_ldap/tests/Integration/setup-scripts/createExplicitUsers.php
blob: aaba2d0bf8502e66cd75ee11327364fffa7419ce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php
/**
 * @copyright Copyright (c) 2016, ownCloud, Inc.
 *
 * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
 * @author Morris Jobke <hey@morrisjobke.de>
 *
 * @license AGPL-3.0
 *
 * This code is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License, version 3,
 * as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License, version 3,
 * along with this program. If not, see <http://www.gnu.org/licenses/>
 *
 */
if(php_sapi_name() !== 'cli') {
	print('Only via CLI, please.');
	exit(1);
}

include __DIR__ . '/config.php';

$cr = ldap_connect($host, $port);
ldap_set_option($cr, LDAP_OPT_PROTOCOL_VERSION, 3);
$ok = ldap_bind($cr, $adn, $apwd);

if (!$ok) {
	die(ldap_error($cr));
}

$ouName = 'Users';
$ouDN = 'ou=' . $ouName . ',' . $bdn;

//creates on OU
if (true) {
	$entry = [];
	$entry['objectclass'][] = 'top';
	$entry['objectclass'][] = 'organizationalunit';
	$entry['ou'] = $ouName;
	$b = ldap_add($cr, $ouDN, $entry);
	if (!$b) {
		die(ldap_error($cr));
	}
}

$users = ['alice', 'boris', 'cynthia', 'derek', 'evelina', 'fatima', 'gregor'];

foreach ($users as $uid) {
	$newDN = 'uid=' . $uid . ',' . $ouDN;
	$fn = ucfirst($uid);
	$sn = ucfirst(str_shuffle($uid));   // not so explicit but it's OK.

	$entry = [];
	$entry['cn'] = $fn . ' ' . $sn;
	$entry['objectclass'][] = 'inetOrgPerson';
	$entry['objectclass'][] = 'person';
	$entry['sn'] = $sn;
	$entry['userPassword'] = $uid;
	$entry['displayName'] = $sn . ', ' . $fn;
	$entry['mail'] = $fn . '@example.com';

	$ok = ldap_add($cr, $newDN, $entry);
	if ($ok) {
		echo('created user ' . ': ' . $entry['cn'] . PHP_EOL);
	} else {
		die(ldap_error($cr));
	}
}