Joemonkey
asked on
Adding a user to an AD group via VBScript using alternate credentials
I'm trying to create a vbscript that receives a parameter of samaccountname then have alternate credentials within the vbscript add that user to a group in Active Directory. We run the script like this:
scriptname.vbs samaccountname
and it pulls in the info correctly, but I can't figure out the code to do the "add user to group" part under the alternate credentials i specified in the script. The current code adds the user to the group with the credentials of the person running the script. i tried
objUser2.add (objGroup.Add("LDAP://"& strUserDN)) but that didn't work either :( all the examples I have found online have things like
objUser2.setPassword
but nothing like I want to do
scriptname.vbs samaccountname
and it pulls in the info correctly, but I can't figure out the code to do the "add user to group" part under the alternate credentials i specified in the script. The current code adds the user to the group with the credentials of the person running the script. i tried
objUser2.add (objGroup.Add("LDAP://"& strUserDN)) but that didn't work either :( all the examples I have found online have things like
objUser2.setPassword
but nothing like I want to do
' Constants for the NameTranslate object.
Const ADS_NAME_INITTYPE_GC = 3
Const ADS_NAME_TYPE_NT4 = 3
Const ADS_NAME_TYPE_1779 = 1
Set args = WScript.Arguments
arg1 = args.Item(0)
' Specify the NetBIOS name of the domain and the NT name of the user.
strNTName = "domain\" & arg1
Set objTrans = CreateObject("NameTranslate")
' Initialize NameTranslate by locating the Global Catalog.
objTrans.Init ADS_NAME_INITTYPE_GC, ""
' Use the Set method to specify the NT format of the object name.
objTrans.Set ADS_NAME_TYPE_NT4, strNTName
' Use the Get method to retrieve the RPC 1779 Distinguished Name.
strUserDN = objTrans.Get(ADS_NAME_TYPE_1779)
' Escape any "/" characters with backslash escape character.
' All other characters that need to be escaped will be escaped.
strUserDN = Replace(strUserDN, "/", "\/")
' Bind to the user object in Active Directory with the LDAP provider.
Set objUser = GetObject("LDAP://" & strUserDN)
strGroupDN = "CN=groupname,OU=ou1,OU=ou2,OU=ou3,OU=ou4,DC=domain,DC=net"
Const ADS_SECURE_AUTHENTICATION = 1
strUserDN2 = "domain\serviceaccount"
strPassword2 = "serviceaccountpassword"
Set objDSO = GetObject("LDAP:")
Set objUser2 = objDSO.OpenDSObject("LDAP://DC=domain,DC=net", strUserDN2, strPassword2, ADS_SECURE_AUTHENTICATION)
'in case user is already in group
On Error Resume Next
Set objGroup = GetObject("LDAP://"& strGroupDN)
objGroup.Add("LDAP://"& strUserDN)
ASKER
That makes sense, but now when I attempt the
objGroup.Add("LDAP://"& strUserDN)
I get the error that Object does not support this property or method "objGroup.Add"
objGroup.Add("LDAP://"& strUserDN)
I get the error that Object does not support this property or method "objGroup.Add"
ASKER
I hit Submit too soon, is there no way to edit a comment? anyway...
Using Set objGroup = objDSO.OpenDSObject("LDAP: //DC=domai n,DC=net", strUserDN2, strPassword2, ADS_SECURE_AUTHENTICATION)
how do i get the script the user and group AD information after binding this way?
Using Set objGroup = objDSO.OpenDSObject("LDAP:
how do i get the script the user and group AD information after binding this way?
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
ASKER
Thanks! I usually only use VBScript for installing things via SMS, querying AD isn't usually something I script.
MemberOf (user attribute) and member (group attribute) are linked attributes. The primary attribute is member (the group attribute), meaning that you change this attribute, not memberof. memberof will follow suit. Therefore you need to connect to the group object using OpenDSObject, as this is the object you are editing.
Instead of
Set objGroup = GetObject("LDAP://" & strGroupDN)
Use...
Set objGroup = objDSO.OpenDSObject("LDAP:
From looking at your code, I don't think you even need to connect to the user object as you're not editing it.
Please let me know if I have misunderstood.