Время соединения ldapjs истекает через определенный промежуток времени
У меня есть некоторые проблемы, связанные с searchEntry в хранилище LDAP с использованием LDAPjs. Я не очень знаком с LDAP, и из-за этого я могу что-то упустить в реализации клиента. Проблема в том, что через некоторое время LDAP не получает ответа от сервера LDAP, просто ни один из обратных вызовов не вызывается.
const ldapClient = ldap.createClient({
url: 'ldap://some.ldap.server',
timeout: 3000,
connectTimeout: 6000
});
ldapClient.search('c=XX', opts, (err, res) => {
if (err) {
ldapClient.unbind(function(err) {
if (err) {
console.log(err)
}
});
return next(null);
}
res.once('searchEntry', (entry) => {
ldapClient.unbind(function(err) {
if (err) {
console.log(err)
}
});
return next(entry);
});
res.on('error', (error) => {
ldapClient.unbind(function(err) {
if (err) {
console.log(err)
}
});
return next(null, new Error(error.message));
});
});
1 ответ
Решение
Пройти reconnect
пометить как true
при создании клиента LDAP и не отвязывайте его так, как вы это сделали. Я думаю, что это также мешает переподключению. Отмените привязку только после успешной поисковой операции.
Этот код работает для меня: (значения, конечно, фиктивные)
var ldap = require('ldapjs');
var tlsOptions = {
host: 'example.com',
port: '636',
ca: [fs.readFileSync('./path/to/cert.pem')]
};
var client = ldap.createClient({
url: 'ldaps://example.com:636',
reconnect: true
tlsOptions: tlsOptions
});
client.bind(username, password, function (err) {
if (err) {
console.log('Error occurred while binding');
} else {
var base = 'cn=admin,dc=example,dc=com';
var search_options = {
scope: 'sub',
filter: '(&(objectClass=*)(CN=' + username + '))',
attrs: 'attrs'
};
client.search(base, search_options, function (err, res) {
if (err) {
console.log('Error occurred while ldap search');
} else {
res.on('searchEntry', function (entry) {
console.log('Entry', JSON.stringify(entry.object));
});
res.on('searchReference', function (referral) {
console.log('Referral', referral);
});
res.on('error', function (err) {
console.log('Error is', err);
});
res.on('end', function (result) {
console.log('Result is', result);
});
}
});
}
});