123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- #!/usr/bin/env node
- // -*- mode: js -*-
- // Copyright 2011 Mark Cavage. All rights reserved.
-
- var fs = require('fs');
- var path = require('path');
-
- var dashdash = require('dashdash');
- var vasync = require('vasync');
-
- var ldap = require('../lib/index');
- var Logger = require('bunyan');
-
-
- ///--- Globals
-
- var opts = [
- {
- names: ['file', 'f'],
- type: 'string',
- help: 'Input file',
- helpArg: 'FILE'
- },
- { group: 'General Options' },
- {
- names: ['help', 'h'],
- type: 'bool',
- help: 'Print this help and exit.'
- },
- {
- names: ['debug', 'd'],
- type: 'integer',
- help: 'Set debug level <0-2>',
- helpArg: 'LEVEL'
- },
- { group: 'Connection Options' },
- {
- names: ['url', 'u'],
- type: 'string',
- help: 'LDAP server URL',
- helpArg: 'URL',
- default: 'ldap://127.0.0.1:389'
- },
- {
- names: ['binddn', 'D'],
- type: 'string',
- help: 'Bind DN',
- helpArg: 'BIND_DN',
- default: ''
- },
- {
- names: ['password', 'w'],
- type: 'string',
- help: 'Bind password',
- helpArg: 'PASSWD',
- default: ''
- },
- {
- names: ['insecure', 'i'],
- type: 'bool',
- env: 'LDAPJS_TLS_INSECURE',
- help: 'Disable SSL certificate verification',
- default: false
- }
- ];
- var parser = dashdash.createParser({options: opts});
-
-
-
- ///--- Helpers
-
- function usage(code, message) {
- var msg = (message ? message + '\n' : '') +
- 'Usage: ' + path.basename(process.argv[1]) + ' [OPTIONS] [JSON]\n\n' +
- parser.help({includeEnv: true});
-
- 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
-
- var logLevel = 'info';
- var parsed;
-
- try {
- parsed = parser.parse(process.argv);
- if (parsed.file) {
- parsed.file = JSON.parse(fs.readFileSync(parsed.file, 'utf8'));
- if (!Array.isArray(parsed.file))
- parsed.file = [parsed.file];
- }
- } catch (e) {
- usage(1, e.toString());
- }
-
- if (parsed.help)
- usage(0);
- if (!parsed.file) {
- parsed.file = [];
- parsed._args.forEach(function (a) {
- var o = JSON.parse(a);
- if (Array.isArray(o)) {
- o.forEach(function (i) {
- parsed.file.push(o);
- });
- return;
- }
- parsed.file.push(o);
- });
- if (parsed.file.length === 0)
- parsed.file = null;
- }
-
- if (!parsed.file)
- usage(1, 'either -f or arguments must be used for adding objects');
-
- if (parsed.debug)
- logLevel = (parsed.debug > 1 ? 'trace' : 'debug');
-
- var log = new Logger({
- name: 'ldapjs',
- component: 'client',
- stream: process.stderr,
- level: logLevel
- });
-
- var client = ldap.createClient({
- url: parsed.url,
- log: log,
- strictDN: false,
- tlsOptions: {
- rejectUnauthorized: !parsed.insecure
- }
- });
-
- client.on('error', function (err) {
- perror(err);
- });
-
- client.bind(parsed.binddn, parsed.password, function (err, res) {
- if (err) {
- perror(err);
- }
-
- vasync.forEachPipeline({
- inputs: parsed.file,
- func: function (entry, cb) {
- var dn = entry.dn;
- delete entry.dn;
- client.add(dn, entry, cb);
- }
- }, function (err2, res2) {
- if (err2) {
- perror(err2);
- }
- client.unbind(function () { return; });
- });
- });
|