ad-ldap-helper

0.1.7 • Public • Published

AD-LDAP-HELPER


A module with some helper functions to authenticate a Microsoft Active Directory user or lookup a user's info with a default account.

Dependencies:

  • dotenv
  • activedirectory2

Requires .env file in root of project with the following environmental variables:

  • LDAP_URL: Active Directory server to connect to, e.g. ldap://ad.example.com
  • BASE_DN: The root DN from which all searches will be performed, e.g. dc=example,dc=com
  • AD_USER: default ad user (hopefully not a real user's account!)
  • AD_PASSWD: default ad user's password

Methods

loginADUser(username: string, password: string, attributes?: Array): User|null

Attempts to authenticate a user with a given sAMAccountName and password. If unsuccessful, it returns null. If successful it returns a user object with:

  • sAMAccountName
  • givenName (firstname)
  • sn (surname)
  • telephoneNumber
  • mail (email)
  • l (location)
  • ... any attributes included in the optional 3rd argument (an array of strings)

getADUserInfo(username: string, attributes?: Array): Promise<User|null> Authenticates with a default user whose sAMAccountName and password are defined in a .env file. If unsuccessful, it returns a Promise rejection with null. If successful it returns a Promise resolve with the user object:

  • sAMAccountName
  • givenName (firstname)
  • sn (surname)
  • telephoneNumber
  • mail (email)
  • l (location)
  • ... any attributes included in the optional 3rd argument (an array of strings)

getADUserGroups(username: string, attributes?: Array): Promise<Array|null> Authenticates with a default user whose sAMAccountName and password are defined in a .env file. If unsuccessful, it returns a Promise rejection with null. If successful it returns a Promise resolve with the user's groups: [ Group { dn, cn, description, distinguishedName, objectCategory }, ... ]

getADUsersForGroup(groupname: string): Promise<Array|null> Authenticates with a default user whose sAMAccountName and password are defined in a .env file. If unsuccessful, it returns a Promise rejection with null. If successful, it returns a Promise resolve with a list of users belonging to the AD group: [ User { sAMAccountName, givenName, sn, mail, l, }, ... ]

Readme

Keywords

Package Sidebar

Install

npm i ad-ldap-helper

Weekly Downloads

8

Version

0.1.7

License

MIT

Unpacked Size

9.23 kB

Total Files

3

Last publish

Collaborators

  • ochsec