entryParser
是有這個目的:
const ActiveDirectory = require('activedirectory');
const config = {
url: 'LDAP://ldap.example.com',
baseDN: 'OU=Users,DC=example,DC=com',
username: '[email protected]',
password: 'password',
entryParser(entry, raw, callback) {
if (raw.hasOwnProperty("objectGUID")) { entry.objectGUID = raw.objectGUID; }
callback(entry);
}
};
const ad = new ActiveDirectory(config);
const query = {
filter: '(objectClass=user)',
attributes: ["dn", "cn", "objectGUID", "objectSid"]
};
ad.findUsers(query, function (err, result) {
if (err) {
return console.error(err);
}
console.log(result.length);
console.log(result[0]); // objectGUID contains Buffer with strange byte order
console.log(result[0].objectGUID
.toString('hex')
.replace(
/^(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)(..)$/,
"{$4$3$2$1-$6$5-$8$7-$10$9-$16$15$14$13$12$11}"
).toUpperCase() // Normal guid, conversion could be moved into the parser
);
});
這可能會幫助:http://ldapwiki.com/WIK我/的objectGUID – jwilleke