12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
-
-
- var assert = require('assert-plus');
- var util = require('util');
-
- var asn1 = require('asn1');
-
- var LDAPMessage = require('./message');
- var Protocol = require('../protocol');
-
-
-
-
- var Ber = asn1.Ber;
- var LDAP_BIND_SIMPLE = 'simple';
- var LDAP_BIND_SASL = 'sasl';
-
-
-
-
- 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();
-
-
- 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());
-
- 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;
- };
-
-
-
-
- module.exports = BindRequest;
|