om/node_modules/ldapjs/lib/messages/bind_request.js

89 lines
1.9 KiB
JavaScript
Raw Permalink Normal View History

// Copyright 2011 Mark Cavage, Inc. All rights reserved.
var assert = require('assert-plus');
var util = require('util');
var asn1 = require('asn1');
var LDAPMessage = require('./message');
var Protocol = require('../protocol');
///--- Globals
var Ber = asn1.Ber;
var LDAP_BIND_SIMPLE = 'simple';
var LDAP_BIND_SASL = 'sasl';
///--- API
function BindRequest(options) {
options = options || {};
assert.object(options);
options.protocolOp = Protocol.LDAP_REQ_BIND;
LDAPMessage.call(this, options);
this.version = options.version || 0x03;
this.name = options.name || null;
this.authentication = options.authentication || LDAP_BIND_SIMPLE;
this.credentials = options.credentials || '';
}
util.inherits(BindRequest, LDAPMessage);
Object.defineProperties(BindRequest.prototype, {
type: {
get: function getType() { return 'BindRequest'; },
configurable: false
},
_dn: {
get: function getDN() { return this.name; },
configurable: false
}
});
BindRequest.prototype._parse = function (ber) {
assert.ok(ber);
this.version = ber.readInt();
this.name = ber.readString();
var t = ber.peek();
// TODO add support for SASL et al
if (t !== Ber.Context)
throw new Error('authentication 0x' + t.toString(16) + ' not supported');
this.authentication = LDAP_BIND_SIMPLE;
this.credentials = ber.readString(Ber.Context);
return true;
};
BindRequest.prototype._toBer = function (ber) {
assert.ok(ber);
ber.writeInt(this.version);
ber.writeString((this.name || '').toString());
// TODO add support for SASL et al
ber.writeString((this.credentials || ''), Ber.Context);
return ber;
};
BindRequest.prototype._json = function (j) {
assert.ok(j);
j.version = this.version;
j.name = this.name;
j.authenticationType = this.authentication;
j.credentials = this.credentials;
return j;
};
///--- Exports
module.exports = BindRequest;