-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathchangeUser.js
More file actions
52 lines (50 loc) · 1.48 KB
/
Copy pathchangeUser.js
File metadata and controls
52 lines (50 loc) · 1.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
'use strict'
const ldap = require('ldapjs')
const ldapChanges = require('./changes')
const utils = require('./utils')
module.exports = function ({adminDn, adminPassword, username, upn, userDn, email, changes}) {
return new Promise((resolve, reject) => {
// create client connection
const client = this.getClient()
// catch LDAP connection errors
client.on('connectError', function (err) {
console.log('Error connecting to LDAP:', err)
reject(err)
})
// login to LDAP
client.bind(adminDn, adminPassword, async (err) => {
// console.log('ldap client bind')
if (err) {
console.log(err)
client.destroy()
return reject(err)
}
// figure out which filter to use to identify the user
let filter
if (username) {
filter = '(sAMAccountName=' + username + ')'
} else if (email) {
filter = '(mail=' + email + ')'
} else if (upn) {
filter = '(userPrincipalName=' + upn + ')'
} else if (userDn) {
filter = '(distinguishedName=' + userDn + ')'
}
// find user by filter
const opts = {
filter,
scope: 'sub',
attributes: ['objectGUID']
}
try {
const user = await utils.applyChanges.call(this, client, this.baseDn, opts, changes)
// console.log('Password reset for ' + user.dn)
client.destroy()
resolve(user)
} catch (e) {
client.destroy()
reject(e)
}
})
})
}