-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathSet-AssetNumber.ps1
81 lines (71 loc) · 3.36 KB
/
Set-AssetNumber.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
80
81
<#
.SYNOPSIS
Sets AssetNumber in AirWatch for a list of SerialNumbers
.DESCRIPTION
.PARAMETER file
Path of a CSV file with a list of Serial Numbers and desired Asset Numbers. This is required.
.PARAMETER fileColumn
Column title in CSV file containing SerialNumber values. This is optional, with a default value of "SerialNumber".
.PARAMETER assetColumn
Column title in CSV file containing AssetNumber values. This is optional, with a default value of "AssetNumber".
.INPUTS
AirWatchConfig.json
Serials.csv
.OUTPUTS
NO OUTPUT CURRENTLY:Outputs a CSV log of actions
.NOTES
Version: 1.6
Author: Joshua Clark @MrTechGadget
Creation Date: 01/14/2020
Update Date: 10/13/2022
Site: https://github.com/MrTechGadget/aw-bulkdevices-script
.EXAMPLE
.\Set-AssetNumber.ps1 -file "Devices.csv" -fileColumn "SerialNumber" -assetColumn "AssetNumber"
#>
[CmdletBinding()]
Param(
[Parameter(Mandatory=$True,Position=0,ValueFromPipeline=$true,HelpMessage="Path to file listing SerialNumbers.")]
[string]$file,
[Parameter(HelpMessage="Name of Id column in file, default is SerialNumber")]
[string]$fileColumn = "SerialNumber",
[Parameter(HelpMessage="Name of desired asset column in file, default is AssetNumber")]
[string]$assetColumn = "AssetNumber"
)
Import-Module .\PSairwatch.psm1
Write-Log -logstring "$($MyInvocation.Line)"
$Logfile = "$PSScriptRoot\AssetNumber.log"
$list = Read-FileWithData $file $fileColumn $assetColumn
Write-Log -logstring "$($MyInvocation.Line)" -logfile $Logfile
$decision = $Host.UI.PromptForChoice(
"Attention! If you proceed, " + @($list).count + " devices will have their AssetNumber overwritten in AirWatch",
"",
@('&Yes', '&No'), 1)
if ($decision -eq 0) {
Write-Log -logstring "Replacing asset numbers on $($list.count) devices in AirWatch" -logfile $Logfile
$i = 0
foreach ($item in $list) {
$i++
Write-Progress -Activity "Editing Devices..." -Status "$($i) of $($list.Count)" -CurrentOperation "$($item.$fileColumn) : $($item.$assetColumn)" -PercentComplete ((($i)/(@($list).Count))*100)
$endpointURL = "mdm/devices?searchBy=Serialnumber&id=$($item.$fileColumn)"
$json = @{AssetNumber=$item.$assetColumn} | ConvertTo-Json
try {
$result = Send-Put -endpoint $endpointURL -body $json -version $version1
if ($result -ne "") {
$err = ($Error[0].ErrorDetails.Message | ConvertFrom-Json)
Write-Warning ("Error Setting AssetNumber: $($item.$fileColumn) : Error", $err.errorCode, $err.message)
Write-Log -logstring ("Error Setting AssetNumber: $($item.$fileColumn) : Error", $err.errorCode, $err.message) -logfile $Logfile
} else {
Write-Host "$($item.$fileColumn) set to $($item.$assetColumn) $result"
Write-Log -logstring "$($item.$fileColumn) set to $($item.$assetColumn) $result" -logfile $Logfile
}
}
catch {
$err2 = ($Error[0].ErrorDetails.Message)
Write-Warning "Error Setting AssetNumber: $($item.$fileColumn) to $($item.$assetColumn) $err2"
Write-Log -logstring "Error Setting AssetNumber: $($item.$fileColumn) to $($item.$assetColumn) $err2" -logfile $Logfile
}
}
} else {
Write-Host "Action Cancelled"
Write-Log -logstring "Action Cancelled" -logfile $Logfile
}