ad-promise
Version:
This is a fork of the gheeres node-activedirectory. It fixes some issues with timeouts with very large AD-Groups as well as returning also promises so you won't have to use callbacks
108 lines (99 loc) • 4.85 kB
JavaScript
const _ = require('underscore');
const User = require('../models/user');
const joinAttributes = require('./internal/service.joinAttributes');
const includeGroupMembershipFor = require('./internal/service.includeGroupMembershipFor');
const search = require('./internal/service.search');
const truncateLogOutput = require('./internal/service.truncateLogOutput');
const pickAttributes = require('./internal/service.pickAttributes');
const getRequiredLdapAttributesForUser = require('./internal/service.getRequiredLdapAttributesForUser');
const getUserQueryFilter = require('./internal/service.getUserQueryFilter');
const getGroupMembershipForDN = require('./service.getGroupMembershipForDn');
const log = require('./internal/service.log');
const defaultAttributes = require('../configs/config.defaultAttributes');
const updateBaseDn = require('./internal/service.updateBaseDn');
/**
* Retrieves the specified user.
*
* @public
* @param {Object} [opts] Optional LDAP query string parameters to execute. { scope: '', filter: '', attributes: [ '', '', ... ], sizeLimit: 0, timelimit: 0 }
* @param {String} username The username to retrieve information about. Optionally can pass in the distinguishedName (dn) of the user to retrieve.
* @param {Boolean} [includeMembership] OBSOLETE; NOT NOT USE. Indicates if the results should include group memberships for the user. Defaults to false.
* @param {Function} callback The callback to execute when completed. callback(err: {Object}, user: {User})
*/
function findUser(opts, username, includeMembership, callback) {
if (typeof (includeMembership) === 'function') {
callback = includeMembership;
includeMembership = undefined;
}
if (typeof (username) === 'function') {
callback = username;
username = opts;
opts = undefined;
}
if (typeof (username) === 'boolean') {
includeMembership = username;
username = opts;
}
if (typeof (opts) === 'string') {
username = opts;
opts = undefined;
}
log.trace('findUser(%j,%s,%s)', opts, username, includeMembership);
var self = this;
return new Promise((resolve, reject) => {
var localOpts = _.defaults(_.omit(opts || {}, 'attributes'), {
filter: getUserQueryFilter.call(self, username),
scope: 'sub',
attributes: joinAttributes((opts || {}).attributes || defaultAttributes.user || [], getRequiredLdapAttributesForUser(opts))
});
updateBaseDn(self, "user");
search.call(self, localOpts, function onSearch(err, results) {
if (err) {
if (callback){
callback(err);
}
return reject(err);
}
if ((!results) || (results.length === 0)) {
log.warn('User "%s" not found for query "%s"', username, truncateLogOutput(localOpts.filter));
if (callback){
callback(null, {});
}
return resolve({});
}
var user = new User(pickAttributes(results[0], (opts || {}).attributes || defaultAttributes.user));
log.info('%d user(s) found for query "%s". Returning first user: %j', results.length, truncateLogOutput(localOpts.filter), user);
// Also retrieving user group memberships?
if (includeGroupMembershipFor(opts, 'user') || includeMembership) {
getGroupMembershipForDN.call(self, opts, user.dn, function (err, groups) {
if (err) {
if (callback){
callback(err);
}
return reject(err);
}
user.groups = groups;
self.emit('user', user);
if (callback){
callback(null, user);
}
return resolve(user);
});
}
else {
self.emit('user', user);
if(err){
if (callback){
callback(err);
}
return reject(err);
}
if(callback){
callback(null, user);
}
return resolve(user);
}
});
});
};
module.exports = findUser;