ldap-pool
TypeScript icon, indicating that this package has built-in type declarations

0.0.1016 • Public • Published

LDAP Pool - a simple client pool for LDAP connections

This API is promise-based - so as to work well with async/await flow control.

Installation

$ npm install ldap-pool --save

Usage

 
import {Pool, LDAPPool, LDAPPoolClient} from 'ldap-pool';
 
let pool = new Pool({});
let pool = Pool.create({});  // same as above
 
// synchronous
let client = pool.getClientSync(); // returns a LDAPPoolClient synchronously
 
// asynchronous
pool.getClient().then(function(c: LDAPPoolClient){
   // gets an LDAPPoolClient asynchronously (the least active client)
});
 

The asynchronous getClient method is preferred, because this can guarantee we use a client that is not already active. Although it shouldn't matter that much.

Here we have a full use cycle:

 
const pool = Pool.create({
  connOpts: {
    url: url,
    reconnect: true,
    idleTimeout: 30000
  },
  size: 4,
  dn: 'uid=cdt_main.gen,OU=Generics,O=cco.nabisco.com',
  pwd: '<pwd>'
})
 
 
let client = pool.getClientSync();
 
client.search('foo', {}, function(err,res){
  
  // when you're done, return the client to the pool
  // this is important for performance, but *not* imperative for functionality/correctness
  client.returnToPool();
  
});
 

Package Sidebar

Install

npm i ldap-pool

Weekly Downloads

17

Version

0.0.1016

License

MIT

Unpacked Size

10.1 kB

Total Files

6

Last publish

Collaborators

  • oresoftware