SetupBase.ps1


function Private-Start-SubTrustQuestion {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param()
   
    if (Test-SubIsAdmin)
    {
        $nonInteractive = Private-Get-IsNonInteractiveShell
        if (-Not $nonInteractive)
        {
            $CertAnswer = Private-Read-CertQuestion
            if ($CertAnswer -eq 0)
            {
                Add-SubTrust
            }

            $PolicyAnswer = Private-Read-PolicyQuestion
            if ($PolicyAnswer -eq 0)
            {
                Set-ExecutionPolicy -ExecutionPolicy Unrestricted -Scope Process
                Set-ExecutionPolicy -ExecutionPolicy Unrestricted -Scope CurrentUser
                Set-ExecutionPolicy -ExecutionPolicy Unrestricted -Scope LocalMachine
            }
            if ($PolicyAnswer -eq 1)
            {
                Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope Process
                Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
                Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope LocalMachine
            }
        }
    }
    else {
        Private-Write-SubStandardMessage -id 1
    }
}

function Private-Read-CertQuestion {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param()
    $title   = 'Code Signing Certificate'
    $msg     = 'Do you want to trust the SetupBase Code Signing Certificate by your local machine.'
    $options = '&Yes', '&No'
    $ChoiceDefault = 0  # 0=Yes, 1=No

    return $Host.UI.PromptForChoice($title, $msg, $options, $ChoiceDefault)
    
}

function Private-Read-PolicyQuestion {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param()
    $title   = "ExecutionPolicy"
    $msg     = "Do want to change your local machine and current user policy to RemoteSigned, this is the default execution policy for Windows servers. It allows you to run SetupBase without restriction if you have installed the certificate."
    $options = '&Unrestricted', '&RemoteSigned', '&NoChange'
    $ChoiceDefault = 1  # 0=Unrestricted, 1=RemoteSigned

    return $Host.UI.PromptForChoice($title, $msg, $options, $ChoiceDefault)
}

function Private-Get-IsNonInteractiveShell {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param()
    # Test each Arg for match of abbreviated '-NonInteractive' command.
    $NonInteractive = [Environment]::GetCommandLineArgs() | Where-Object{ $_ -like '*-NonInteractive*' }

    if ([Environment]::UserInteractive -and -not $NonInteractive) {
        # We are in an interactive shell.
        return $false
    }

    return $true
}

function Private-Test-SubIsAdmin {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    [OutputType([bool])]
    param()
    $IsAdmin = (New-Object Security.Principal.WindowsPrincipal([Security.Principal.WindowsIdentity]::GetCurrent())).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)
    return $IsAdmin
}

function Private-Write-SubStandardMessage {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param(
        [int]$id
    )

    $result = switch ( $id )
    {
        1 { "The command invoked require administrator rights."    }
        default { "The `$id=$id has not been defined in Private-Write-SubStandardMessage" }
    }
    Write-Warning "$result"
}

function Private-Add-SubTrust {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param()
    if (Test-SubIsAdmin)
    {
        $certr = Get-ChildItem "cert:\LocalMachine\Root" | Where-Object {$_.Subject -eq "CN=SetupBase Code Signing Certificate"}
        $certt = Get-ChildItem "cert:\LocalMachine\TrustedPublisher" | Where-Object {$_.Subject -eq "CN=SetupBase Code Signing Certificate"}

        if ($null -eq $certr)
        {
            Import-Certificate -FilePath "$PSScriptRoot\SetupBase Code Signing Certificate.cer" -CertStoreLocation "cert:\LocalMachine\Root" | Out-Null
        }

        if ($null -eq $certt)
        {
            Import-Certificate -FilePath "$PSScriptRoot\SetupBase Code Signing Certificate.cer" -CertStoreLocation "cert:\LocalMachine\TrustedPublisher" | Out-Null
        }
    }
    else {
        Private-Write-SubStandardMessage -id 1
    }
}


function Private-Remove-SubTrust {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param()
    if (Test-SubIsAdmin)
    {
        $certr = Get-ChildItem "cert:\LocalMachine\Root" | Where-Object {$_.Subject -eq "CN=SetupBase Code Signing Certificate"}
        $certt = Get-ChildItem "cert:\LocalMachine\TrustedPublisher" | Where-Object {$_.Subject -eq "CN=SetupBase Code Signing Certificate"}

        if (-Not ($null -eq $certr))
        {
            Get-ChildItem "cert:\LocalMachine\Root" | Where-Object {$_.Subject -eq "CN=SetupBase Code Signing Certificate"} | ForEach-Object {Remove-Item -Path "cert:\LocalMachine\Root\$($_.Thumbprint)"}
        }

        if (-Not ($null -eq $certt))
        {
            Get-ChildItem "cert:\LocalMachine\TrustedPublisher" | Where-Object {$_.Subject -eq "CN=SetupBase Code Signing Certificate"} | ForEach-Object {Remove-Item -Path "cert:\LocalMachine\TrustedPublisher\$($_.Thumbprint)"}
        }
    }
    else {
        Private-Write-SubStandardMessage -id 1
    }
}

function Private-Import-SubPfx {
    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseApprovedVerbs", "")]
    param(
        [Parameter(Mandatory)]
        [string]$File,
        [bool]$Both = $false
    )

    $fi = Get-Item $File
    [void][Reflection.Assembly]::LoadWithPartialName('Microsoft.VisualBasic')
    $title = 'ImportPfx'
    $msg   = "Enter pfx password:`n`n$($fi.Name)"
    $text = [Microsoft.VisualBasic.Interaction]::InputBox($msg, $title)

    if ($text -ne "")
    {
        $IsAdmin = (New-Object Security.Principal.WindowsPrincipal([Security.Principal.WindowsIdentity]::GetCurrent())).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)
        $SecPwd = ConvertTo-SecureString -String "$text" -Force -AsPlainText
    
        if ($IsAdmin)
        {
            Import-PfxCertificate -FilePath "$File" -CertStoreLocation Cert:\LocalMachine\My -Password $SecPwd
            Write-Host "Imported $File to Cert:\LocalMachine\My"
            if ($Both)
            {
                Import-PfxCertificate -FilePath "$File" -CertStoreLocation Cert:\CurrentUser\My -Password $SecPwd
                Write-Host "Imported $File to Cert:\CurrentUser\My"
            }
        }
        else {
            Import-PfxCertificate -FilePath "$File" -CertStoreLocation Cert:\CurrentUser\My -Password $SecPwd
            Write-Host "Imported $File to Cert:\CurrentUser\My"
        }
    }
}

# SIG # Begin signature block
# MIIb1wYJKoZIhvcNAQcCoIIbyDCCG8QCAQExCzAJBgUrDgMCGgUAMGkGCisGAQQB
# gjcCAQSgWzBZMDQGCisGAQQBgjcCAR4wJgIDAQAABBAfzDtgWUsITrck0sYpfvNR
# AgEAAgEAAgEAAgEAAgEAMCEwCQYFKw4DAhoFAAQU6978E5VhpS2NbTdf7gyPthzi
# fwegghY7MIIDKjCCAhKgAwIBAgIQL6HHqwoFIaBK+v4IX7cvUDANBgkqhkiG9w0B
# AQsFADAtMSswKQYDVQQDDCJTZXR1cEJhc2UgQ29kZSBTaWduaW5nIENlcnRpZmlj
# YXRlMB4XDTIyMDgyNDE3MjEzOFoXDTI0MDgyNDE3MzEzOFowLTErMCkGA1UEAwwi
# U2V0dXBCYXNlIENvZGUgU2lnbmluZyBDZXJ0aWZpY2F0ZTCCASIwDQYJKoZIhvcN
# AQEBBQADggEPADCCAQoCggEBAK+riPnD6ghFJKZrD9Pr8ExR1Q8GhMfR6yccf1dA
# ucHMs9E3RydQpQPIhIWBFej9GJPWSoZSz7bja22Y1D3j+yHArYmjd62JaZH2dw0A
# WBixvXBmcdzrzA5+CR03P3Ey2gSJNxZL5XfQB+oJ4Wq1vr68N+5oqdS0kDaxfY9x
# J6EOiLv85bF487zNOOMzewH9lpHvb23jqjpiauWF7K3JhlO0aNl201/nrYuoaabX
# sMce+agFt7YkTbouSkAwkDAl1fvcxxJ4aid6Tpcs3lm2HwL91LMCncTp6RCQTQ7S
# pfcelI0nazSfsCuMPs3LcMho0k13gE4uWDhgh4NGbsYYNtECAwEAAaNGMEQwDgYD
# VR0PAQH/BAQDAgeAMBMGA1UdJQQMMAoGCCsGAQUFBwMDMB0GA1UdDgQWBBTjh0nl
# V516/ZVRhSQi+cKSfVsIuDANBgkqhkiG9w0BAQsFAAOCAQEAhzpMoTObmPQUu1lz
# qiArE4v62EsayGYfCQbc/gNucMjpjoj4oqtSPtYLuTb62RlteuWzYh1nFmTt2K+P
# PbM3HkYMJ0tX6jSRzDyZSa2ENVGL81vWOFpBANFRf4JD7Fnzler0Xi2OUoulRJAw
# DoQ3HKrdYgAOI8PcGZq+HT5CkZNNgWtMFDS2iPI3MHTM4aGEMvKQNMr6WXpdA/uk
# A8mA/UdOgyA4C+BEZwn0UPZR/mNtCSG/XIwE/thEqlZpskt8eCVyQ+AG/tdIIXpG
# jZRATGJ2gx0+ZXvAZH8qHHYh0RG9ESwfdmYoILoaeuvh0fRGP9ed+yz9DEknNGjB
# X6J3BzCCBY0wggR1oAMCAQICEA6bGI750C3n79tQ4ghAGFowDQYJKoZIhvcNAQEM
# BQAwZTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UE
# CxMQd3d3LmRpZ2ljZXJ0LmNvbTEkMCIGA1UEAxMbRGlnaUNlcnQgQXNzdXJlZCBJ
# RCBSb290IENBMB4XDTIyMDgwMTAwMDAwMFoXDTMxMTEwOTIzNTk1OVowYjELMAkG
# A1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UECxMQd3d3LmRp
# Z2ljZXJ0LmNvbTEhMB8GA1UEAxMYRGlnaUNlcnQgVHJ1c3RlZCBSb290IEc0MIIC
# IjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAv+aQc2jeu+RdSjwwIjBpM+zC
# pyUuySE98orYWcLhKac9WKt2ms2uexuEDcQwH/MbpDgW61bGl20dq7J58soR0uRf
# 1gU8Ug9SH8aeFaV+vp+pVxZZVXKvaJNwwrK6dZlqczKU0RBEEC7fgvMHhOZ0O21x
# 4i0MG+4g1ckgHWMpLc7sXk7Ik/ghYZs06wXGXuxbGrzryc/NrDRAX7F6Zu53yEio
# ZldXn1RYjgwrt0+nMNlW7sp7XeOtyU9e5TXnMcvak17cjo+A2raRmECQecN4x7ax
# xLVqGDgDEI3Y1DekLgV9iPWCPhCRcKtVgkEy19sEcypukQF8IUzUvK4bA3VdeGbZ
# OjFEmjNAvwjXWkmkwuapoGfdpCe8oU85tRFYF/ckXEaPZPfBaYh2mHY9WV1CdoeJ
# l2l6SPDgohIbZpp0yt5LHucOY67m1O+SkjqePdwA5EUlibaaRBkrfsCUtNJhbesz
# 2cXfSwQAzH0clcOP9yGyshG3u3/y1YxwLEFgqrFjGESVGnZifvaAsPvoZKYz0YkH
# 4b235kOkGLimdwHhD5QMIR2yVCkliWzlDlJRR3S+Jqy2QXXeeqxfjT/JvNNBERJb
# 5RBQ6zHFynIWIgnffEx1P2PsIV/EIFFrb7GrhotPwtZFX50g/KEexcCPorF+CiaZ
# 9eRpL5gdLfXZqbId5RsCAwEAAaOCATowggE2MA8GA1UdEwEB/wQFMAMBAf8wHQYD
# VR0OBBYEFOzX44LScV1kTN8uZz/nupiuHA9PMB8GA1UdIwQYMBaAFEXroq/0ksuC
# MS1Ri6enIZ3zbcgPMA4GA1UdDwEB/wQEAwIBhjB5BggrBgEFBQcBAQRtMGswJAYI
# KwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3
# aHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9v
# dENBLmNydDBFBgNVHR8EPjA8MDqgOKA2hjRodHRwOi8vY3JsMy5kaWdpY2VydC5j
# b20vRGlnaUNlcnRBc3N1cmVkSURSb290Q0EuY3JsMBEGA1UdIAQKMAgwBgYEVR0g
# ADANBgkqhkiG9w0BAQwFAAOCAQEAcKC/Q1xV5zhfoKN0Gz22Ftf3v1cHvZqsoYcs
# 7IVeqRq7IviHGmlUIu2kiHdtvRoU9BNKei8ttzjv9P+Aufih9/Jy3iS8UgPITtAq
# 3votVs/59PesMHqai7Je1M/RQ0SbQyHrlnKhSLSZy51PpwYDE3cnRNTnf+hZqPC/
# Lwum6fI0POz3A8eHqNJMQBk1RmppVLC4oVaO7KTVPeix3P0c2PR3WlxUjG/voVA9
# /HYJaISfb8rbII01YBwCA8sgsKxYoA5AY8WYIsGyWfVVa88nq2x2zm8jLfR+cWoj
# ayL/ErhULSd+2DrZ8LaHlv1b0VysGMNNn3O3AamfV6peKOK5lDCCBq4wggSWoAMC
# AQICEAc2N7ckVHzYR6z9KGYqXlswDQYJKoZIhvcNAQELBQAwYjELMAkGA1UEBhMC
# VVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UECxMQd3d3LmRpZ2ljZXJ0
# LmNvbTEhMB8GA1UEAxMYRGlnaUNlcnQgVHJ1c3RlZCBSb290IEc0MB4XDTIyMDMy
# MzAwMDAwMFoXDTM3MDMyMjIzNTk1OVowYzELMAkGA1UEBhMCVVMxFzAVBgNVBAoT
# DkRpZ2lDZXJ0LCBJbmMuMTswOQYDVQQDEzJEaWdpQ2VydCBUcnVzdGVkIEc0IFJT
# QTQwOTYgU0hBMjU2IFRpbWVTdGFtcGluZyBDQTCCAiIwDQYJKoZIhvcNAQEBBQAD
# ggIPADCCAgoCggIBAMaGNQZJs8E9cklRVcclA8TykTepl1Gh1tKD0Z5Mom2gsMyD
# +Vr2EaFEFUJfpIjzaPp985yJC3+dH54PMx9QEwsmc5Zt+FeoAn39Q7SE2hHxc7Gz
# 7iuAhIoiGN/r2j3EF3+rGSs+QtxnjupRPfDWVtTnKC3r07G1decfBmWNlCnT2exp
# 39mQh0YAe9tEQYncfGpXevA3eZ9drMvohGS0UvJ2R/dhgxndX7RUCyFobjchu0Cs
# X7LeSn3O9TkSZ+8OpWNs5KbFHc02DVzV5huowWR0QKfAcsW6Th+xtVhNef7Xj3OT
# rCw54qVI1vCwMROpVymWJy71h6aPTnYVVSZwmCZ/oBpHIEPjQ2OAe3VuJyWQmDo4
# EbP29p7mO1vsgd4iFNmCKseSv6De4z6ic/rnH1pslPJSlRErWHRAKKtzQ87fSqEc
# azjFKfPKqpZzQmiftkaznTqj1QPgv/CiPMpC3BhIfxQ0z9JMq++bPf4OuGQq+nUo
# JEHtQr8FnGZJUlD0UfM2SU2LINIsVzV5K6jzRWC8I41Y99xh3pP+OcD5sjClTNfp
# mEpYPtMDiP6zj9NeS3YSUZPJjAw7W4oiqMEmCPkUEBIDfV8ju2TjY+Cm4T72wnSy
# Px4JduyrXUZ14mCjWAkBKAAOhFTuzuldyF4wEr1GnrXTdrnSDmuZDNIztM2xAgMB
# AAGjggFdMIIBWTASBgNVHRMBAf8ECDAGAQH/AgEAMB0GA1UdDgQWBBS6FtltTYUv
# cyl2mi91jGogj57IbzAfBgNVHSMEGDAWgBTs1+OC0nFdZEzfLmc/57qYrhwPTzAO
# BgNVHQ8BAf8EBAMCAYYwEwYDVR0lBAwwCgYIKwYBBQUHAwgwdwYIKwYBBQUHAQEE
# azBpMCQGCCsGAQUFBzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wQQYIKwYB
# BQUHMAKGNWh0dHA6Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0
# ZWRSb290RzQuY3J0MEMGA1UdHwQ8MDowOKA2oDSGMmh0dHA6Ly9jcmwzLmRpZ2lj
# ZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRSb290RzQuY3JsMCAGA1UdIAQZMBcwCAYG
# Z4EMAQQCMAsGCWCGSAGG/WwHATANBgkqhkiG9w0BAQsFAAOCAgEAfVmOwJO2b5ip
# RCIBfmbW2CFC4bAYLhBNE88wU86/GPvHUF3iSyn7cIoNqilp/GnBzx0H6T5gyNgL
# 5Vxb122H+oQgJTQxZ822EpZvxFBMYh0MCIKoFr2pVs8Vc40BIiXOlWk/R3f7cnQU
# 1/+rT4osequFzUNf7WC2qk+RZp4snuCKrOX9jLxkJodskr2dfNBwCnzvqLx1T7pa
# 96kQsl3p/yhUifDVinF2ZdrM8HKjI/rAJ4JErpknG6skHibBt94q6/aesXmZgaNW
# hqsKRcnfxI2g55j7+6adcq/Ex8HBanHZxhOACcS2n82HhyS7T6NJuXdmkfFynOlL
# AlKnN36TU6w7HQhJD5TNOXrd/yVjmScsPT9rp/Fmw0HNT7ZAmyEhQNC3EyTN3B14
# OuSereU0cZLXJmvkOHOrpgFPvT87eK1MrfvElXvtCl8zOYdBeHo46Zzh3SP9HSjT
# x/no8Zhf+yvYfvJGnXUsHicsJttvFXseGYs2uJPU5vIXmVnKcPA3v5gA3yAWTyf7
# YGcWoWa63VXAOimGsJigK+2VQbc61RWYMbRiCQ8KvYHZE/6/pNHzV9m8BPqC3jLf
# BInwAM1dwvnQI38AC+R2AibZ8GV2QqYphwlHK+Z/GqSFD/yYlvZVVCsfgPrA8g4r
# 5db7qS9EFUrnEw4d2zc4GqEr9u3WfPwwggbGMIIErqADAgECAhAKekqInsmZQpAG
# YzhNhpedMA0GCSqGSIb3DQEBCwUAMGMxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5E
# aWdpQ2VydCwgSW5jLjE7MDkGA1UEAxMyRGlnaUNlcnQgVHJ1c3RlZCBHNCBSU0E0
# MDk2IFNIQTI1NiBUaW1lU3RhbXBpbmcgQ0EwHhcNMjIwMzI5MDAwMDAwWhcNMzMw
# MzE0MjM1OTU5WjBMMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIElu
# Yy4xJDAiBgNVBAMTG0RpZ2lDZXJ0IFRpbWVzdGFtcCAyMDIyIC0gMjCCAiIwDQYJ
# KoZIhvcNAQEBBQADggIPADCCAgoCggIBALkqliOmXLxf1knwFYIY9DPuzFxs4+Al
# LtIx5DxArvurxON4XX5cNur1JY1Do4HrOGP5PIhp3jzSMFENMQe6Rm7po0tI6IlB
# fw2y1vmE8Zg+C78KhBJxbKFiJgHTzsNs/aw7ftwqHKm9MMYW2Nq867Lxg9GfzQnF
# uUFqRUIjQVr4YNNlLD5+Xr2Wp/D8sfT0KM9CeR87x5MHaGjlRDRSXw9Q3tRZLER0
# wDJHGVvimC6P0Mo//8ZnzzyTlU6E6XYYmJkRFMUrDKAz200kheiClOEvA+5/hQLJ
# huHVGBS3BEXz4Di9or16cZjsFef9LuzSmwCKrB2NO4Bo/tBZmCbO4O2ufyguwp7g
# C0vICNEyu4P6IzzZ/9KMu/dDI9/nw1oFYn5wLOUrsj1j6siugSBrQ4nIfl+wGt0Z
# vZ90QQqvuY4J03ShL7BUdsGQT5TshmH/2xEvkgMwzjC3iw9dRLNDHSNQzZHXL537
# /M2xwafEDsTvQD4ZOgLUMalpoEn5deGb6GjkagyP6+SxIXuGZ1h+fx/oK+QUshbW
# gaHK2jCQa+5vdcCwNiayCDv/vb5/bBMY38ZtpHlJrYt/YYcFaPfUcONCleieu5tL
# suK2QT3nr6caKMmtYbCgQRgZTu1Hm2GV7T4LYVrqPnqYklHNP8lE54CLKUJy93my
# 3YTqJ+7+fXprAgMBAAGjggGLMIIBhzAOBgNVHQ8BAf8EBAMCB4AwDAYDVR0TAQH/
# BAIwADAWBgNVHSUBAf8EDDAKBggrBgEFBQcDCDAgBgNVHSAEGTAXMAgGBmeBDAEE
# AjALBglghkgBhv1sBwEwHwYDVR0jBBgwFoAUuhbZbU2FL3MpdpovdYxqII+eyG8w
# HQYDVR0OBBYEFI1kt4kh/lZYRIRhp+pvHDaP3a8NMFoGA1UdHwRTMFEwT6BNoEuG
# SWh0dHA6Ly9jcmwzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNFJTQTQw
# OTZTSEEyNTZUaW1lU3RhbXBpbmdDQS5jcmwwgZAGCCsGAQUFBwEBBIGDMIGAMCQG
# CCsGAQUFBzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wWAYIKwYBBQUHMAKG
# TGh0dHA6Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNFJT
# QTQwOTZTSEEyNTZUaW1lU3RhbXBpbmdDQS5jcnQwDQYJKoZIhvcNAQELBQADggIB
# AA0tI3Sm0fX46kuZPwHk9gzkrxad2bOMl4IpnENvAS2rOLVwEb+EGYs/XeWGT76T
# Ot4qOVo5TtiEWaW8G5iq6Gzv0UhpGThbz4k5HXBw2U7fIyJs1d/2WcuhwupMdsqh
# 3KErlribVakaa33R9QIJT4LWpXOIxJiA3+5JlbezzMWn7g7h7x44ip/vEckxSli2
# 3zh8y/pc9+RTv24KfH7X3pjVKWWJD6KcwGX0ASJlx+pedKZbNZJQfPQXpodkTz5G
# iRZjIGvL8nvQNeNKcEiptucdYL0EIhUlcAZyqUQ7aUcR0+7px6A+TxC5MDbk86pp
# CaiLfmSiZZQR+24y8fW7OK3NwJMR1TJ4Sks3KkzzXNy2hcC7cDBVeNaY/lRtf3Gp
# SBp43UZ3Lht6wDOK+EoojBKoc88t+dMj8p4Z4A2UKKDr2xpRoJWCjihrpM6ddt6p
# c6pIallDrl/q+A8GQp3fBmiW/iqgdFtjZt5rLLh4qk1wbfAs8QcVfjW05rUMopml
# 1xVrNQ6F1uAszOAMJLh8UgsemXzvyMjFjFhpr6s94c/MfRWuFL+Kcd/Kl7HYR+oc
# heBFThIcFClYzG/Tf8u+wQ5KbyCcrtlzMlkI5y2SoRoR/jKYpl0rl+CL05zMbbUN
# rkdjOEcXW28T2moQbh9Jt0RbtAgKh1pZBHYRoad3AhMcMYIFBjCCBQICAQEwQTAt
# MSswKQYDVQQDDCJTZXR1cEJhc2UgQ29kZSBTaWduaW5nIENlcnRpZmljYXRlAhAv
# ocerCgUhoEr6/ghfty9QMAkGBSsOAwIaBQCgeDAYBgorBgEEAYI3AgEMMQowCKAC
# gAChAoAAMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisGAQQBgjcCAQsx
# DjAMBgorBgEEAYI3AgEVMCMGCSqGSIb3DQEJBDEWBBQAwQGyEFV3OU3/VypL4MYG
# lCYMTzANBgkqhkiG9w0BAQEFAASCAQBFmke4WAHTrDZF5Orfwv7IsXNUl2yrrUYR
# eDzO6Epjh2Lp/Uvs0rfNGW8UBGHCBu3hnVtV16c66+3GQMssv1OESfbfIEFJAx80
# Rsyp4KkwdrwydW9dJf2hb5OHcDHQdPZPGVpAFMZkMpuW3DeYHJ8YQGlkD95dmVxk
# OC4H2v9poCFGOBaR93zrDkfZLUaX52OJ/IMKYYk5Sj1/4FWtMOQkxpjek9MLTAKg
# BkbGXi4xYd79Fz28TN0JWgrRcP9vzIPLTCVWTyc++k0BYZZa1zvvd8WidwugiM1k
# uPi32hX1nuWtuwgR5ApZ0ID3DWHvx6UDYSlOOGBdTaBMphhwd72loYIDIDCCAxwG
# CSqGSIb3DQEJBjGCAw0wggMJAgEBMHcwYzELMAkGA1UEBhMCVVMxFzAVBgNVBAoT
# DkRpZ2lDZXJ0LCBJbmMuMTswOQYDVQQDEzJEaWdpQ2VydCBUcnVzdGVkIEc0IFJT
# QTQwOTYgU0hBMjU2IFRpbWVTdGFtcGluZyBDQQIQCnpKiJ7JmUKQBmM4TYaXnTAN
# BglghkgBZQMEAgEFAKBpMBgGCSqGSIb3DQEJAzELBgkqhkiG9w0BBwEwHAYJKoZI
# hvcNAQkFMQ8XDTIyMDgyNDE5NTg0OFowLwYJKoZIhvcNAQkEMSIEIK3QeEbnvXOK
# gmOH4tAkYLAf0H6DIme2DeP86nrpmCGrMA0GCSqGSIb3DQEBAQUABIICAGMhvSH2
# pxcTmIh/mjmQZizpSSRQulAPXVsMxj7tEKNmyjJC5Sm4QjgJcNUw/Jsq9eMBTtvt
# T23QsJsDYvTMCA7irsPBkEU7AnDO9AosYNwDXAPYlO2Pp0yKIMDIGNt2NrNRiYHR
# Nx4evOJzGfnRYZtZ3BwMAwSk829HSQP54dFY3eXgZ5qZoQJ5nDLCHS6ACqx9gsJ+
# dy66RrHCx+amOHTV9BRM07YUky8g2pfVk04V727lafUQMRVND9/cTK0IzGj4KpII
# o44ucOakxcpG4MpzLD+GNJ+rbzDDzcI1l0KzP5mioHTkcZ/TdvrVDdSmoxS7dV5Q
# 8ZwXjeSFOlGX1LO6mgpki190L6uIbXkJZgq3XN+d1Cu1q0xukBf5IlRphnM9MiJ6
# TD2aYEcMDhfutGuMWBE9NzQSjGE8CuCela8uihYEOM7+OuNAUNllh0sxONGl7H2e
# jLfCGKIPwifg+sWJext6WjlbwX3E4DIVcpJQqgifYEE90lSVMDsZhC2PEq5wu+QF
# pusTqJeRHRdoyIFf3J8rWs8lUHoaZtNhOOJ6xbxRtb7L0734eXyrLNuZTCKUYZPA
# 8F5NDWXdGF0N4qiWKz5fwgL2YVMI69u9lxM+YmmPBM+Q2afQV7ifFZz260R0MibQ
# WMuu3Zr0ka5lpnmerSNXcs875SiL7TLfANHy
# SIG # End signature block