-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathLoadComputers.ps1
79 lines (67 loc) · 2.31 KB
/
LoadComputers.ps1
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# Script to import computer information from a .csv file and
# load the info into the MDT database
#
# Script requires the MDTDB.psm1 writen by Michael Niehaus and assumes
# that it is located in the same directory.
#
# Written by Vaughn Miller
#Import the module that allows us to interact with MDT
Import-Module -name .\MDTDB.psm1
#Open a connection to our database
Connect-MDTDatabase -sqlServer deploy.example.com -instance ADSQL -database msdeploy
#Read in the csv file
$machines = Import-Csv .\computers.csv
#Set up the log file information and initialize counters
$date = get-date -format MMddyyHHmmss
$logfile = ".\logs\Import"+$date+".log"
$validrecords = 0
$invalidrecords = 0
#Loop through each record from the file and process the information
For ($i=1; $i -le $machines.count; $i++)
{
$machines[$i-1].mac=$machines[$i-1].mac.ToUpper()
$macvalid=$TRUE
$temp = $machines[$i-1].mac.Split(":")
if (($temp.count -ne 6) -or ($machines[$i-1].mac.length -ne 17))
{ $macvalid = $FALSE
}
$namevalid=$TRUE
if ($machines[$i-1].name.length -gt 15)
{ $namevalid=$FALSE
}
if ($namevalid -and $macvalid)
{
$validrecords=$validrecords+1
$machineid=Get-MDTComputer -macAddress $machines[$i-1].mac
if ($machineid.id -gt 0)
{
Remove-MDTComputer $machineid.id
}
New-MDTComputer -macAddress $machines[$i-1].mac -description $machines[$i-1].name -settings @{
OSInstall='YES';
OSDComputerName=$machines[$i-1].name;
AdminPassword=$machines[$i-1].password;
}
$machineid=Get-MDTComputer -macAddress $machines[$i-1].mac
Set-MDTComputerRole $machineid.id $machines[$i-1].role
}
else
{ #log the invalid record
$invalidrecords=$invalidrecords+1
$text = "Invalid Record : "+$i+" "+$machines[$i-1].mac+" "+$machines[$i-1].name
$text >> $logfile
}
}
#Some closing information for the logfile
" " >> $logfile
$text="Total records processed = "+($invalidrecords+$validrecords)
$text>>$logfile
$text="Invalid records = "+$invalidrecords
$text>>$logfile
$text="Valid records = "+$validrecords
$text>>$logfile
#Let the user know the script is finished and where the log file is
" "
" "
"Script execution Complete"
"Check "+$logfile+" "+"for invalid records"