forked from bbalet/jorani
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtestldap.php
148 lines (138 loc) · 7.05 KB
/
testldap.php
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
<?php
/**
* This diagnostic page helps you to check ldap setup.
* @copyright Copyright (c) 2014-2016 Benjamin BALET
* @license http://opensource.org/licenses/AGPL-3.0 AGPL-3.0
* @link https://github.com/bbalet/jorani
* @since 0.4.2
*/
define('BASEPATH', '.'); //Make this script works with nginx
if (!defined('LDAP_OPT_DIAGNOSTIC_MESSAGE')) {
define('LDAP_OPT_DIAGNOSTIC_MESSAGE', 0x0032);
}
//Configuration values are taken from application/config/config.php
//This script may take some time especially if the LDAP is unreachable
//-----------------------------------------------------------------
//Please enter a valid username and password
define('LDAP_LOGIN', ''); //This login must exist in Jorani and LDAP
define('LDAP_PASSWORD', ''); //This is the password we will use to bind to LDAP
//-----------------------------------------------------------------
?>
<html>
<head>
<title>Jorani LDAP Configuration</title>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
<meta charset="UTF-8">
<link rel="icon" type="image/x-icon" href="favicon.ico" sizes="32x32">
<link href="assets/bootstrap/css/bootstrap.min.css" rel="stylesheet">
<script type="text/javascript" src="assets/js/jquery-1.11.0.min.js"></script>
</head>
<body>
<div class="container-fluid">
<ul class="nav nav-pills">
<li><a href="requirements.php">Requirements</a></li>
<li><a href="testmail.php">Email</a></li>
<li class="active"><a href="#">LDAP</a></li>
<li><a href="testssl.php">SSL</a></li>
<li><a href="testoauth2.php">OAuth2</a></li>
<li><a href="opcache.php">Opcache</a></li>
</ul>
<h1>Test of your LDAP configuration</h1>
<?php
//Check if we can access to the configuration file
$pathConfigFile = realpath(join(DIRECTORY_SEPARATOR, array('application', 'config', 'config.php')));
$pathDbFile = realpath(join(DIRECTORY_SEPARATOR, array('application', 'config', 'database.php')));
$configFileExists = file_exists($pathConfigFile);
$dBFileExists = file_exists($pathDbFile);
if (LDAP_LOGIN == '') {
echo '<b>ERROR:</b> Please provide a valid login in testldap.php.<br />' . PHP_EOL;
} else {
if ($configFileExists && $dBFileExists) {
if (extension_loaded('ldap')) {
include $pathConfigFile;
try {
if ($config['ldap_enabled'] == FALSE) {
echo '<b>WARNING:</b> LDAP is disabled into Jorani configuration file.<br />' . PHP_EOL;
}
$ldapUrl = 'ldap://' . $config['ldap_host'] . ':' . $config['ldap_port'] . '/';
$handle = @ldap_connect($ldapUrl);
if ($handle == FALSE) {
//This is tricky because LDAP 2.x.x will always return a resource id, next call might fail
echo '<b>ERROR:</b> Impossible to connect to LDAP server.<br />' . PHP_EOL;
}
//Protocol v3 is mandatory, because we might use Microsoft AD
ldap_set_option(NULL, LDAP_OPT_DEBUG_LEVEL, 7);
ldap_set_option($handle, LDAP_OPT_PROTOCOL_VERSION, 3);
$basedn = "";
if ($config['ldap_basedn_db'] == TRUE) {
echo '<b>INFO:</b> Using BaseDN defined into database.<br />' . PHP_EOL;
include $pathDbFile;
$dbConn = new mysqli($db['default']['hostname'], $db['default']['username'], $db['default']['password']);
$dbConn->select_db($db['default']['database']);
$sql = "SELECT ldap_path FROM users WHERE login = ?";
$stmt = $dbConn->prepare($sql);
$stmt->bind_param('s', $login);
$login = LDAP_LOGIN;
$stmt->execute();
$res = $stmt->get_result();
$row = $res->fetch_assoc();
if (count($row) == 0) {
echo '<b>ERROR:</b> The user wasn\'t found into Jorani\'s database.<br />' . PHP_EOL;
} else {
$basedn = $row['ldap_path'];
if ($basedn == "") {
echo '<b>ERROR:</b> The baseDN from DB is empty.<br />' . PHP_EOL;
}
}
} else {
echo '<b>INFO:</b> Using BaseDN defined into configuration file.<br />' . PHP_EOL;
$basedn = sprintf($config['ldap_basedn'], LDAP_LOGIN);
}
//Try to search for user
if ($basedn != "") {
$bind = @ldap_bind($handle, $basedn, LDAP_PASSWORD);
if (!$bind) {
echo '<b>ERROR:</b>Binding to LDAP. Message = ' . ldap_error($handle) . '<br />' . PHP_EOL;
} else {
echo '<b>INFO:</b> Connection is successful.<br />' . PHP_EOL;
}
}
ldap_close($handle);
} catch (Exception $e) {
echo '<b>ERROR:</b> Unexpected error.<br />' . PHP_EOL;
$text = $e->getMessage();
$text = iconv(mb_detect_encoding($text, mb_detect_order(), true), "UTF-8", $text);
echo $text . PHP_EOL;
}
} else {
echo '<b>ERROR:</b> PHP LDAP extension is not loaded.<br />' . PHP_EOL;
}
} else {
echo '<b>ERROR:</b> The configuration files were not found.<br />' . PHP_EOL;
}
}
?>
<h3>Troubleshooting</h3>
<p>In case of error, here are some additional steps:</p>
<ul>
<li>Whether you are using LDAP or Microsoft Active Directory, the users must be created into Jorani (of course, we'll not use the password stored into DB).</li>
<li>If you are using Microsoft Active Directory, you must enable LDAP v3 protocol.</li>
<li>Check the configuration with your IT Admin team. Ask them about the pattern to be used for binding to LDAP.</li>
<li>The LDAP port may be blocked by your organization/server's security policy (or firewall).</li>
<li>When running SELinux, the webserver is blocked by default (it cannot open a network connection). Please consider unblocking it:
<p>
<pre>
$ setsebool -P httpd_can_network_connect 1
</pre>
</p>
</li>
<li>Some LDAP servers require the application server (eg Jorani) to be whitelisted.</li>
</ul>
<h3>Examples of BaseURL</h3>
<p>With LDAP, if your users are all into the same OU, you'd use a common pattern:</p>
<pre>uid=%s,ou=people,dc=company,dc=com</pre>
<p>With Microsoft Active Directory, you would associate a user with its LDAP full path into the DB table <tt>users</tt>:</p>
<pre>CN=BALET benjamin,OU=Users,DC=COMMON,DC=AD,DC=COMPANY,DC=FR</pre>
</div>
</body>
</html>