#
.SYNOPSIS
GPO Deployment Script for Secure Boot Event Collection
Creates and links a GPO to deploy the collection script as a scheduled task
.DESCRIPTION
This script automates the deployment of Secure Boot event collection via Group Policy.
It creates a GPO with:
- A scheduled task that runs the collection script daily
- Proper permissions for writing to the central share
- WMI filters for targeting specific OS versions
.PARAMETER GPOName
Name for the new GPO
.PARAMETER DomainName
Target domain FQDN
.PARAMETER OUPath
Distinguished Name of the OU(s) to link the GPO to.
Accepts multiple OUs as an array. Not required if -AutoDetectOU is specified.
.PARAMETER AutoDetectOU
Switch to interactively list and select OUs from Active Directory.
When specified, -OUPath is optional.
.PARAMETER CollectionSharePath
UNC path where collection results will be stored
.PARAMETER ScriptSourcePath
Path where the collection script is stored (will be copied to SYSVOL)
.PARAMETER RandomDelayHours
Number of hours to randomly spread script execution across endpoints.
This prevents all machines from writing to the share simultaneously.
Default: 4 hours. Valid range: 1-24 hours.
Recommended values:
- 1-10K devices: 4 hours (default)
- 10K-50K devices: 8 hours
- 50K+ devices: 12-24 hours
.EXAMPLE
.\Deploy-GPO-SecureBootCollection.ps1 -DomainName "contoso.com" -OUPath "OU=Workstations,DC=contoso,DC=com"
.EXAMPLE
.\Deploy-GPO-SecureBootCollection.ps1 -DomainName "contoso.com" -OUPath "OU=Workstations,DC=contoso,DC=com" -RandomDelayHours 8
.EXAMPLE
.\Deploy-GPO-SecureBootCollection.ps1 -DomainName "contoso.com" -AutoDetectOU
Lists all OUs in the domain and prompts for selection.
.EXAMPLE
.\Deploy-GPO-SecureBootCollection.ps1 -DomainName "contoso.com" -OUPath @("OU=Workstations,DC=contoso,DC=com", "OU=Laptops,DC=contoso,DC=com")
Links GPO to multiple OUs in a single run.
.NOTES
Requires: Active Directory PowerShell module, Group Policy module
Must be run with Domain Admin or delegated GPO creation rights
#>
[CmdletBinding()]
param(
[Parameter(Mandatory = $false)]
[string]$GPOName = "SecureBoot-EventCollection",
[Parameter(Mandatory = $false)]
[string]$DomainName,
[Parameter(Mandatory = $false)]
[string[]]$OUPath,
[Parameter(Mandatory = $false)]
[switch]$AutoDetectOU,
[Parameter(Mandatory = $false)]
[string]$CollectionSharePath = "\\$DomainName\NETLOGON\SecureBootLogs",
[Parameter(Mandatory = $false)]
[string]$ScriptSourcePath = ".\Detect-SecureBootCertUpdateStatus.ps1",
[Parameter(Mandatory = $false)]
[ValidateSet("Daily", "Weekly", "AtStartup")]
[string]$Schedule = "Daily",
[Parameter(Mandatory = $false)]
[string]$ScheduleTime = "14:00",
[Parameter(Mandatory = $false)]
[ValidateRange(1, 24)]
[int]$RandomDelayHours = 4
)
#Requires -Modules ActiveDirectory, GroupPolicy
#Requires -Version 5.1
$ErrorActionPreference = "Stop"
$DownloadUrl = "https://aka.ms/getsecureboot"
$DownloadSubPage = "Deployment and Monitoring Samples"
# ============================================================================
# DEPENDENCY VALIDATION
# ============================================================================
function Test-ScriptDependencies {
param(
[Parameter(Mandatory = $true)]
[string]$ScriptDirectory,
[Parameter(Mandatory = $true)]
[string[]]$RequiredScripts
)
$missingScripts = @()
foreach ($script in $RequiredScripts) {
$scriptPath = Join-Path $ScriptDirectory $script
if (-not (Test-Path $scriptPath)) {
$missingScripts += $script
}
}
if ($missingScripts.Count -gt 0) {
Write-Host ""
Write-Host ("=" * 70) -ForegroundColor Red
Write-Host " MISSING DEPENDENCIES" -ForegroundColor Red
Write-Host ("=" * 70) -ForegroundColor Red
Write-Host ""
Write-Host "The following required scripts were not found:" -ForegroundColor Yellow
foreach ($script in $missingScripts) {
Write-Host " - $script" -ForegroundColor White
}
Write-Host ""
Write-Host "Please download the latest scripts from:" -ForegroundColor Cyan
Write-Host " URL: $DownloadUrl" -ForegroundColor White
Write-Host " Navigate to: '$DownloadSubPage'" -ForegroundColor White
Write-Host ""
Write-Host "Extract all scripts to the same directory and run again." -ForegroundColor Yellow
Write-Host ""
return $false
}
return $true
}
# The Detect script is required - it gets deployed to endpoints via GPO
$requiredScripts = @(
"Detect-SecureBootCertUpdateStatus.ps1"
)
if (-not (Test-ScriptDependencies -ScriptDirectory $PSScriptRoot -RequiredScripts $requiredScripts)) {
exit 1
}
# ============================================================================
# AUTO-DETECT DOMAIN NAME
# ============================================================================
if (-not $DomainName) {
$DomainName = $env:USERDNSDOMAIN
if (-not $DomainName) {
# Try to get from AD module
try {
Import-Module ActiveDirectory -ErrorAction Stop
$DomainName = (Get-ADDomain).DNSRoot
} catch {
Write-Host "ERROR: Could not auto-detect domain name." -ForegroundColor Red
Write-Host "Please specify -DomainName parameter." -ForegroundColor Yellow
Write-Host ""
Write-Host "Example:" -ForegroundColor Gray
Write-Host " .\Deploy-GPO-SecureBootCollection.ps1 -DomainName contoso.com -AutoDetectOU" -ForegroundColor White
exit 1
}
}
Write-Host "Auto-detected domain: $DomainName" -ForegroundColor Green
}
# Set CollectionSharePath default if not explicitly provided
if (-not $PSBoundParameters.ContainsKey('CollectionSharePath')) {
$CollectionSharePath = "\\$DomainName\NETLOGON\SecureBootLogs"
}
Write-Host "============================================" -ForegroundColor Cyan
Write-Host "Secure Boot Collection - GPO Deployment" -ForegroundColor Cyan
Write-Host "============================================" -ForegroundColor Cyan
# Validate prerequisites
Write-Host "`n[1/6] Validating prerequisites..." -ForegroundColor Yellow
if (-not (Get-Module -ListAvailable -Name ActiveDirectory)) {
throw "ActiveDirectory module not found. Install RSAT tools."
}
if (-not (Get-Module -ListAvailable -Name GroupPolicy)) {
throw "GroupPolicy module not found. Install RSAT tools."
}
Import-Module ActiveDirectory
Import-Module GroupPolicy
# Validate domain connectivity
try {
$domain = Get-ADDomain -Server $DomainName
Write-Host " Connected to domain: $($domain.DNSRoot)" -ForegroundColor Green
} catch {
throw "Cannot connect to domain: $DomainName. Error: $_"
}
# Handle OU selection
if ($AutoDetectOU) {
Write-Host "`n Discovering OUs in domain..." -ForegroundColor Cyan
$allOUs = Get-ADOrganizationalUnit -Filter * -Server $DomainName |
Sort-Object DistinguishedName |
Select-Object @{N='Index';E={0}}, Name, DistinguishedName
# Assign indices
for ($i = 0; $i -lt $allOUs.Count; $i++) {
$allOUs[$i].Index = $i + 1
}
Write-Host "`n Available OUs:" -ForegroundColor Yellow
Write-Host " ---------------------------------------------------------------------" -ForegroundColor DarkGray
$allOUs | ForEach-Object {
Write-Host (" {0,3}) {1}" -f $_.Index, $_.DistinguishedName) -ForegroundColor White
}
Write-Host " ---------------------------------------------------------------------" -ForegroundColor DarkGray
Write-Host " Tip: Enter comma-separated numbers to select multiple OUs (e.g., 1,3,5)" -ForegroundColor DarkGray
Write-Host " Enter 'A' to select ALL OUs" -ForegroundColor DarkGray
Write-Host ""
$selection = Read-Host " Select OU(s) to link GPO"
if ($selection -eq 'A' -or $selection -eq 'a') {
$OUPath = $allOUs.DistinguishedName
Write-Host " Selected ALL $($OUPath.Count) OUs" -ForegroundColor Green
} else {
$indices = $selection -split ',' | ForEach-Object { [int]$_.Trim() }
$OUPath = @()
foreach ($idx in $indices) {
$selected = $allOUs | Where-Object { $_.Index -eq $idx }
if ($selected) {
$OUPath += $selected.DistinguishedName
} else {
Write-Warning "Invalid index: $idx - skipping"
}
}
}
if ($OUPath.Count -eq 0) {
throw "No OUs selected. Aborting."
}
Write-Host "`n Selected $($OUPath.Count) OU(s):" -ForegroundColor Green
$OUPath | ForEach-Object { Write-Host " - $_" -ForegroundColor Gray }
} elseif (-not $OUPath -or $OUPath.Count -eq 0) {
throw "Either -OUPath or -AutoDetectOU must be specified."
} else {
# Validate each OU exists
foreach ($path in $OUPath) {
try {
$ou = Get-ADOrganizationalUnit -Identity $path -Server $DomainName
Write-Host " Target OU found: $($ou.Name)" -ForegroundColor Green
} catch {
throw "OU not found: $path"
}
}
}
# Validate source script exists
if (-not (Test-Path $ScriptSourcePath)) {
throw "Collection script not found: $ScriptSourcePath"
}
# Step 2: Create collection share structure
Write-Host "`n[2/6] Setting up collection share..." -ForegroundColor Yellow
$sysvolScriptPath = "\\$DomainName\SYSVOL\$DomainName\Scripts\SecureBootCollection"
# Create SYSVOL script folder
if (-not (Test-Path $sysvolScriptPath)) {
New-Item -ItemType Directory -Path $sysvolScriptPath -Force | Out-Null
Write-Host " Created SYSVOL script folder: $sysvolScriptPath" -ForegroundColor Green
}
# Copy collection script to SYSVOL
$destScript = Join-Path $sysvolScriptPath "Detect-SecureBootCertUpdateStatus.ps1"
# Remove existing destination if it's a directory (fix for Copy-Item bug)
if (Test-Path $destScript -PathType Container) {
Remove-Item $destScript -Recurse -Force
}
Copy-Item -Path $ScriptSourcePath -Destination $destScript -Force
Write-Host " Copied collection script to SYSVOL" -ForegroundColor Green
# Create a wrapper script that calls the main script with parameters
$wrapperScript = @"
# Secure Boot Event Collection Wrapper
# Auto-generated by Deploy-GPO-SecureBootCollection.ps1
`$ErrorActionPreference = 'SilentlyContinue'
# Configuration
`$CollectionShare = '$CollectionSharePath'
`$ScriptPath = '$sysvolScriptPath\Detect-SecureBootCertUpdateStatus.ps1'
# Run collection with -OutputPath parameter
if (Test-Path `$ScriptPath) {
& `$ScriptPath -OutputPath `$CollectionShare
} else {
Write-EventLog -LogName Application -Source "SecureBootCollection" -EventId 1001 -EntryType Error -Message "Collection script not found: `$ScriptPath"
}
"@
$wrapperPath = Join-Path $sysvolScriptPath "Run-SecureBootCollection.ps1"
$wrapperScript | Out-File -FilePath $wrapperPath -Encoding UTF8 -Force
Write-Host " Created wrapper script" -ForegroundColor Green
# Create collection share (if on a file server)
Write-Host " Collection share path: $CollectionSharePath" -ForegroundColor Cyan
Write-Host " NOTE: Ensure this share exists with 'Domain Computers' write access" -ForegroundColor Yellow
# Step 3: Create the GPO
Write-Host "`n[3/6] Creating Group Policy Object..." -ForegroundColor Yellow
# Check if GPO already exists
$existingGPO = Get-GPO -Name $GPOName -Domain $DomainName -ErrorAction SilentlyContinue
if ($existingGPO) {
Write-Host " GPO '$GPOName' already exists. Updating..." -ForegroundColor Yellow
$gpo = $existingGPO
} else {
$gpo = New-GPO -Name $GPOName -Domain $DomainName -Comment "Deploys Secure Boot event collection script to endpoints"
Write-Host " Created GPO: $GPOName" -ForegroundColor Green
}
# Step 4: Configure Scheduled Task via GPO Preferences
Write-Host "`n[4/6] Configuring scheduled task..." -ForegroundColor Yellow
# Build the scheduled task XML
# RandomDelay spreads execution across endpoints to prevent server overload
Write-Host " Random delay: $RandomDelayHours hours (spreads load across fleet)" -ForegroundColor Cyan
$taskTrigger = switch ($Schedule) {
"Daily" {
@"
2024-01-01T${ScheduleTime}:00
true
1
PT${RandomDelayHours}H
"@
}
"Weekly" {
@"
2024-01-01T${ScheduleTime}:00
true
1
PT${RandomDelayHours}H
"@
}
"AtStartup" {
# For startup triggers, use Delay to add random start time
# Each machine will start between 5 and (5 + RandomDelayHours*60) minutes after boot
$maxDelayMinutes = 5 + ($RandomDelayHours * 60)
@"
true
PT5M
PT${RandomDelayHours}H
"@
}
}
$scheduledTaskXML = @"
Collects Secure Boot event data for enterprise census
Enterprise Security
$taskTrigger
S-1-5-18
HighestAvailable
IgnoreNew
false
false
true
true
true
false
false
true
true
false
false
false
true
false
PT1H
7
powershell.exe
-NoProfile -ExecutionPolicy Bypass -File "$wrapperPath"
"@
# Save task XML to SYSVOL for reference/backup
$taskXmlPath = Join-Path $sysvolScriptPath "SecureBootCollection-Task.xml"
$scheduledTaskXML | Out-File -FilePath $taskXmlPath -Encoding Unicode -Force
Write-Host " Saved scheduled task XML to SYSVOL (backup)" -ForegroundColor Green
# Inject scheduled task into GPO Preferences
Write-Host " Injecting scheduled task into GPO Preferences..." -ForegroundColor Cyan
$gpoId = $gpo.Id.ToString()
$gpoPrefPath = "\\$DomainName\SYSVOL\$DomainName\Policies\{$gpoId}\Machine\Preferences\ScheduledTasks"
# Create Preferences folder structure
if (-not (Test-Path $gpoPrefPath)) {
New-Item -ItemType Directory -Path $gpoPrefPath -Force | Out-Null
}
# Generate unique GUID for the task
$taskGuid = [guid]::NewGuid().ToString("B").ToUpper()
# Build GPO Preferences ScheduledTasks.xml format
# This is different from standard Task Scheduler XML - it's GPP format
$gppScheduledTasksXml = @"
Enterprise Security
Collects Secure Boot certificate status for enterprise compliance monitoring
NT AUTHORITY\System
S4U
HighestAvailable
PT10M
PT1H
false
false
IgnoreNew
false
false
true
true
true
true
true
false
false
false
PT1H
7
$taskTrigger
powershell.exe
-NoProfile -ExecutionPolicy Bypass -File "$wrapperPath"
"@
# Write GPP ScheduledTasks.xml to GPO
$gppXmlPath = Join-Path $gpoPrefPath "ScheduledTasks.xml"
$gppScheduledTasksXml | Out-File -FilePath $gppXmlPath -Encoding UTF8 -Force
Write-Host " [OK] Scheduled task injected into GPO" -ForegroundColor Green
Write-Host " Task schedule: $Schedule at $ScheduleTime with $RandomDelayHours hour random delay" -ForegroundColor Gray
# Step 5: Link GPO to OU(s)
Write-Host "`n[5/6] Linking GPO to OU(s)..." -ForegroundColor Yellow
$linkedCount = 0
$skippedCount = 0
foreach ($targetOU in $OUPath) {
$existingLink = Get-GPInheritance -Target $targetOU -Domain $DomainName |
Select-Object -ExpandProperty GpoLinks |
Where-Object { $_.DisplayName -eq $GPOName }
if (-not $existingLink) {
New-GPLink -Name $GPOName -Target $targetOU -Domain $DomainName -LinkEnabled Yes | Out-Null
Write-Host " [OK] Linked to: $targetOU" -ForegroundColor Green
$linkedCount++
} else {
Write-Host " - Already linked: $targetOU" -ForegroundColor Yellow
$skippedCount++
}
}
Write-Host "`n Summary: $linkedCount new links, $skippedCount already existed" -ForegroundColor Cyan
# Step 6: Create WMI Filter (optional - for Windows 10/11 only)
Write-Host "`n[6/6] Creating WMI filter..." -ForegroundColor Yellow
$wmiFilterName = "Windows 10 and 11 Workstations"
$wmiQuery = 'SELECT * FROM Win32_OperatingSystem WHERE Version LIKE "10.%" AND ProductType = "1"'
Write-Host @"
[NOTE] OPTIONAL: Create WMI Filter in GPMC
Filter Name: $wmiFilterName
Query: $wmiQuery
This filters the GPO to only apply to Windows 10/11 workstations.
"@ -ForegroundColor Yellow
# Summary
Write-Host "`n============================================" -ForegroundColor Cyan
Write-Host "DEPLOYMENT COMPLETE" -ForegroundColor Green
Write-Host "============================================" -ForegroundColor Cyan
Write-Host @"
Summary:
- GPO Name: $GPOName
- Target OU: $OUPath
- Collection Share: $CollectionSharePath
- Script Location: $sysvolScriptPath
- Schedule: $Schedule at $ScheduleTime
Next Steps:
1. Create the collection share with proper permissions:
- Share: $CollectionSharePath
- Permissions: Domain Computers (Write), Domain Admins (Full)
2. Complete the scheduled task configuration in GPMC (see instructions above)
3. Run 'gpupdate /force' on a test machine to verify deployment
4. Monitor collection results in: $CollectionSharePath
5. Run aggregation script to generate reports:
.\Aggregate-SecureBootData.ps1 -InputPath "$CollectionSharePath"
"@ -ForegroundColor White
# SIG # Begin signature block
# MIIpzwYJKoZIhvcNAQcCoIIpwDCCKbwCAQExDzANBglghkgBZQMEAgEFADB5Bgor
# BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG
# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCDkaOlBD0VVm0R/
# hcG0gPPU0PF8QwchqAtFlhqhktt7BaCCDdYwgga9MIIEpaADAgECAhMzAAAAHEif
# gd+hsLd3AAAAAAAcMA0GCSqGSIb3DQEBDAUAMIGIMQswCQYDVQQGEwJVUzETMBEG
# A1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWlj
# cm9zb2Z0IENvcnBvcmF0aW9uMTIwMAYDVQQDEylNaWNyb3NvZnQgUm9vdCBDZXJ0
# aWZpY2F0ZSBBdXRob3JpdHkgMjAxMDAeFw0yNDA4MDgyMTM2MjNaFw0zNTA2MjMy
# MjA0MDFaMF8xCzAJBgNVBAYTAlVTMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9y
# YXRpb24xMDAuBgNVBAMTJ01pY3Jvc29mdCBXaW5kb3dzIENvZGUgU2lnbmluZyBQ
# Q0EgMjAyNDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAJp9a30nwXYq
# Lq7j1TT/zCtt7vxU+CCj+7BkifS/B2gXKGU7OV9SXRJGP1yFs5p6jpsYi4cYzF56
# AV0AEmmEjV8wT2lvPU5BhN3wV30HqYPIYEj5P3WXf0kXD9fvjUf1GAtXEriJ8w7A
# LNaVEm9Rs4ePA0ZsYHaCbU5kBUJQDXv76hafOcQgdFCA3I3zYtfzX2vOwx87uDOa
# CuyKORZih9c3zTf+TLC5QYLyhVMBnDXEHDOrvaw92DSyIqpdgRWpufzqDFy1egVj
# koXZhb+9pZ9heUzNXTXhOoXzexh6YzAL4flBWm+Bc1hQyESenEvBJznV+25u3h77
# jjgMUY44+WXQ4u9qddDe/U5SeAaKRvvibmi4z7QRpLvZsla0CPiOUGz00Do5sfkC
# 0EwlsSzfM3+8A9rsyFVOgWDVPzt98OJP2EoaEOq8GE9GCoN2i7/4C2FCwff1BSCT
# JWZO1Wcr2MteJE6UxGV+ihA8nN51YPKD2dYGoewrXvRzC/1HoUeSvlZf0mf9GHEt
# vvkbJVRRo6PBf0md5t87Vb1mM/fIp1eypyaxmXkgpcBwuylsOq2kSVOJ5wBPoaEs
# sJkeMcKnEuuu++UKdDHlS0DtsYjN0QnOucvTdSsdvhzKOSjJF3XVqr9f2C945LXT
# 5rxKIHUIEDBcNYU6BKDDH6rfpKOOCSilAgMBAAGjggFGMIIBQjAOBgNVHQ8BAf8E
# BAMCAYYwEAYJKwYBBAGCNxUBBAMCAQAwHQYDVR0OBBYEFB6C3w7XjLPXAjSDDtqr
# rWW5r7jsMBkGCSsGAQQBgjcUAgQMHgoAUwB1AGIAQwBBMA8GA1UdEwEB/wQFMAMB
# Af8wHwYDVR0jBBgwFoAU1fZWy4/oolxiaNE9lJBb186aGMQwVgYDVR0fBE8wTTBL
# oEmgR4ZFaHR0cDovL2NybC5taWNyb3NvZnQuY29tL3BraS9jcmwvcHJvZHVjdHMv
# TWljUm9vQ2VyQXV0XzIwMTAtMDYtMjMuY3JsMFoGCCsGAQUFBwEBBE4wTDBKBggr
# BgEFBQcwAoY+aHR0cDovL3d3dy5taWNyb3NvZnQuY29tL3BraS9jZXJ0cy9NaWNS
# b29DZXJBdXRfMjAxMC0wNi0yMy5jcnQwDQYJKoZIhvcNAQEMBQADggIBAENf+N8/
# u+mUjDtc9btoA52RBc0XVDSBMQBMqxu56hXHBwuctUWs1XBqDDMIFCHu9c6Y/UF+
# TN8EIgjnujApKYmHP4f4EM3ARSmlzrpF5ozOJx0BA5FUv1jmpdf/2ZbqpvCxlxv/
# G1R4KjrSmmqPHzs6igw3b7RTbj7BxIS8fOIkwYWQhB2fLjlg+3HSrDGPFIhpIJWV
# amMIR7a72OGonjdf45rspwqIHuynZU4avy9ruB/Rhhbwm+fMb8BMecIaTmkohx/E
# ZZ5GNWcN6oTYW3G2BM3B3YznWkl9t4shP60fMue+2ksdHGWSE8EVTdSmGUdj0jrU
# c46lGVFJISF3/MxcxnlNeP1Khyr+ZzT4Ets/I7mufpaLnLalzMR2zIuhGOAWWswe
# sbjtFzkVUFgDR2SW903I0XKlbPEA6q8epHGJ9roxh85nsEKcBNUw4Scp68KCqSpF
# BaKiyV1skd+l8U50WNePMb9Bzz0OfASal8v5sQG+DW01kN+I+RKUIbM5I50wJjiH
# ymQFNDsbobFx9I95mCEEPU7fUZ3VT/HOUVbkmX7ltIC/eQAu5GO8fu+ceETMybvb
# oxUM4dYNC+PzooUxfmC0DuKRwB21bX9+acuIBkxIm4Ed3O19w1VLoA7UNOUuJ7z6
# NQ2W/+q7cnfOPl2QVL4qlgCblUT2vmQpllV3MIIHETCCBPmgAwIBAgITMwAAASPV
# jwJDBgPuLgAAAAABIzANBgkqhkiG9w0BAQwFADBfMQswCQYDVQQGEwJVUzEeMBwG
# A1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTAwLgYDVQQDEydNaWNyb3NvZnQg
# V2luZG93cyBDb2RlIFNpZ25pbmcgUENBIDIwMjQwHhcNMjYwMzA1MTk1ODI2WhcN
# MjcwMzAzMTk1ODI2WjB0MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3Rv
# bjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0
# aW9uMR4wHAYDVQQDExVNaWNyb3NvZnQgQ29ycG9yYXRpb24wggIiMA0GCSqGSIb3
# DQEBAQUAA4ICDwAwggIKAoICAQDRofDhyqNp9ilU2DM6Ctcq1F931sSAyfMEmR3c
# E/fpq4C15SQYoNRfyQ1YXmcjtfWjaAB4Dsqr+po0Q6IXSERF31/leCtiRtPrS8/1
# T9FA9AeOUTaFYyqHRz1M4MVeTwu89ZHo9xR26SVQmOHbFWLinZzlBV9WUJxfz0TN
# MdWwAXzxnY9nln8Fn3Y0BnCXU8V3wjeCCAxoqM0v2gPG25eNn665gv7Zt3zh3vQY
# hDkb48hXJPi4DvCrpBVwCd0Iv2Sgt4qftn5STyqhdu5WWqva+pk+Sa71Db9OAy6b
# L640bGmzlUek1LAP97Ey8exl0c9azmLEQB97q4JRvhCSeejBM96a8Y6ccrrfhg/h
# ZJEOka1eIDJxCuKdZaWCec0v+V7oI3RStJu1BEcF9d4FQaDSaWDAbDxqXUm1fHUJ
# 9Xqky1yftpTfKFw3/gqsyXV44PE7EVHwwTCAGE5Z+skXRt4HEHuIhcOGxIFbH3nA
# l5KvFxopRs2zExvh2WheW8Pu79sr3baamlQA2v4k9FqJl4k1RfwO5e0/9CKyDZ6c
# ck/lV8zHM7PJtNtQUHc1FoyZ78GSlX6UFiJxDWzUzPbIHMcV4PSBV8/O7bs5h/bx
# r3B4PxjIpWUztZhzXBhU9vhUjQgOX5ZLV7bmSJ+IrxtaN+5w2Nsewt9N+mfUUFyK
# Av38uQIDAQABo4IBrzCCAaswDgYDVR0PAQH/BAQDAgeAMB8GA1UdJQQYMBYGCisG
# AQQBgjc9BgEGCCsGAQUFBwMDMAwGA1UdEwEB/wQCMAAwHQYDVR0OBBYEFNlj7H2k
# ZtpiMmz55wigojWkWZZSMEUGA1UdEQQ+MDykOjA4MR4wHAYDVQQLExVNaWNyb3Nv
# ZnQgQ29ycG9yYXRpb24xFjAUBgNVBAUTDTIzMDg2NSs1MDY5NTYwHwYDVR0jBBgw
# FoAUHoLfDteMs9cCNIMO2qutZbmvuOwwagYDVR0fBGMwYTBfoF2gW4ZZaHR0cDov
# L3d3dy5taWNyb3NvZnQuY29tL3BraW9wcy9jcmwvTWljcm9zb2Z0JTIwV2luZG93
# cyUyMENvZGUlMjBTaWduaW5nJTIwUENBJTIwMjAyNC5jcmwwdwYIKwYBBQUHAQEE
# azBpMGcGCCsGAQUFBzAChltodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3Bz
# L2NlcnRzL01pY3Jvc29mdCUyMFdpbmRvd3MlMjBDb2RlJTIwU2lnbmluZyUyMFBD
# QSUyMDIwMjQuY3J0MA0GCSqGSIb3DQEBDAUAA4ICAQAu6aVarz1Rb5/9eAD9oHOw
# QS4jDknbBYnDwLcgMy/h995knuPL6/5K0XSUICUrjU3/bL56UD1tVwXsRehrHMkR
# kgOMQk+7eH+Xvp6cyyTxwgIM7xy5YSf3VmJD3GI87lkGUqPFFOqGWjzZc3e/UQU7
# VbN4Elh4zJeKOdokXNuE3a5U1lAr1hnD6WpfIHO2nzGUHVSXDLMktWKMO89pMgLh
# 6BXHdx1cAth+ugl86sdXC+VxCQJ28a2JvNq5RQcEBEuqSISe3/YRWYRTSLqhn8ea
# v4lK4n+3fnAy2bmz76Z7UJ92X5KgTaHD+r8cvXmssFH3UbOj6EtE+c4SPNaFdIUW
# GJyZBhLbThhlh1QlbTg0X47GhI89qZ/lxuYeEDYbPGaDry/KpMoUQxU+l49iQ6zd
# kWSPGczB4ZDVRSrkDqz2K70tIvFaz8YfMhzTy5hhMNGvonCcguaFTgUsxr+OrvGC
# WadOV/pZ3BcRafKvBDX+ney3HFcUByI3VPzIU7saoUbcujqTVA6GeNSybo8AI+71
# 9omBObyf2lriZb9a2/oVe5SiKhH/BDQVn+14Q26UxrUA/8zVOlzJS5eJQYhkHM9h
# /Y2Nnmr2xLtFN0vW/aad7i104dVRaTLMBzbKIlCBOruBjM87frQc2Ncfb5Kme4u9
# o6GQVZf3kVy+p8uv8YgnQTGCG08wghtLAgEBMHYwXzELMAkGA1UEBhMCVVMxHjAc
# BgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEwMC4GA1UEAxMnTWljcm9zb2Z0
# IFdpbmRvd3MgQ29kZSBTaWduaW5nIFBDQSAyMDI0AhMzAAABI9WPAkMGA+4uAAAA
# AAEjMA0GCWCGSAFlAwQCAQUAoIH6MBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEE
# MC8GCSqGSIb3DQEJBDEiBCB5Z/DqeZfULmSNLNDIQleqZPMALJBeLpWxBgPRUW2W
# GTBQBgorBgEEAYI3CgMcMUIMQDRBNjhBQkREQjA1RkVBRThCRDgyMkM1NjlBMUMw
# OTFGMzI2Q0JBMUQ2MjNFODYxMEI3RUZCRDdDODc0QUM3MTkwWgYKKwYBBAGCNwIB
# DDFMMEqgJIAiAE0AaQBjAHIAbwBzAG8AZgB0ACAAVwBpAG4AZABvAHcAc6EigCBo
# dHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vd2luZG93czANBgkqhkiG9w0BAQEFAASC
# AgBu15TOpdv4a2bnoVmNYNLPn3kBUF7ubu9CYaXzsWO0NwQmPxpA+wQO4nQ4s2Cu
# bb813iMDxnIINnBVnEdLwPiar6WlUjYjX6XeAXSuUKvOamn2e0ySYvmDuchigRPn
# dx4avEi5iGzfKA5a8I3wjWcq9wS5pcX9r7UyDLUBg2CPIH/Fal7Er0Fa0QrAKFTl
# XEKcVtWOGaddlUwI7qfaKgx7ltO3DtEqtv31MCVBR+RmElxnicykaaicw+IcuoH3
# 736kXye1QNBW8+ThkzpuahX3uYME37bzIiKdWxuz1+8YYPAxUjIroIglV4aV8hZx
# powIeMn2eo8PGoqJZFKB2X+TpBI+k7kt5fBQuRiAOxE1BqDBcZ+g7A6RHGq98wrU
# ocoCNyC8Bb9O3dmD35iviirQzAyy/V7UHLYH18Vr32PPc3PGnD23ozhQc+gR3mKa
# hl/5+qdR5oJkFGC46zvvi8cQQ0Z3G15M1F+1nkxd7doAXIcU+fKdvvSeCatmoYhe
# wUHJEJQ0Cq1n/WeluvXPSNakJRt2LX/xTchBJUq/0YthAa+sSi7t3BaBb8eydygz
# YPzECj0W0kgQMztNcn0oGwRBRQtWeyWK2l+blgEUOhfFG4jtGf/u/AQaDQXDWG2d
# 8GA7MBGWhJqyShPlH9vxFJfmNKLD2gNqVn8NG8YoduM7AKGCF60wghepBgorBgEE
# AYI3AwMBMYIXmTCCF5UGCSqGSIb3DQEHAqCCF4YwgheCAgEDMQ8wDQYJYIZIAWUD
# BAIBBQAwggFaBgsqhkiG9w0BCRABBKCCAUkEggFFMIIBQQIBAQYKKwYBBAGEWQoD
# ATAxMA0GCWCGSAFlAwQCAQUABCCpm7T6Z3/eHlsNbSEYwFRjdudVBz3jrVtyPACl
# cdU86AIGaewOOPO3GBMyMDI2MDUwNjE1NDA0OS44MTRaMASAAgH0oIHZpIHWMIHT
# MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVk
# bW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQLEyRN
# aWNyb3NvZnQgSXJlbGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJzAlBgNVBAsTHm5T
# aGllbGQgVFNTIEVTTjo1MjFBLTA1RTAtRDk0NzElMCMGA1UEAxMcTWljcm9zb2Z0
# IFRpbWUtU3RhbXAgU2VydmljZaCCEfswggcoMIIFEKADAgECAhMzAAACF3H7LqWv
# AR3qAAEAAAIXMA0GCSqGSIb3DQEBCwUAMHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQI
# EwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3Nv
# ZnQgQ29ycG9yYXRpb24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBD
# QSAyMDEwMB4XDTI1MDgxNDE4NDgyM1oXDTI2MTExMzE4NDgyM1owgdMxCzAJBgNV
# BAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4w
# HAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xLTArBgNVBAsTJE1pY3Jvc29m
# dCBJcmVsYW5kIE9wZXJhdGlvbnMgTGltaXRlZDEnMCUGA1UECxMeblNoaWVsZCBU
# U1MgRVNOOjUyMUEtMDVFMC1EOTQ3MSUwIwYDVQQDExxNaWNyb3NvZnQgVGltZS1T
# dGFtcCBTZXJ2aWNlMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAwM82
# sEw+39vYR7iGCIFDnYNhRM+BzF2AYiq5dUpZpJFPRjCcipQ6RUbI+RAYNRApExx5
# ygrXbaWtuwvqsqAVSWbU/W6fecujjILkPqn9pngtWRkfQgbYgvaXALl6PY2yOH9f
# 72MD+6AyxQenSpAMdUzY/Qk/jtjsHdFXVBe+tshlIkSJ3GZw8VVKqTg3GZElztwb
# JWNtrhBEvhf6anxMegQMJP7tO8/BJ7ITs4/AV3D2bv8eHk81Y+fOmQ8mQ61WLq2w
# ItvlzIT5bzelK9LvEycf5x1lXxAwEw5a7dpS+CKTanhtv+Q2mwebAybjf9io4k48
# stTaq1rtcrOiDwddqVm1S9e8h1TszXFzjLLvE9EmjnNfIewsY+RChUaHnY4FFwwJ
# EnEv/JS76oHT0oGdy7+J60fGOl7A1UoUyAkhpb2Bja+SwSIiHbQ4FDyJiLlZ6drZ
# Z84MoJ852JSxM0hBjGO6FZlPO8iuNyk680Di8VnbSNpIdJN+DhlepeTUMBDHqCmd
# 0mVWRWZPm1pvgty93asNt/Ng6o4m2dnooWOdM3yKsJaWjyHqic9gfTrZBM+PCXqe
# TaO1oEiaQ+h4w0nHVdV+XSvI2m1yN4iibqjm5HPaAO3OJ+OmNLftNVmr4Z6U2T6p
# IcLBysoKcDUvCqycXj4C/+n1KFBpDGdDMw9gmu8CAwEAAaOCAUkwggFFMB0GA1Ud
# DgQWBBRQrN9jlwNOoeE5ZQqnF5x8S1bJQzAfBgNVHSMEGDAWgBSfpxVdAF5iXYP0
# 5dJlpxtTNRnpcjBfBgNVHR8EWDBWMFSgUqBQhk5odHRwOi8vd3d3Lm1pY3Jvc29m
# dC5jb20vcGtpb3BzL2NybC9NaWNyb3NvZnQlMjBUaW1lLVN0YW1wJTIwUENBJTIw
# MjAxMCgxKS5jcmwwbAYIKwYBBQUHAQEEYDBeMFwGCCsGAQUFBzAChlBodHRwOi8v
# d3d3Lm1pY3Jvc29mdC5jb20vcGtpb3BzL2NlcnRzL01pY3Jvc29mdCUyMFRpbWUt
# U3RhbXAlMjBQQ0ElMjAyMDEwKDEpLmNydDAMBgNVHRMBAf8EAjAAMBYGA1UdJQEB
# /wQMMAoGCCsGAQUFBwMIMA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQsFAAOC
# AgEARmgFdhB7xIAIHEEg5I/5S+gx67aR6RiW8ZAwtE3mz8o0dyn+pIP+lidNR1IK
# QQ0r+RjYgI9cZ6mbvAyvh3e2q/BV8rjHE3ud9PyYyq32euFgdZ3vX4b5QXePWlpB
# AYrdziR27rHz6WwpH5dZsSypbXDBbQkWkNl6g82yTy3AbBbKDXBdzxZsEauaOpla
# tK7Er4dhglKBex8JQ2dMSkSZweCNDXqd9r/9W2VdRZsDJKP/Xc4UyQlVsboBotKt
# YESXFkjwR1HVsH+Q0C69/N5CP/Tq3YgI1ub4b9+3MJFKWhJXCcJGFZkcLwUmYwoF
# g1XLo7DLJdGjrIH1jsI2NFXJFQHef6AdRe1ERvYQeqtyrBvxIvR+P/83FNYyzx04
# inUT9TF2AwTOuqCC6Z67oNwR4pEEJyAIEREvkdhjjfWcgsk/nGTlfahvNY/SOHrN
# RKo49KDlccNzRCJQyQ+D59r7/qebNSyQPTfwI9++jEY0Q/UWKVNLhio55GYBseJ9
# 9s7NzkdxOr9Uftp597HEovbA69qGlZ3OpUE3H1RBGDVp/FvM2uXTum8LrMkPXx5A
# p/kbPASsC9ju9oMCe2IEXO2SeD1aD3IqvAOdHFKHg1vpbPUQSWb6g2xfBV30wFcq
# aPYgzcbxPWPyZqK+S8l7zw64aO5hmJ7eQwoMfTu0Vay6r48wggdxMIIFWaADAgEC
# AhMzAAAAFcXna54Cm0mZAAAAAAAVMA0GCSqGSIb3DQEBCwUAMIGIMQswCQYDVQQG
# EwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwG
# A1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTIwMAYDVQQDEylNaWNyb3NvZnQg
# Um9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgMjAxMDAeFw0yMTA5MzAxODIyMjVa
# Fw0zMDA5MzAxODMyMjVaMHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5n
# dG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9y
# YXRpb24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwMIIC
# IjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA5OGmTOe0ciELeaLL1yR5vQ7V
# gtP97pwHB9KpbE51yMo1V/YBf2xK4OK9uT4XYDP/XE/HZveVU3Fa4n5KWv64NmeF
# RiMMtY0Tz3cywBAY6GB9alKDRLemjkZrBxTzxXb1hlDcwUTIcVxRMTegCjhuje3X
# D9gmU3w5YQJ6xKr9cmmvHaus9ja+NSZk2pg7uhp7M62AW36MEBydUv626GIl3GoP
# z130/o5Tz9bshVZN7928jaTjkY+yOSxRnOlwaQ3KNi1wjjHINSi947SHJMPgyY9+
# tVSP3PoFVZhtaDuaRr3tpK56KTesy+uDRedGbsoy1cCGMFxPLOJiss254o2I5Jas
# AUq7vnGpF1tnYN74kpEeHT39IM9zfUGaRnXNxF803RKJ1v2lIH1+/NmeRd+2ci/b
# fV+AutuqfjbsNkz2K26oElHovwUDo9Fzpk03dJQcNIIP8BDyt0cY7afomXw/TNuv
# XsLz1dhzPUNOwTM5TI4CvEJoLhDqhFFG4tG9ahhaYQFzymeiXtcodgLiMxhy16cg
# 8ML6EgrXY28MyTZki1ugpoMhXV8wdJGUlNi5UPkLiWHzNgY1GIRH29wb0f2y1BzF
# a/ZcUlFdEtsluq9QBXpsxREdcu+N+VLEhReTwDwV2xo3xwgVGD94q0W29R6HXtqP
# nhZyacaue7e3PmriLq0CAwEAAaOCAd0wggHZMBIGCSsGAQQBgjcVAQQFAgMBAAEw
# IwYJKwYBBAGCNxUCBBYEFCqnUv5kxJq+gpE8RjUpzxD/LwTuMB0GA1UdDgQWBBSf
# pxVdAF5iXYP05dJlpxtTNRnpcjBcBgNVHSAEVTBTMFEGDCsGAQQBgjdMg30BATBB
# MD8GCCsGAQUFBwIBFjNodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3BzL0Rv
# Y3MvUmVwb3NpdG9yeS5odG0wEwYDVR0lBAwwCgYIKwYBBQUHAwgwGQYJKwYBBAGC
# NxQCBAweCgBTAHUAYgBDAEEwCwYDVR0PBAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8w
# HwYDVR0jBBgwFoAU1fZWy4/oolxiaNE9lJBb186aGMQwVgYDVR0fBE8wTTBLoEmg
# R4ZFaHR0cDovL2NybC5taWNyb3NvZnQuY29tL3BraS9jcmwvcHJvZHVjdHMvTWlj
# Um9vQ2VyQXV0XzIwMTAtMDYtMjMuY3JsMFoGCCsGAQUFBwEBBE4wTDBKBggrBgEF
# BQcwAoY+aHR0cDovL3d3dy5taWNyb3NvZnQuY29tL3BraS9jZXJ0cy9NaWNSb29D
# ZXJBdXRfMjAxMC0wNi0yMy5jcnQwDQYJKoZIhvcNAQELBQADggIBAJ1VffwqreEs
# H2cBMSRb4Z5yS/ypb+pcFLY+TkdkeLEGk5c9MTO1OdfCcTY/2mRsfNB1OW27DzHk
# wo/7bNGhlBgi7ulmZzpTTd2YurYeeNg2LpypglYAA7AFvonoaeC6Ce5732pvvinL
# btg/SHUB2RjebYIM9W0jVOR4U3UkV7ndn/OOPcbzaN9l9qRWqveVtihVJ9AkvUCg
# vxm2EhIRXT0n4ECWOKz3+SmJw7wXsFSFQrP8DJ6LGYnn8AtqgcKBGUIZUnWKNsId
# w2FzLixre24/LAl4FOmRsqlb30mjdAy87JGA0j3mSj5mO0+7hvoyGtmW9I/2kQH2
# zsZ0/fZMcm8Qq3UwxTSwethQ/gpY3UA8x1RtnWN0SCyxTkctwRQEcb9k+SS+c23K
# jgm9swFXSVRk2XPXfx5bRAGOWhmRaw2fpCjcZxkoJLo4S5pu+yFUa2pFEUep8beu
# yOiJXk+d0tBMdrVXVAmxaQFEfnyhYWxz/gq77EFmPWn9y8FBSX5+k77L+DvktxW/
# tM4+pTFRhLy/AsGConsXHRWJjXD+57XQKBqJC4822rpM+Zv/Cuk0+CQ1ZyvgDbjm
# jJnW4SLq8CdCPSWU5nR0W2rRnj7tfqAxM328y+l7vzhwRNGQ8cirOoo6CGJ/2XBj
# U02N7oJtpQUQwXEGahC0HVUzWLOhcGbyoYIDVjCCAj4CAQEwggEBoYHZpIHWMIHT
# MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVk
# bW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQLEyRN
# aWNyb3NvZnQgSXJlbGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJzAlBgNVBAsTHm5T
# aGllbGQgVFNTIEVTTjo1MjFBLTA1RTAtRDk0NzElMCMGA1UEAxMcTWljcm9zb2Z0
# IFRpbWUtU3RhbXAgU2VydmljZaIjCgEBMAcGBSsOAwIaAxUAabKAFaKt2haUdqkH
# fFYzAzfgSMuggYMwgYCkfjB8MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGlu
# Z3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBv
# cmF0aW9uMSYwJAYDVQQDEx1NaWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAxMDAN
# BgkqhkiG9w0BAQsFAAIFAO2ltS8wIhgPMjAyNjA1MDYxMjQwMTVaGA8yMDI2MDUw
# NzEyNDAxNVowdDA6BgorBgEEAYRZCgQBMSwwKjAKAgUA7aW1LwIBADAHAgEAAgId
# NzAHAgEAAgISmDAKAgUA7acGrwIBADA2BgorBgEEAYRZCgQCMSgwJjAMBgorBgEE
# AYRZCgMCoAowCAIBAAIDB6EgoQowCAIBAAIDAYagMA0GCSqGSIb3DQEBCwUAA4IB
# AQCV/MwCAxF3xUZn43lHcX31uag30J8uWoUaVPrt2AZoBQCgFxDqbQWu+4Hc8MkN
# gT/f0TiuJ6MkieMhw2Ib8zdA/MhKrBV7oyKmW32WJwVAj1+5+Yxpp5qBUwjubx1c
# N3gHyRxG69GBTg1qUkdzJz6McNn/lxI6/PRKuyn4iLRLC5cjYoAA6B+W+owij9fg
# xmqsbVRywRE/r92NI1spsELDfuP56PHBjT0vHvJvKmrHXqhH0dGU1tFvlLryJ7AP
# BQSlQjcI9NzTQ1naIyQ/g2/fU07QSbpqCeCPhxQE+1z0PBcGCgpxQzHJvwXpQYrY
# CGsVMPEHKiwKLLhCWH3GCL0gMYIEDTCCBAkCAQEwgZMwfDELMAkGA1UEBhMCVVMx
# EzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoT
# FU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUt
# U3RhbXAgUENBIDIwMTACEzMAAAIXcfsupa8BHeoAAQAAAhcwDQYJYIZIAWUDBAIB
# BQCgggFKMBoGCSqGSIb3DQEJAzENBgsqhkiG9w0BCRABBDAvBgkqhkiG9w0BCQQx
# IgQgY5VCIa+VEDOOyuIXGpyx9fDRLwQtIQmjfSk4KrYpf4wwgfoGCyqGSIb3DQEJ
# EAIvMYHqMIHnMIHkMIG9BCDQ8lBgPl23yZ0SzUSt5phOIegHPywrkNwevxe2k+Ra
# WzCBmDCBgKR+MHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAw
# DgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24x
# JjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwAhMzAAACF3H7
# LqWvAR3qAAEAAAIXMCIEIBXMg7rRFVwXSxRNkprGj+O8uys1iCGaoG+CeHxxjNUU
# MA0GCSqGSIb3DQEBCwUABIICADA7vv6xTHxOlJvit6Gl2CqfOfaPHNbyEhr/cDGM
# IusE1y7AGu8ul6Ri35iE4+PL9I8mQz27YWEMrpFcFXs3w0UD4NZjuFMomH5tqPYx
# lXsq9rBGD+ccqE6HG6nAtqVPN+hdRRP1ktpVCazjqC+v6wk/YKWTf1sUOZ0MyEHk
# PxgyQsUCcbXgq/cALekLflstt6JEgzwy0i/BCfN1+j+VCeyBwlh5N5Hr4j9PuEbo
# CGL5o1oF65HVq3W6jb48BAvOQ4FCSbQtZ6OpAf7iBYZNmhuUaNPwPhG+6ppbxJ5U
# gc4CJBLiXID/WpTNEE59zIkKKNRdsrCuecNC7377wXJRe+CN6rwMPugZ/pyyl60n
# O4rlOv+JGEqYyAJLuRP+JYur5OS15058kbPM+HymhmTswxPckm/wkoTWgghHRLVU
# RRbNwmUNLJcb+4VzhA0RaVRa0Av7RgUEH58Tvj7ChcXbWrwXzAZag+pnIJ8fiLmt
# xzKqA4aY99YPrMJAU18zhebKquuRE/s5Guq3PORGuZ0yjTxKE4mrZI2boBIWKtiX
# +9iYujQdPXQ5VLHlQbnrC1uUNhj2aAYHZgsOiu740bJdsOqJj/dc5Tq7i4STJHDv
# L3Yjk+1/jRhHl7l/jqz7gQt7Zc3rtOXraaR1PoRkTlCBZer8B5noGi6FjDgOyJ0i
# +b9P
# SIG # End signature block
x
Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586