Obs/scripts/Install-Extension.ps1

##------------------------------------------------------------------
## <copyright file="Install-Extension.ps1" company="Microsoft">
## Copyright (C) Microsoft. All rights reserved.
## </copyright>
##------------------------------------------------------------------

Param (
    [Parameter(Mandatory = $false)]
    [System.String] $DeviceArmResourceUri = [System.String]::Empty,

    [Parameter(Mandatory = $false)]
    [System.String] $StampId = [System.String]::Empty,

    [Parameter(Mandatory=$false)]
    [System.String] $ClusterName = [System.String]::Empty,

    [Parameter(Mandatory=$false)]
    [System.String] $CloudName = "AzureCloud",

    [Parameter(Mandatory=$false)]
    [System.String] $RegistrationRegion = "eastus"
)

$ErrorActionPreference = "Stop"
$functionName = $MyInvocation.MyCommand.Name

#region Imports
Import-Module (Join-Path -Path $PSScriptRoot -ChildPath 'ExtensionHelper.psm1') `
    -DisableNameChecking `
    -Verbose:$false

$gmaPackageContentPath = Get-GmaPackageContentPath
Import-Module (Join-Path -Path "$gmaPackageContentPath" -ChildPath 'GMATenantJsonHelper.psm1') `
    -DisableNameChecking `
    -Verbose:$false

Import-Module (Join-Path -Path $PSScriptRoot -ChildPath 'ScenarioHelper.psm1') `
    -DisableNameChecking `
    -Verbose:$false

Import-Module (Join-Path -Path $PSScriptRoot -ChildPath 'ObservabilityDeploymentHelper.psm1') `
    -DisableNameChecking `
    -Verbose:$false
#endregion Imports

$logFile = Get-HandlerLogFile

try {
    Write-Log "$functionName : Install script started." `
        -LogFile $logFile

    #region Pre-installation validations
    Invoke-PreInstallationValidation -LogFile $logFile
    #endregion Pre-installation validations

    Write-Log "$functionName : Installing Observability-Telemetry pipeline components." `
        -LogFile $logFile

    Set-DeviceType -LogFile $logFile

    
    #region VCRuntime setup
    Install-VCRuntime -LogFile $logFile
    #endregion VCRuntime setup
        
    #region UTC setup
    if (Confirm-IsTelemetryEnabled) {
        Initialize-UTCSetup -LogFile $logFile
    }
    else {
        Write-Log "$functionName : Initialize-UTCSetup will not be executed as Telemetry is disabled." `
            -LogFile $logFile
    }
    #endregion UTC setup

    ##----------------------------------------------------------------------------------------------------------------------------------
    ## NOTE: UTC setup needs to happen before GMA as the GenevaNamespace registry key for UTCGeneveExporter needs to be created before GMA setup updates its value.
    ##----------------------------------------------------------------------------------------------------------------------------------

    #region GMA setup
    ## Create required cache folders
    $cacheDirectories = New-CacheDirectories -LogFile $logFile
    $gmaCacheFolderPath = $cacheDirectories.GMACache

    $assemblyVersion = [System.String]::Empty ## NA for Arc extension

    ## If Cloud name is passed from config settings than use that or else use the existing one.
    $CloudName = Get-CloudName -ExistingCloudName $CloudName -LogFile $logFile

    ## If region name is passed from config settings than use that or else use the existing one.
    $GcsRegionName = Get-GcsRegionName -RegistrationRegion $RegistrationRegion -LogFile $logFile

    $GcsEnvironment = Get-GcsEnvironmentName -CloudName $CloudName -LogFile $logFile

    Write-Log -Message "$functionName : gmaCacheFolderPath = $gmaCacheFolderPath" -LogFile $logFile
    Write-Log -Message "$functionName : CloudName = $CloudName" -LogFile $logFile
    Write-Log -Message "$functionName : GcsRegionName = $GcsRegionName" -LogFile $logFile
    Write-Log -Message "$functionName : GcsEnvironment = $GcsEnvironment" -LogFile $logFile
    Write-Log -Message "$functionName : ClusterName = $ClusterName" -LogFile $logFile
    Write-Log -Message "$functionName : assemblyVersion = $assemblyVersion" -LogFile $logFile

    if (Test-RegKeyExists -Path $MiscConstants.GMAScenarioRegKey.Path -Name $MiscConstants.GMAScenarioRegKey.Name) {
         $gmaScenario = Get-ItemPropertyValue -Path $MiscConstants.GMAScenarioRegKey.Path -Name $MiscConstants.GMAScenarioRegKey.Name
         if ($gmaScenario -eq $MiscConstants.GMAScenarioRegKey.Bootstrap)
         {
            Set-BootstrapTenantConfig `
                -GcsRegionName $GcsRegionName `
                -GcsEnvironment $GcsEnvironment `
                -GMACacheFolderPath $gmaCacheFolderPath `
                -LogFile $logFile
         }
         elseif ($gmaScenario -eq $MiscConstants.GMAScenarioRegKey.OneP)
         {
             Set-StandaloneTenantConfig `
                 -GcsRegionName $GcsRegionName `
                 -GcsEnvironment $GcsEnvironment `
                 -GMACacheFolderPath $gmaCacheFolderPath `
                 -LogFile $logFile
         }
    }
    else
    {
        Set-HCITenantConfig `
            -GcsRegionName $GcsRegionName `
            -GcsEnvironment $GcsEnvironment `
            -GMACacheFolderPath $gmaCacheFolderPath `
            -DeviceArmResourceUri $DeviceArmResourceUri `
            -StampId $StampId `
            -ClusterName $ClusterName `
            -LogFile $logFile
    }

    #region MA Watchdog setup
    ## Set HCITelemetry AllowTelemetry
    New-RegKey `
        -Path $MiscConstants.HCITelemetryRegKey.Path `
        -LogFile $logFile `
        -CreatePathOnly

    New-RegKey `
        -Path $MiscConstants.HCITelemetryRegKey.Path `
        -Name $MiscConstants.HCITelemetryRegKey.Name `
        -PropertyType $MiscConstants.HCITelemetryRegKey.PropertyType `
        -Value $MiscConstants.HCITelemetryRegKey.Value `
        -LogFile $logFile

    New-Directory -Path $MiscConstants.FDAOutputDirectory -LogFile $logFile
    $FDACmdLine = "/EmissionType Local /OutputPath $($MiscConstants.FDAOutputDirectory) /OutputZip /NoAutopilot"
    ## Set MA Watchdog app config settings
    $watchdogPackageContentPath = Get-WatchdogPackageContentPath
    $watchdogAppConfigPath = Join-Path $watchdogPackageContentPath -ChildPath $MiscConstants.MAWatchDogAppAppConfigName
    $watchdogAppConfig = Get-Content $watchdogAppConfigPath -Raw

    $appConfigValuesToUpdate = @{
        ExtensionStatusFilePath = Get-StatusFilePath
        FDAPath = Get-FDAPackageContentPath
        FDACmdLine = $FDACmdLine
        GMACmdLine = "-serviceMode -localPath $($cacheDirectories.MonAgentHostCache) -JsonDropLocation $($cacheDirectories.JsonDropLocation)"
        GMALauncherFileName = $MiscConstants.MonAgentHostExeName
        HeartBeatFilePath = Get-HandlerHeartBeatFile -LogFile $LogFile
        MonitoringPath = "$gmaPackageContentPath\Monitoring\Agent"
        WatchdogTimerFrequencyInSeconds = $MiscConstants.WatchdogTimerFrequencyInSeconds
        WatchdogStatusFilePath = Get-WatchdogStatusFile -LogFile $logFile
    }

    ## Constrained language mode must be supported, so regex is used instead of xml node selection to update config
    $appConfigValuesToUpdate.Keys | ForEach-Object {
        $key = $_
        $value = $appConfigValuesToUpdate[$key]
        $searchRegex = "add key=`"$key`" value=`"[^`"]+`""
        $replaceRegex = "add key=`"$key`" value=`"$value`""
        $watchdogAppConfig = $watchdogAppConfig -replace $searchRegex, $replaceRegex
    }

    Set-Content -Path $watchdogAppConfigPath -Value $watchdogAppConfig
 
    ## Register MAWatchDog as Windows Service.
    $binaryFilePath = Join-Path -Path $watchdogPackageContentPath `
                        -ChildPath $MiscConstants.ObsServiceDetails.WatchdogAgent.BinaryFileName

    Register-ServiceForObservability `
        -ServiceName $MiscConstants.ObsServiceDetails.WatchdogAgent.Name `
        -ServiceDisplayName $MiscConstants.ObsServiceDetails.WatchdogAgent.DisplayName `
        -ServiceBinaryFilePath $binaryFilePath `
        -LogFile $logFile
    #endregion MA Watchdog setup

    #region Diagnostics setup
    Write-Log "$functionName : Installing Observability-Diagnostics pipeline components." `
        -LogFile $logFile
    ## Based on device type place log configuration files appropriately.
    Move-LogCollectionConfigurations -LogFile $logFile
    
    ## Register Observability windows eventsources and create Observability Pruner, Uptime, and Census Scheduled tasks
    Register-ObservabilityEventSources -LogFile $logFile
    Set-ObservabilityDeploymentScheduledTasks -LogFile $logFile

    ## Register Obs Agent as Windows service
    $binaryFilePath = Join-Path -Path $global:ObsArtifactsPaths.ObservabilityAgent `
                        -ChildPath $MiscConstants.ObsServiceDetails.ObsAgent.BinaryFileName
                        
    Register-ServiceForObservability `
        -ServiceName $MiscConstants.ObsServiceDetails.ObsAgent.Name `
        -ServiceDisplayName $MiscConstants.ObsServiceDetails.ObsAgent.DisplayName `
        -ServiceBinaryFilePath $binaryFilePath `
        -LogFile $logFile

    ## logman
    Initialize-LogmanTraceSession -Logfile $logFile

    #endregion Diagnostics setup

    Write-Log `
        -Message "$functionName : Successfully installed observability pipeline components." `
        -LogFile $logFile

    Set-Status `
        -Name $MiscConstants.WorkLoadName.Install `
        -Operation "Install succeeded" `
        -Message "Successfully installed extension." `
        -Status $MiscConstants.Status.Success `
        -Code $MiscConstants.SuccessCode
}
catch {
    Import-Module (Join-Path -Path $gmaPackageContentPath -ChildPath 'GMATenantJsonHelper.psm1') `
        -DisableNameChecking `
        -Verbose:$false
    
    $errorCode = $ErrorConstants.DefaultErrorMessage.Code
    $customErrorMessage = "Failed to install extension, "

    $errorKey = $_.ToString()
    if ($ErrorConstants.Keys -contains $errorKey) {
        $errorConstant = $ErrorConstants[$errorKey]
        $customErrorMessage += $errorConstant.Message
        $errorCode = $errorConstant.Code
    }
    else {
        $customErrorMessage += "$($ErrorConstants.DefaultErrorMessage.Message) $errorKey"
        $errorCode = $ErrorConstants.DefaultErrorMessage.Code
    }

    $exceptionDetailsAsString = Get-ExceptionDetails -ErrorObject $_

    # Exception details are saved for logging only.
    Write-Log `
        -Message "$customErrorMessage : $exceptionDetailsAsString" `
        -LogFile $LogFile `
        -Level $MiscConstants.Level.Error

    # In status file, only the exception message is sent along with the custom message.
    Set-Status `
        -Name $MiscConstants.WorkLoadName.Install `
        -Operation "Install failed" `
        -Message $customErrorMessage `
        -Status $MiscConstants.Status.Error `
        -Code $errorCode

    exit $errorCode
}
# SIG # Begin signature block
# MIIoLQYJKoZIhvcNAQcCoIIoHjCCKBoCAQExDzANBglghkgBZQMEAgEFADB5Bgor
# BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG
# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCCiWTTQ2BAG3zUW
# aVa86ATqu6MBlNH5t7P7azkocmwu0qCCDXYwggX0MIID3KADAgECAhMzAAADTrU8
# esGEb+srAAAAAANOMA0GCSqGSIb3DQEBCwUAMH4xCzAJBgNVBAYTAlVTMRMwEQYD
# VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy
# b3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNpZ25p
# bmcgUENBIDIwMTEwHhcNMjMwMzE2MTg0MzI5WhcNMjQwMzE0MTg0MzI5WjB0MQsw
# CQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9u
# ZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMR4wHAYDVQQDExVNaWNy
# b3NvZnQgQ29ycG9yYXRpb24wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB
# AQDdCKiNI6IBFWuvJUmf6WdOJqZmIwYs5G7AJD5UbcL6tsC+EBPDbr36pFGo1bsU
# p53nRyFYnncoMg8FK0d8jLlw0lgexDDr7gicf2zOBFWqfv/nSLwzJFNP5W03DF/1
# 1oZ12rSFqGlm+O46cRjTDFBpMRCZZGddZlRBjivby0eI1VgTD1TvAdfBYQe82fhm
# WQkYR/lWmAK+vW/1+bO7jHaxXTNCxLIBW07F8PBjUcwFxxyfbe2mHB4h1L4U0Ofa
# +HX/aREQ7SqYZz59sXM2ySOfvYyIjnqSO80NGBaz5DvzIG88J0+BNhOu2jl6Dfcq
# jYQs1H/PMSQIK6E7lXDXSpXzAgMBAAGjggFzMIIBbzAfBgNVHSUEGDAWBgorBgEE
# AYI3TAgBBggrBgEFBQcDAzAdBgNVHQ4EFgQUnMc7Zn/ukKBsBiWkwdNfsN5pdwAw
# RQYDVR0RBD4wPKQ6MDgxHjAcBgNVBAsTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEW
# MBQGA1UEBRMNMjMwMDEyKzUwMDUxNjAfBgNVHSMEGDAWgBRIbmTlUAXTgqoXNzci
# tW2oynUClTBUBgNVHR8ETTBLMEmgR6BFhkNodHRwOi8vd3d3Lm1pY3Jvc29mdC5j
# b20vcGtpb3BzL2NybC9NaWNDb2RTaWdQQ0EyMDExXzIwMTEtMDctMDguY3JsMGEG
# CCsGAQUFBwEBBFUwUzBRBggrBgEFBQcwAoZFaHR0cDovL3d3dy5taWNyb3NvZnQu
# Y29tL3BraW9wcy9jZXJ0cy9NaWNDb2RTaWdQQ0EyMDExXzIwMTEtMDctMDguY3J0
# MAwGA1UdEwEB/wQCMAAwDQYJKoZIhvcNAQELBQADggIBAD21v9pHoLdBSNlFAjmk
# mx4XxOZAPsVxxXbDyQv1+kGDe9XpgBnT1lXnx7JDpFMKBwAyIwdInmvhK9pGBa31
# TyeL3p7R2s0L8SABPPRJHAEk4NHpBXxHjm4TKjezAbSqqbgsy10Y7KApy+9UrKa2
# kGmsuASsk95PVm5vem7OmTs42vm0BJUU+JPQLg8Y/sdj3TtSfLYYZAaJwTAIgi7d
# hzn5hatLo7Dhz+4T+MrFd+6LUa2U3zr97QwzDthx+RP9/RZnur4inzSQsG5DCVIM
# pA1l2NWEA3KAca0tI2l6hQNYsaKL1kefdfHCrPxEry8onJjyGGv9YKoLv6AOO7Oh
# JEmbQlz/xksYG2N/JSOJ+QqYpGTEuYFYVWain7He6jgb41JbpOGKDdE/b+V2q/gX
# UgFe2gdwTpCDsvh8SMRoq1/BNXcr7iTAU38Vgr83iVtPYmFhZOVM0ULp/kKTVoir
# IpP2KCxT4OekOctt8grYnhJ16QMjmMv5o53hjNFXOxigkQWYzUO+6w50g0FAeFa8
# 5ugCCB6lXEk21FFB1FdIHpjSQf+LP/W2OV/HfhC3uTPgKbRtXo83TZYEudooyZ/A
# Vu08sibZ3MkGOJORLERNwKm2G7oqdOv4Qj8Z0JrGgMzj46NFKAxkLSpE5oHQYP1H
# tPx1lPfD7iNSbJsP6LiUHXH1MIIHejCCBWKgAwIBAgIKYQ6Q0gAAAAAAAzANBgkq
# hkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24x
# EDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlv
# bjEyMDAGA1UEAxMpTWljcm9zb2Z0IFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5
# IDIwMTEwHhcNMTEwNzA4MjA1OTA5WhcNMjYwNzA4MjEwOTA5WjB+MQswCQYDVQQG
# EwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwG
# A1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSgwJgYDVQQDEx9NaWNyb3NvZnQg
# Q29kZSBTaWduaW5nIFBDQSAyMDExMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC
# CgKCAgEAq/D6chAcLq3YbqqCEE00uvK2WCGfQhsqa+laUKq4BjgaBEm6f8MMHt03
# a8YS2AvwOMKZBrDIOdUBFDFC04kNeWSHfpRgJGyvnkmc6Whe0t+bU7IKLMOv2akr
# rnoJr9eWWcpgGgXpZnboMlImEi/nqwhQz7NEt13YxC4Ddato88tt8zpcoRb0Rrrg
# OGSsbmQ1eKagYw8t00CT+OPeBw3VXHmlSSnnDb6gE3e+lD3v++MrWhAfTVYoonpy
# 4BI6t0le2O3tQ5GD2Xuye4Yb2T6xjF3oiU+EGvKhL1nkkDstrjNYxbc+/jLTswM9
# sbKvkjh+0p2ALPVOVpEhNSXDOW5kf1O6nA+tGSOEy/S6A4aN91/w0FK/jJSHvMAh
# dCVfGCi2zCcoOCWYOUo2z3yxkq4cI6epZuxhH2rhKEmdX4jiJV3TIUs+UsS1Vz8k
# A/DRelsv1SPjcF0PUUZ3s/gA4bysAoJf28AVs70b1FVL5zmhD+kjSbwYuER8ReTB
# w3J64HLnJN+/RpnF78IcV9uDjexNSTCnq47f7Fufr/zdsGbiwZeBe+3W7UvnSSmn
# Eyimp31ngOaKYnhfsi+E11ecXL93KCjx7W3DKI8sj0A3T8HhhUSJxAlMxdSlQy90
# lfdu+HggWCwTXWCVmj5PM4TasIgX3p5O9JawvEagbJjS4NaIjAsCAwEAAaOCAe0w
# ggHpMBAGCSsGAQQBgjcVAQQDAgEAMB0GA1UdDgQWBBRIbmTlUAXTgqoXNzcitW2o
# ynUClTAZBgkrBgEEAYI3FAIEDB4KAFMAdQBiAEMAQTALBgNVHQ8EBAMCAYYwDwYD
# VR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBRyLToCMZBDuRQFTuHqp8cx0SOJNDBa
# BgNVHR8EUzBRME+gTaBLhklodHRwOi8vY3JsLm1pY3Jvc29mdC5jb20vcGtpL2Ny
# bC9wcm9kdWN0cy9NaWNSb29DZXJBdXQyMDExXzIwMTFfMDNfMjIuY3JsMF4GCCsG
# AQUFBwEBBFIwUDBOBggrBgEFBQcwAoZCaHR0cDovL3d3dy5taWNyb3NvZnQuY29t
# L3BraS9jZXJ0cy9NaWNSb29DZXJBdXQyMDExXzIwMTFfMDNfMjIuY3J0MIGfBgNV
# HSAEgZcwgZQwgZEGCSsGAQQBgjcuAzCBgzA/BggrBgEFBQcCARYzaHR0cDovL3d3
# dy5taWNyb3NvZnQuY29tL3BraW9wcy9kb2NzL3ByaW1hcnljcHMuaHRtMEAGCCsG
# AQUFBwICMDQeMiAdAEwAZQBnAGEAbABfAHAAbwBsAGkAYwB5AF8AcwB0AGEAdABl
# AG0AZQBuAHQALiAdMA0GCSqGSIb3DQEBCwUAA4ICAQBn8oalmOBUeRou09h0ZyKb
# C5YR4WOSmUKWfdJ5DJDBZV8uLD74w3LRbYP+vj/oCso7v0epo/Np22O/IjWll11l
# hJB9i0ZQVdgMknzSGksc8zxCi1LQsP1r4z4HLimb5j0bpdS1HXeUOeLpZMlEPXh6
# I/MTfaaQdION9MsmAkYqwooQu6SpBQyb7Wj6aC6VoCo/KmtYSWMfCWluWpiW5IP0
# wI/zRive/DvQvTXvbiWu5a8n7dDd8w6vmSiXmE0OPQvyCInWH8MyGOLwxS3OW560
# STkKxgrCxq2u5bLZ2xWIUUVYODJxJxp/sfQn+N4sOiBpmLJZiWhub6e3dMNABQam
# ASooPoI/E01mC8CzTfXhj38cbxV9Rad25UAqZaPDXVJihsMdYzaXht/a8/jyFqGa
# J+HNpZfQ7l1jQeNbB5yHPgZ3BtEGsXUfFL5hYbXw3MYbBL7fQccOKO7eZS/sl/ah
# XJbYANahRr1Z85elCUtIEJmAH9AAKcWxm6U/RXceNcbSoqKfenoi+kiVH6v7RyOA
# 9Z74v2u3S5fi63V4GuzqN5l5GEv/1rMjaHXmr/r8i+sLgOppO6/8MO0ETI7f33Vt
# Y5E90Z1WTk+/gFcioXgRMiF670EKsT/7qMykXcGhiJtXcVZOSEXAQsmbdlsKgEhr
# /Xmfwb1tbWrJUnMTDXpQzTGCGg0wghoJAgEBMIGVMH4xCzAJBgNVBAYTAlVTMRMw
# EQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVN
# aWNyb3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNp
# Z25pbmcgUENBIDIwMTECEzMAAANOtTx6wYRv6ysAAAAAA04wDQYJYIZIAWUDBAIB
# BQCgga4wGQYJKoZIhvcNAQkDMQwGCisGAQQBgjcCAQQwHAYKKwYBBAGCNwIBCzEO
# MAwGCisGAQQBgjcCARUwLwYJKoZIhvcNAQkEMSIEIPAKj2nrIJaeEEtAg8R7TBQT
# pDqMirDJFit9lDSU5ZmKMEIGCisGAQQBgjcCAQwxNDAyoBSAEgBNAGkAYwByAG8A
# cwBvAGYAdKEagBhodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20wDQYJKoZIhvcNAQEB
# BQAEggEAllean3hSvkzR72XLGEjbOVN1AudSa3C0mkrQTkZJ1PmOu+haYROJrmWr
# T6M57clFAduwYwHrv/a3xmXnPTBfzC1/WrP+eLBnJS2//bE5wmdmfrj8TXTGzML/
# KUhtbQVqX6Hq6SCdnOynRfJ1ryG/79Tx+gOVZ7oocd0LmFYHETXZWhuisr/3hIWo
# pfoUOJuEEcQPSot+tTLRxoTHKPeXQFqN9UFZASvV1ANACK0T07t32vG1JgOsNXGa
# tLIqnXl7FXe0JnF+EjCnCzMDVYSA5vMti6Fdy9AFugJcEHzTVPE2xXZfUdl4bVaW
# VMc5M6wgfX3BXUsxjAUcRGOiGounxaGCF5cwgheTBgorBgEEAYI3AwMBMYIXgzCC
# F38GCSqGSIb3DQEHAqCCF3AwghdsAgEDMQ8wDQYJYIZIAWUDBAIBBQAwggFSBgsq
# hkiG9w0BCRABBKCCAUEEggE9MIIBOQIBAQYKKwYBBAGEWQoDATAxMA0GCWCGSAFl
# AwQCAQUABCCEoVLfSwaIcSdmbAmb8Bb7ppctWDg9Hul3SzuvxwqGRwIGZMvhvAvm
# GBMyMDIzMDgwNzIxMzM0MC43OTZaMASAAgH0oIHRpIHOMIHLMQswCQYDVQQGEwJV
# UzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UE
# ChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSUwIwYDVQQLExxNaWNyb3NvZnQgQW1l
# cmljYSBPcGVyYXRpb25zMScwJQYDVQQLEx5uU2hpZWxkIFRTUyBFU046REMwMC0w
# NUUwLUQ5NDcxJTAjBgNVBAMTHE1pY3Jvc29mdCBUaW1lLVN0YW1wIFNlcnZpY2Wg
# ghHtMIIHIDCCBQigAwIBAgITMwAAAdIhJDFKWL8tEQABAAAB0jANBgkqhkiG9w0B
# AQsFADB8MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UE
# BxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSYwJAYD
# VQQDEx1NaWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAxMDAeFw0yMzA1MjUxOTEy
# MjFaFw0yNDAyMDExOTEyMjFaMIHLMQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2Fz
# aGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENv
# cnBvcmF0aW9uMSUwIwYDVQQLExxNaWNyb3NvZnQgQW1lcmljYSBPcGVyYXRpb25z
# MScwJQYDVQQLEx5uU2hpZWxkIFRTUyBFU046REMwMC0wNUUwLUQ5NDcxJTAjBgNV
# BAMTHE1pY3Jvc29mdCBUaW1lLVN0YW1wIFNlcnZpY2UwggIiMA0GCSqGSIb3DQEB
# AQUAA4ICDwAwggIKAoICAQDcYIhC0QI/SPaT5+nYSBsSdhBPO2SXM40Vyyg8Fq1T
# PrMNDzxChxWUD7fbKwYGSsONgtjjVed5HSh5il75jNacb6TrZwuX+Q2++f2/8CCy
# u8TY0rxEInD3Tj52bWz5QRWVQejfdCA/n6ZzinhcZZ7+VelWgTfYC7rDrhX3TBX8
# 9elqXmISOVIWeXiRK8h9hH6SXgjhQGGQbf2bSM7uGkKzJ/pZ2LvlTzq+mOW9iP2j
# cYEA4bpPeurpglLVUSnGGQLmjQp7Sdy1wE52WjPKdLnBF6JbmSREM/Dj9Z7okxRN
# UjYSdgyvZ1LWSilhV/wegYXVQ6P9MKjRnE8CI5KMHmq7EsHhIBK0B99dFQydL1vd
# uC7eWEjzz55Z/DyH6Hl2SPOf5KZ4lHf6MUwtgaf+MeZxkW0ixh/vL1mX8VsJTHa8
# AH+0l/9dnWzFMFFJFG7g95nHJ6MmYPrfmoeKORoyEQRsSus2qCrpMjg/P3Z9WJAt
# FGoXYMD19NrzG4UFPpVbl3N1XvG4/uldo1+anBpDYhxQU7k1gfHn6QxdUU0TsrJ/
# JCvLffS89b4VXlIaxnVF6QZh+J7xLUNGtEmj6dwPzoCfL7zqDZJvmsvYNk1lcbyV
# xMIgDFPoA2fZPXHF7dxahM2ZG7AAt3vZEiMtC6E/ciLRcIwzlJrBiHEenIPvxW15
# qwIDAQABo4IBSTCCAUUwHQYDVR0OBBYEFCC2n7cnR3ToP/kbEZ2XJFFmZ1kkMB8G
# A1UdIwQYMBaAFJ+nFV0AXmJdg/Tl0mWnG1M1GelyMF8GA1UdHwRYMFYwVKBSoFCG
# Tmh0dHA6Ly93d3cubWljcm9zb2Z0LmNvbS9wa2lvcHMvY3JsL01pY3Jvc29mdCUy
# MFRpbWUtU3RhbXAlMjBQQ0ElMjAyMDEwKDEpLmNybDBsBggrBgEFBQcBAQRgMF4w
# XAYIKwYBBQUHMAKGUGh0dHA6Ly93d3cubWljcm9zb2Z0LmNvbS9wa2lvcHMvY2Vy
# dHMvTWljcm9zb2Z0JTIwVGltZS1TdGFtcCUyMFBDQSUyMDIwMTAoMSkuY3J0MAwG
# A1UdEwEB/wQCMAAwFgYDVR0lAQH/BAwwCgYIKwYBBQUHAwgwDgYDVR0PAQH/BAQD
# AgeAMA0GCSqGSIb3DQEBCwUAA4ICAQCw5iq0Ey0LlAdz2PcqchRwW5d+fitNISCv
# qD0E6W/AyiTk+TM3WhYTaxQ2pP6Or4qOV+Du7/L+k18gYr1phshxVMVnXNcdjecM
# tTWUOVAwbJoeWHaAgknNIMzXK3+zguG5TVcLEh/CVMy1J7KPE8Q0Cz56NgWzd9ur
# G+shSDKkKdhOYPXF970Mr1GCFFpe1oXjEy6aS+Heavp2wmy65mbu0AcUOPEn+hYq
# ijgLXSPqvuFmOOo5UnSV66Dv5FdkqK7q5DReox9RPEZcHUa+2BUKPjp+dQ3D4c9I
# H8727KjMD8OXZomD9A8Mr/fcDn5FI7lfZc8ghYc7spYKTO/0Z9YRRamhVWxxrIsB
# N5LrWh+18soXJ++EeSjzSYdgGWYPg16hL/7Aydx4Kz/WBTUmbGiiVUcE/I0aQU2U
# /0NzUiIFIW80SvxeDWn6I+hyVg/sdFSALP5JT7wAe8zTvsrI2hMpEVLdStFAMqan
# FYqtwZU5FoAsoPZ7h1ElWmKLZkXk8ePuALztNY1yseO0TwdueIGcIwItrlBYg1Xp
# Pz1+pMhGMVble6KHunaKo5K/ldOM0mQQT4Vjg6ZbzRIVRoDcArQ5//0875jOUvJt
# Yyc7Hl04jcmvjEIXC3HjkUYvgHEWL0QF/4f7vLAchaEZ839/3GYOdqH5VVnZrUIB
# QB6DTaUILDCCB3EwggVZoAMCAQICEzMAAAAVxedrngKbSZkAAAAAABUwDQYJKoZI
# hvcNAQELBQAwgYgxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAw
# DgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24x
# MjAwBgNVBAMTKU1pY3Jvc29mdCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAy
# MDEwMB4XDTIxMDkzMDE4MjIyNVoXDTMwMDkzMDE4MzIyNVowfDELMAkGA1UEBhMC
# VVMxEzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNV
# BAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRp
# bWUtU3RhbXAgUENBIDIwMTAwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC
# AQDk4aZM57RyIQt5osvXJHm9DtWC0/3unAcH0qlsTnXIyjVX9gF/bErg4r25Phdg
# M/9cT8dm95VTcVrifkpa/rg2Z4VGIwy1jRPPdzLAEBjoYH1qUoNEt6aORmsHFPPF
# dvWGUNzBRMhxXFExN6AKOG6N7dcP2CZTfDlhAnrEqv1yaa8dq6z2Nr41JmTamDu6
# GnszrYBbfowQHJ1S/rboYiXcag/PXfT+jlPP1uyFVk3v3byNpOORj7I5LFGc6XBp
# Dco2LXCOMcg1KL3jtIckw+DJj361VI/c+gVVmG1oO5pGve2krnopN6zL64NF50Zu
# yjLVwIYwXE8s4mKyzbnijYjklqwBSru+cakXW2dg3viSkR4dPf0gz3N9QZpGdc3E
# XzTdEonW/aUgfX782Z5F37ZyL9t9X4C626p+Nuw2TPYrbqgSUei/BQOj0XOmTTd0
# lBw0gg/wEPK3Rxjtp+iZfD9M269ewvPV2HM9Q07BMzlMjgK8QmguEOqEUUbi0b1q
# GFphAXPKZ6Je1yh2AuIzGHLXpyDwwvoSCtdjbwzJNmSLW6CmgyFdXzB0kZSU2LlQ
# +QuJYfM2BjUYhEfb3BvR/bLUHMVr9lxSUV0S2yW6r1AFemzFER1y7435UsSFF5PA
# PBXbGjfHCBUYP3irRbb1Hode2o+eFnJpxq57t7c+auIurQIDAQABo4IB3TCCAdkw
# EgYJKwYBBAGCNxUBBAUCAwEAATAjBgkrBgEEAYI3FQIEFgQUKqdS/mTEmr6CkTxG
# NSnPEP8vBO4wHQYDVR0OBBYEFJ+nFV0AXmJdg/Tl0mWnG1M1GelyMFwGA1UdIARV
# MFMwUQYMKwYBBAGCN0yDfQEBMEEwPwYIKwYBBQUHAgEWM2h0dHA6Ly93d3cubWlj
# cm9zb2Z0LmNvbS9wa2lvcHMvRG9jcy9SZXBvc2l0b3J5Lmh0bTATBgNVHSUEDDAK
# BggrBgEFBQcDCDAZBgkrBgEEAYI3FAIEDB4KAFMAdQBiAEMAQTALBgNVHQ8EBAMC
# AYYwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBTV9lbLj+iiXGJo0T2UkFvX
# zpoYxDBWBgNVHR8ETzBNMEugSaBHhkVodHRwOi8vY3JsLm1pY3Jvc29mdC5jb20v
# cGtpL2NybC9wcm9kdWN0cy9NaWNSb29DZXJBdXRfMjAxMC0wNi0yMy5jcmwwWgYI
# KwYBBQUHAQEETjBMMEoGCCsGAQUFBzAChj5odHRwOi8vd3d3Lm1pY3Jvc29mdC5j
# b20vcGtpL2NlcnRzL01pY1Jvb0NlckF1dF8yMDEwLTA2LTIzLmNydDANBgkqhkiG
# 9w0BAQsFAAOCAgEAnVV9/Cqt4SwfZwExJFvhnnJL/Klv6lwUtj5OR2R4sQaTlz0x
# M7U518JxNj/aZGx80HU5bbsPMeTCj/ts0aGUGCLu6WZnOlNN3Zi6th542DYunKmC
# VgADsAW+iehp4LoJ7nvfam++Kctu2D9IdQHZGN5tggz1bSNU5HhTdSRXud2f8449
# xvNo32X2pFaq95W2KFUn0CS9QKC/GbYSEhFdPSfgQJY4rPf5KYnDvBewVIVCs/wM
# nosZiefwC2qBwoEZQhlSdYo2wh3DYXMuLGt7bj8sCXgU6ZGyqVvfSaN0DLzskYDS
# PeZKPmY7T7uG+jIa2Zb0j/aRAfbOxnT99kxybxCrdTDFNLB62FD+CljdQDzHVG2d
# Y3RILLFORy3BFARxv2T5JL5zbcqOCb2zAVdJVGTZc9d/HltEAY5aGZFrDZ+kKNxn
# GSgkujhLmm77IVRrakURR6nxt67I6IleT53S0Ex2tVdUCbFpAUR+fKFhbHP+Crvs
# QWY9af3LwUFJfn6Tvsv4O+S3Fb+0zj6lMVGEvL8CwYKiexcdFYmNcP7ntdAoGokL
# jzbaukz5m/8K6TT4JDVnK+ANuOaMmdbhIurwJ0I9JZTmdHRbatGePu1+oDEzfbzL
# 6Xu/OHBE0ZDxyKs6ijoIYn/ZcGNTTY3ugm2lBRDBcQZqELQdVTNYs6FwZvKhggNQ
# MIICOAIBATCB+aGB0aSBzjCByzELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hp
# bmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jw
# b3JhdGlvbjElMCMGA1UECxMcTWljcm9zb2Z0IEFtZXJpY2EgT3BlcmF0aW9uczEn
# MCUGA1UECxMeblNoaWVsZCBUU1MgRVNOOkRDMDAtMDVFMC1EOTQ3MSUwIwYDVQQD
# ExxNaWNyb3NvZnQgVGltZS1TdGFtcCBTZXJ2aWNloiMKAQEwBwYFKw4DAhoDFQCJ
# ptLCZsE06NtmHQzB5F1TroFSBqCBgzCBgKR+MHwxCzAJBgNVBAYTAlVTMRMwEQYD
# VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy
# b3NvZnQgQ29ycG9yYXRpb24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1w
# IFBDQSAyMDEwMA0GCSqGSIb3DQEBCwUAAgUA6HumKDAiGA8yMDIzMDgwNzE3MTkz
# NloYDzIwMjMwODA4MTcxOTM2WjB3MD0GCisGAQQBhFkKBAExLzAtMAoCBQDoe6Yo
# AgEAMAoCAQACAhDjAgH/MAcCAQACAhNjMAoCBQDofPeoAgEAMDYGCisGAQQBhFkK
# BAIxKDAmMAwGCisGAQQBhFkKAwKgCjAIAgEAAgMHoSChCjAIAgEAAgMBhqAwDQYJ
# KoZIhvcNAQELBQADggEBAF3O9ZIy+ReDG9zcjledOS/Pvwp64zcZzXIU8a66LPmm
# xSLJcsyPRq/UfgdFYeSRR5zwlaeNb2Q7Vgi3foNXsoIhAQDKCq1evNyF0lGUqLnG
# U+ZdbvMhts1FsXlPn7NQCybSUd7ZeW0WhF0ZCE9r051QkTumXtOAueBBtTHlac7Y
# Hg3jeLRYLxWZKJn5v/mNGUFOwkz8aSMxR4GsrulBJgVlovvZnxLo6t1md0Aj1nit
# cPQCaBdzmI0wKSIbZjBztus/YuawnAKn9yocB0xDo3NcTH9B0B9W7I8bmbE+yUuJ
# i2JD1KQh9ITWj/smbeoFAecNzRF+CuIb52uFwW0MMicxggQNMIIECQIBATCBkzB8
# MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVk
# bW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSYwJAYDVQQDEx1N
# aWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAxMAITMwAAAdIhJDFKWL8tEQABAAAB
# 0jANBglghkgBZQMEAgEFAKCCAUowGgYJKoZIhvcNAQkDMQ0GCyqGSIb3DQEJEAEE
# MC8GCSqGSIb3DQEJBDEiBCBjmH6zI+dkMETPgy2HAC9H1hD4L+67X1P9EOuocSPU
# LDCB+gYLKoZIhvcNAQkQAi8xgeowgecwgeQwgb0EIMeAIJPf30i9ZbOExU557GwW
# NaLH0Z5s65JFga2DeaROMIGYMIGApH4wfDELMAkGA1UEBhMCVVMxEzARBgNVBAgT
# Cldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29m
# dCBDb3Jwb3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUtU3RhbXAgUENB
# IDIwMTACEzMAAAHSISQxSli/LREAAQAAAdIwIgQg2cELRqGf2GEm5p7GuIiVTGko
# LY0wRXu0l+4iPAXTgkYwDQYJKoZIhvcNAQELBQAEggIAbCjyxDY5+H4UVtryt1NR
# UpbWW98XbLxOYgu5+qvGF8PLjT/8ZtKq1xVt6AGMLj2N3kPsCQza67tM+GXCPX/n
# d9BkIT6tfx9JTZGtbj5OOgVi8omDvt3hJnOCLTzSj1E58VF+CSnmK6skud/tf942
# MThviZKAoCg6hsjy2ncNZXWftjpn5GYrsdllRzDKCLDItd//JMs1fWEx30uu/Sic
# eJpJ2D4UjfJLszNLRkxR5Cup26UagfC6gt6fuXvGrT0nJPoyvtMbDspTH9WtmTGH
# KullA0Fx/iOV6lZOAwBAXwJJ7IQGlwK6laH5fDt8fAtEnzEUOnrlcggs6U8ex1o2
# fJQMuRplP0x66FSEmG6HF/wsZTgnKdKqnRZqOnZuQGNk9dneW9y5eqtXn4CoPHaC
# axPnYi8/jAHaUPKGmiqHbrnvJ06aGVJ5u44VynWGVlSMUotfv0+MvcNG6QqtyA7e
# wQBLwbxQUgpx+qsVU/pRqxlZNvpUMuXeKsBYNWAZZZOZIPm9H0U5H1x/bQKoThRR
# wbXFkk2SsROSR8gk3/N7ttqD0raEUyJyqpqGTsAN7H/uhUEUCPO7GRLlFZl1QdEN
# E36vaJk6Xnn9p1dKJbWW1wCY442ugMBjUC9AxV122zMeQU8+GjmsjuzxfU/NLWxm
# LpZdLEEGF/lzBpV97g7NfZM=
# SIG # End signature block