2011-10-18 20:49:48 +00:00
|
|
|
#!/usr/bin/env node
|
|
|
|
// -*- mode: js -*-
|
|
|
|
// Copyright 2011 Mark Cavage. All rights reserved.
|
|
|
|
|
|
|
|
var fs = require('fs');
|
|
|
|
var path = require('path');
|
|
|
|
var url = require('url');
|
|
|
|
|
|
|
|
var nopt = require('nopt');
|
|
|
|
|
|
|
|
var ldap = require('../lib/index');
|
2013-04-24 18:45:19 +00:00
|
|
|
var Logger = require('bunyan');
|
2011-10-18 20:49:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
///--- Globals
|
|
|
|
|
|
|
|
nopt.typeDefs.DN = {
|
|
|
|
type: ldap.DN,
|
|
|
|
validate: function(data, k, val) {
|
|
|
|
data[k] = ldap.parseDN(val);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
var opts = {
|
|
|
|
'attribute': String,
|
|
|
|
'debug': Number,
|
|
|
|
'binddn': ldap.DN,
|
|
|
|
'file': String,
|
2014-04-23 00:46:14 +00:00
|
|
|
'insecure': Boolean,
|
2011-10-18 20:49:48 +00:00
|
|
|
'password': String,
|
|
|
|
'url': url,
|
|
|
|
'value': String,
|
|
|
|
};
|
|
|
|
|
|
|
|
var shortOpts = {
|
|
|
|
'a': ['--attribute'],
|
|
|
|
'd': ['--debug'],
|
|
|
|
'D': ['--binddn'],
|
|
|
|
'f': ['--file'],
|
2014-04-23 00:46:14 +00:00
|
|
|
'i': ['--insecure'],
|
2011-10-18 20:49:48 +00:00
|
|
|
'w': ['--password'],
|
|
|
|
'u': ['--url'],
|
|
|
|
'v': ['--value']
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
///--- Helpers
|
|
|
|
|
|
|
|
function usage(code, message) {
|
|
|
|
var _opts = '';
|
|
|
|
Object.keys(shortOpts).forEach(function(k) {
|
|
|
|
if (!Array.isArray(shortOpts[k]))
|
|
|
|
return;
|
|
|
|
var longOpt = shortOpts[k][0].replace('--', '');
|
|
|
|
var type = opts[longOpt].name || 'string';
|
|
|
|
if (type && type === 'boolean') type = '';
|
|
|
|
type = type.toLowerCase();
|
|
|
|
|
|
|
|
_opts += ' [--' + longOpt + ' ' + type + ']';
|
|
|
|
});
|
|
|
|
_opts += ' DN';
|
|
|
|
|
|
|
|
var msg = (message ? message + '\n' : '') +
|
|
|
|
'usage: ' + path.basename(process.argv[1]) + _opts;
|
|
|
|
|
|
|
|
process.stderr.write(msg + '\n');
|
|
|
|
process.exit(code);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function perror(err) {
|
|
|
|
if (parsed.debug) {
|
|
|
|
process.stderr.write(err.stack + '\n');
|
|
|
|
} else {
|
|
|
|
process.stderr.write(err.message + '\n');
|
|
|
|
}
|
|
|
|
process.exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
///--- Mainline
|
|
|
|
|
2013-04-24 18:45:19 +00:00
|
|
|
var logLevel = 'info';
|
2011-10-18 20:49:48 +00:00
|
|
|
var parsed;
|
|
|
|
|
|
|
|
try {
|
|
|
|
parsed = nopt(opts, shortOpts, process.argv, 2);
|
|
|
|
} catch (e) {
|
|
|
|
usage(1, e.toString());
|
|
|
|
}
|
|
|
|
|
2014-04-23 00:46:14 +00:00
|
|
|
if (parsed.insecure === undefined &&
|
|
|
|
process.env.LDAPJS_TLS_INSECURE !== undefined) {
|
|
|
|
if (process.env.LDAPJS_TLS_INSECURE === '0') {
|
|
|
|
parsed.insecure = false;
|
|
|
|
} else {
|
|
|
|
parsed.insecure = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-10-18 20:49:48 +00:00
|
|
|
if (parsed.help)
|
|
|
|
usage(0);
|
|
|
|
|
|
|
|
if (parsed.argv.remain.length < 1)
|
|
|
|
usage(1, 'DN required');
|
|
|
|
try {
|
|
|
|
parsed.argv.remain.forEach(function(dn) {
|
|
|
|
ldap.parseDN(dn);
|
|
|
|
});
|
|
|
|
} catch (e) {
|
|
|
|
usage(1, e.toString());
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!parsed.attribute || typeof(parsed.value) !== 'string')
|
|
|
|
usage(1, 'attribute and value required');
|
|
|
|
|
|
|
|
if (parsed.debug)
|
2013-04-24 18:45:19 +00:00
|
|
|
logLevel = (parsed.debug > 1 ? 'trace' : 'debug');
|
2011-10-18 20:49:48 +00:00
|
|
|
if (!parsed.url)
|
|
|
|
parsed.url = 'ldap://127.0.0.1:389';
|
|
|
|
if (!parsed.binddn)
|
|
|
|
parsed.binddn = '';
|
|
|
|
if (!parsed.password)
|
|
|
|
parsed.password = '';
|
|
|
|
|
2013-04-24 18:45:19 +00:00
|
|
|
var log = new Logger({
|
|
|
|
name: 'ldapjs',
|
|
|
|
component: 'client',
|
|
|
|
stream: process.stderr,
|
|
|
|
level: logLevel
|
|
|
|
});
|
|
|
|
|
2011-10-18 20:49:48 +00:00
|
|
|
var client = ldap.createClient({
|
|
|
|
url: parsed.url,
|
2014-04-23 00:46:14 +00:00
|
|
|
log: log,
|
|
|
|
tlsOptions: {
|
|
|
|
rejectUnauthorized: !parsed.insecure
|
|
|
|
}
|
2011-10-18 20:49:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
client.on('error', function(err) {
|
|
|
|
perror(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
client.bind(parsed.binddn, parsed.password, function(err, res) {
|
|
|
|
if (err)
|
|
|
|
perror(err);
|
|
|
|
|
|
|
|
var finished = 0;
|
|
|
|
parsed.argv.remain.forEach(function(dn) {
|
|
|
|
client.compare(dn, parsed.attribute, parsed.value, function(err, match) {
|
|
|
|
if (err)
|
|
|
|
perror(err);
|
|
|
|
|
|
|
|
process.stdout.write(match + '\n');
|
|
|
|
|
|
|
|
if (++finished === parsed.argv.remain.length) {
|
|
|
|
client.unbind(function() {
|
|
|
|
return;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|