check NSS LDAP

This commit is contained in:
Roland Gruber 2010-01-02 18:40:29 +00:00
parent 497ab97997
commit dfa837f932
2 changed files with 27 additions and 2 deletions

View File

@ -140,12 +140,34 @@ while (1) {
sub runTest {
# basic test
if ($vals[2] eq 'basic') {
$return = "Ok";
$return = "INFO,Basic test ok";
}
# quota test
elsif ($vals[2] eq 'quota') {
require Quota;
$return = "Ok";
$return = "INFO,Quota test ok";
}
# NSS LDAP
elsif ($vals[2] eq 'nss') {
$userName = $vals[3];
# check if the user exists in /etc/passwd
system("grep", "-q", "^" . $userName . ":", "/etc/passwd");
if ( $? == 0 ) {
$error = "User $userName is a local user (/etc/passwd) but should be LDAP only.";
$return = "ERROR,$error";
logMessage(LOG_ERR, $error);
}
else {
# check if home directory is readable
@user = getpwnam($userName);
if ($user[7] eq '') {
$return = "ERROR,Unable to determine home directory of user $userName. Please check that NSS LDAP is correctly configured.";
logMessage(LOG_ERR, "Unable to determine home directory of user $userName. Please check that NSS LDAP is correctly configured.");
}
else {
$return = "INFO,NSS test ok";
}
}
}
}

View File

@ -292,6 +292,9 @@ function lamRunLamdaemonTestSuite($serverName, $serverTitle, $testQuota) {
flush();
$stopTest = lamTestLamdaemon("+" . $SPLIT_DELIMITER . "test" . $SPLIT_DELIMITER . "basic\n", $stopTest, $handle, _("Execute lamdaemon"));
$handle = lamTestConnectSSH($serverName);
@ssh2_auth_password($handle, $userName, $credentials[1]);
$stopTest = lamTestLamdaemon("+" . $SPLIT_DELIMITER . "test" . $SPLIT_DELIMITER . "nss" . $SPLIT_DELIMITER . "$userName\n", $stopTest, $handle, _("Lamdaemon: check NSS LDAP"));
if ($testQuota) {
$handle = lamTestConnectSSH($serverName);
@ssh2_auth_password($handle, $userName, $credentials[1]);