forked from microsoft/nav-arm-templates
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathStartDockerAgent.ps1
97 lines (83 loc) · 5.29 KB
/
StartDockerAgent.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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
Param(
[string] $AgentName = "Manual"
)
$erroractionpreference = "Stop"
. (Join-Path $PSScriptRoot "settings.ps1")
[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.SecurityProtocolType]::Ssl3 -bor [System.Net.SecurityProtocolType]::Tls -bor [System.Net.SecurityProtocolType]::Ssl3 -bor [System.Net.SecurityProtocolType]::Tls11 -bor [System.Net.SecurityProtocolType]::Tls12
[Reflection.Assembly]::LoadWithPartialName("System.IO.Compression.Filesystem") | Out-Null
$navDockerUrl = "https://github.com/Microsoft/nav-docker/archive/master.zip"
$tempFolder = Join-Path ([System.IO.Path]::GetTempPath()) ([System.Guid]::NewGuid().ToString())
$tempFile = "$tempFolder.zip"
$secureStorageAccountKey = ConvertTo-SecureString -String $StorageAccountKey -Key $passwordKey
$plainStorageAccountKey = [System.Runtime.InteropServices.Marshal]::PtrToStringAuto([System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($secureStorageAccountKey))
$storageContext = New-AzureStorageContext -StorageAccountName $StorageAccountName -StorageAccountKey $plainStorageAccountKey
$azureQueue = Get-AzureStorageQueue -Name $queue -Context $storageContext -ErrorAction Ignore
if (!($azureQueue)) {
New-AzureStorageQueue –Name $queue –Context $storageContext -ErrorAction Ignore | Out-Null
}
$azureQueue = Get-AzureStorageQueue -Name $queue -Context $storageContext -ErrorAction Ignore
$table = Get-AzureStorageTable –Name "QueueStatus" –Context $storageContext -ErrorAction Ignore
if (!($table)) {
New-AzureStorageTable –Name "QueueStatus" –Context $storageContext -ErrorAction Ignore | Out-Null
}
$table = Get-AzureStorageTable –Name "QueueStatus" –Context $storageContext
while ($true) {
$message = $azureQueue.CloudQueue.GetMessage([TimeSpan]::FromHours(2))
if (!($message)) {
break
}
$transcriptname = ([Guid]::NewGuid().ToString()+".txt")
$transcriptfilename = "c:\agent\$transcriptname"
$transcripting = $false
try {
if (!(Test-Path $tempFolder -PathType Container)) {
New-Item -ItemType Directory -Path $tempFolder | out-null
(New-Object System.Net.WebClient).DownloadFile($navDockerUrl, $tempFile)
[System.IO.Compression.ZipFile]::ExtractToDirectory($tempFile, $tempFolder)
}
$navDockerPath = Join-Path $tempFolder "nav-docker-master"
$json = $message.AsString | ConvertFrom-Json
$ht = @{ "vmName" = $vmName
"Queue" = $queue
"Task" = $json.task
"navversion" = $json.navversion
"cu" = $json.cu
"Country" = $json.country
"Dequeue" = $message.DequeueCount
"version" = $json.version
"transcript" = ""
}
Add-StorageTableRow -table $table -partitionKey $AgentName -rowKey ([string]::Format("{0:D19}", [DateTime]::MaxValue.Ticks - [DateTime]::UtcNow.Ticks)) -property (@{"Status" = "Build"} + $ht) | Out-Null
Start-Transcript -Path $transcriptfilename
$transcripting = $true
Write-Host '---------------------------'
Write-Host $message.AsString
Write-Host '---------------------------'
. (Join-Path $navDockerPath "$($json.task)\build.ps1") -json $json
$transcripting = $false
Stop-Transcript
Set-AzureStorageBlobContent -File $transcriptfilename -Context $storageContext -Container $json.blobcontainer -Blob $transcriptname -Force | Out-Null
$ht.transcript = "https://$StorageAccountName.blob.core.windows.net/$($json.blobContainer)/$transcriptname"
Add-StorageTableRow -table $table -partitionKey $AgentName -rowKey ([string]::Format("{0:D19}", [DateTime]::MaxValue.Ticks - [DateTime]::UtcNow.Ticks)) -property (@{"Status" = "Success"} + $ht) | Out-Null
$azureQueue.CloudQueue.DeleteMessage($message)
. (Join-Path $navDockerPath "$($json.task)\cleanup.ps1") -Context $storageContext -json $json
} catch {
if ($transcripting) {
Stop-Transcript
}
Set-AzureStorageBlobContent -File $transcriptfilename -Context $storageContext -Container $json.blobcontainer -Blob $transcriptname -Force | Out-Null
$ht.transcript = "https://$StorageAccountName.blob.core.windows.net/$($json.blobContainer)/$transcriptname"
if ($message.DequeueCount -eq 10) {
Add-StorageTableRow -table $table -partitionKey $AgentName -rowKey ([string]::Format("{0:D19}", [DateTime]::MaxValue.Ticks - [DateTime]::UtcNow.Ticks)) -property (@{"Status" = "Fail"} + $ht) | Out-Null
$azureQueue.CloudQueue.DeleteMessage($message)
. (Join-Path $navDockerPath "$($json.task)\cleanup.ps1") -Context $storageContext -json $json
} else {
Add-StorageTableRow -table $table -partitionKey $AgentName -rowKey ([string]::Format("{0:D19}", [DateTime]::MaxValue.Ticks - [DateTime]::UtcNow.Ticks)) -property (@{"Status" = "Retry"} + $ht) | Out-Null
Start-Sleep -Seconds 60
}
} finally {
Remove-Item -Path $tempFolder -Recurse -Force -ErrorAction Ignore
Remove-Item -Path $tempFile -Force -ErrorAction Ignore
Remove-Item -Path $transcriptfilename -Force -ErrorAction Ignore
}
}