aboutsummaryrefslogtreecommitdiffstats
path: root/apps/user_ldap/tests/Integration/setup-scripts/createUsersWithoutDisplayName.php
blob: 18584fbe7480d337a77525566b5eced3f0ba7830 (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
<?php

/**
 * SPDX-FileCopyrightText: 2019-2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
 * SPDX-License-Identifier: AGPL-3.0-only
 */
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;

$users = ['robot'];

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'] = ucfirst($uid);
	$entry['objectclass'][] = 'inetOrgPerson';
	$entry['objectclass'][] = 'person';
	$entry['sn'] = $sn;
	$entry['userPassword'] = $uid;

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