Solved

Moving Computers from one OU to another OU

Posted on 2003-11-17
5
612 Views
Last Modified: 2008-01-16
Hello All
I am trying to move a computer object in AD from one OU to another ou and I keep getting the below error.  I am pulling the Ldap Path (target and destination) and the computername from a text file.  

C:\Support\movecomputer.vbs(28, 1) Microsoft VBScript runtime error: Wrong numbe
r of arguments or invalid property assignment: 'objNewOU.MoveHere'

Below is the Script
Set oCmdArgs = CreateObject("MTP.CmdArgs")

oCmdArgs.FromCollection(wscript.Arguments)
chnglist2 = oCmdArgs(0).Text
oCmdArgs.Reset
Set oStream = CreateObject("Scripting.FilesystemObject").OpenTextFile(chnglist2)
oCmdArgs.FromStream(oStream)

For ix = 0 To (oCmdArgs.Count - 1)
' Wscript.echo "Arg " & ix & ": " & oCmdArgs(ix).Text
'parses the test file and assigns variables for each value
sArray = Split(oCmdArgs(ix).Text, ";")
Computername = sArray(0)
ADSPath = sArray(1)
targetadspath = sArray(2)

'Wscript.echo targetadspath


Set objNewOU = GetObject("LDAP://" & targetadspath & "")


Set objMoveComputer = objNewOU.MoveHere("LDAP://CN=" & Computername & "," & ADSPath & ", " & """" & Computername & """")
Next
0
Comment
Question by:magsdtev
5 Comments
 
LVL 3

Expert Comment

by:tim_mcgue
Comment Utility
This method takes two parameters.  See this article:

http://msdn.microsoft.com/library/default.asp?url=/library/en-us/netdir/adsi/iadscontainer_movehere.asp

It looks like you want to replace your second to last line with this:

Set objMoveComputer = objNewOU.MoveHere("LDAP://CN=" & Computername & "," & ADSPath, "CN=" & Computername)

or this:
Set objMoveComputer = objNewOU.MoveHere("LDAP://CN=" & Computername & "," & ADSPath, vbNullString)
0
 

Author Comment

by:magsdtev
Comment Utility
Tim
Thanks for the response.  I tried the above with no sucess.  After alot of research I found that the below worked

Set oCmdArgs = CreateObject("MTP.CmdArgs")

oCmdArgs.FromCollection(wscript.Arguments)
chnglist2 = oCmdArgs(0).Text
oCmdArgs.Reset
Set oStream = CreateObject("Scripting.FilesystemObject").OpenTextFile(chnglist2)
oCmdArgs.FromStream(oStream)
'Gets the text file and parses it
For ix = 0 To (oCmdArgs.Count - 1)
'      Wscript.echo "Arg " & ix & ": " & oCmdArgs(ix).Text
      'parses the test file and assigns variables for each value
      sArray = Split(oCmdArgs(ix).Text, ";")      
      Computername = sArray(0)
      srcADSPath = sArray(1)
      targetadspath = sArray(2)

Set objNewOU = GetObject("LDAP://" & targetadspath)
Set objsrcOU = GetObject("LDAP://CN=" & Computername & "," & srcADSPath)

Wscript.echo Computername

'Set objMoveComputer = objNewOU.MoveHere("LDAP://CN=" & Computername & "," & ADSPath & ", CN=" & Computername)

objNewOU.MoveHere objsrcOU.ADsPath, objsrcOU.Name

Next
0
 
LVL 49

Expert Comment

by:DanRollins
Comment Utility
magsdtev, an EE Moderator will handle this for you.
Moderator, my recommended disposition is:

    Refund points and save as a 0-pt PAQ.

Dan Rollins -- EE database cleanup volunteer
0
 

Accepted Solution

by:
CetusMOD earned 0 total points
Comment Utility
PAQed, with points refunded (200)

CetusMOD
Community Support Moderator
0

Featured Post

Why You Should Analyze Threat Actor TTPs

After years of analyzing threat actor behavior, it’s become clear that at any given time there are specific tactics, techniques, and procedures (TTPs) that are particularly prevalent. By analyzing and understanding these TTPs, you can dramatically enhance your security program.

Join & Write a Comment

When designing a form there are several BorderStyles to choose from, all of which can be classified as either 'Fixed' or 'Sizable' and I'd guess that 'Fixed Single' or one of the other fixed types is the most popular choice. I assume it's the most p…
Article by: Martin
Here are a few simple, working, games that you can use as-is or as the basis for your own games. Tic-Tac-Toe This is one of the simplest of all games.   The game allows for a choice of who goes first and keeps track of the number of wins for…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…

762 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

8 Experts available now in Live!

Get 1:1 Help Now