lvfengfree b92e1119ae fix: 修复菜单为空问题 - 移除后端过滤home路由的错误逻辑
- 修复RouteService中错误过滤home路由的问题
- 后端现在正确返回所有用户有权限的路由
- 添加设备管理相关功能(列表、在线监控、电源管理、远程监控)
- 添加详细的修复文档和重启脚本
- 更新权限配置脚本

问题根源:后端代码中有逻辑会过滤掉home路由,导致前端收到空数组,无法生成菜单
解决方案:移除过滤home路由的逻辑,让后端返回所有有权限的路由
2026-03-01 09:50:19 +08:00

726 lines
33 KiB
PowerShell
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Copyright (C) 2007 Intel Corporation
Function Set-AMTSystemDefense {
<#
.Synopsis
Enables Intel Active Management Technology System Defense
.Description
This CmdLet disables network access using Intel Active Management Technology (AMT) System Defense from clients that have Intel AMT Firmware version 3.0 and Higher.
.Notes
Supported AMT Firmware Versions: 3.0 and higher
AMT Provisioning:
The vPro client AMT firmware must be provisioned prior to accessing AMT functionality. This Cmdlet will fail if it is run against a vPro client that has not been provisioned.
AMT Client Authentication:
To invoke commands against AMT enabled clients credentials to authenticate must be specified.
When no credential is provided as a parameter, the script will use the local logged on Kerberos credential.
When only the username (Kerberos or Digest) parameter is included the user will be prompted to provide the associated password.
Credentials should be stored as a PowerShell variable then passed into the Cmdlet with the credential parameter.
$AMTCredential = get-credential
AMT Client Encryption:
If the Intel vPro client has been configured to use TLS (a web server certificate has been issued to the Intel Management Engine) the Cmdlet must be called with a -TLS switch.
When managing an Intel vPro client over TLS (Port 16993) it is important that the computername parameter matchs the primary subject name of the issued TLS certificate. Typically this is the fully qualified domain name (FQDN).
Status:
Status output designates if the Cmdlet was run successfully. For failed attempts additional status may be provided.
.Link
http:\\vproexpert.com
http:\\www.intel.com\vpro
http:\\www.intel.com
.Example
Set-AMTSystemDefense vproclient.vprodemo.com -TLS
ComputerName Port Status EnabledOnInterfaces
------------ ---- ------ -------------------
vproclient.vprodemo.com 16993 Successful Wireless1, Wired
.Example
Set-AMTSystemDefense vproclient 16992 -username:amtuser
Will prompt for digest username password.
ComputerName Port Status EnabledOnInterfaces
------------ ---- ------ -------------------
vproclient 16992 Successful Wireless1, Wired0
.Example
Get-Content computers.txt | Set-AMTSystemDefense -TLS
Will pull the list of amt clients from a text file and pipe them into Set-AMTSystemDefense
ComputerName Port Status EnabledOnInterfaces
------------ ---- ------ -------------------
Computer1.vprodemo.com 16993 Successful Wireless1, Wired0
Computer2.vprodemo.com 16993 Successful Wired0
.Example
Set-AMTSystemDefense vproclient.vprodemo.com -TLS -XMLConfig xmlfile.xml
Here is the outline of the xml format, see 'System Defense' in the AMT SDK for more details.
http://software.intel.com/sites/manageability/AMT_Implementation_and_Reference_Guide/default.htm
<?xml version="1.0"?>
<SystemDefensePolicySet>
<ArrayOfFilter xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Filter xsi:type="AMT_Hdr8021Filter">
<Name/>
<PolicyName/>
<CreationClassName/>
<SystemName/>
<SystemCreationClassName/>
<FilterProfile/>
<FilterDirection/>
<ActionEventOnMatch/>
<HdrProtocolID8021/>
</Filter>
<Filter xsi:type="AMT_IPHeadersFilter">
<Name/>
<PolicyName/>
<CreationClassName/>
<SystemName/>
<SystemCreationClassName/>
<HdrIPVersion/>
<HdrProtocolID/>
<FilterProfile/>
<FilterDirection/>
<ActionEventOnMatch/>
<HdrDestAddress/>
<HdrDestMask/>
<HdrDestPortStart/>
<HdrDestPortEnd/>
</Filter>
</ArrayOfFilter>
<ArrayOfPolicies xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Policy xsi:type="AMT_systemDefensePolicy">
<PolicyName/>
<PolicyPrecedence/>
<AntiSpoofingSupport/>
<TxDefaultDrop/>
<TxDefaultMatchEvent/>
<TxDefaultCount/>
<RxDefaultDrop/>
<RxDefaultMatchEvent/>
<RxDefaultCount/>
<Active/>
</Policy>
</ArrayOfPolicies>
</SystemDefensePolicySet>
#>
[CmdletBinding()]
Param (
[Parameter(Mandatory=$true,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$true, position=0, HelpMessage="Hostname, FQDN, or IP Address")] [String[]] $ComputerName,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="Valid Ports are 16992 (non-TLS) or 16993 (TLS)")][ValidateSet("16992", "16993")] [String] $Port,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="Use TLS (Port 16993)")] [switch] $TLS,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="Accept self-signed certificate for TLS connection (skip any certificate checks.)")] [switch] $AcceptSelfSignedCert,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="Digest of Kerberos User")] [string] $Username,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="Digest of Kerberos Password")] [string] $Password,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="PS Credential")] [System.Management.Automation.PSCredential] $Credential,
[Parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true,ValueFromPipeline=$false, HelpMessage="Path to XMl configuration file")] [string] $XMLConfig
)
PROCESS {
$defaultXML = @'
<?xml version="1.0"?>
<SystemDefensePolicySet>
<ArrayOfFilter xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Filter xsi:type="AMT_Hdr8021Filter">
<Name>defaultBlock</Name>
<PolicyName>defaultPolicy</PolicyName>
<CreationClassName>n/a</CreationClassName>
<SystemName>n/a</SystemName>
<SystemCreationClassName>n/a</SystemCreationClassName>
<FilterProfile>1</FilterProfile>
<FilterDirection>0</FilterDirection>
<ActionEventOnMatch>false</ActionEventOnMatch>
<HdrProtocolID8021>2048</HdrProtocolID8021>
</Filter>
</ArrayOfFilter>
<ArrayOfPolicies xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Policy xsi:type="AMT_systemDefensePolicy">
<PolicyName>defaultPolicy</PolicyName>
<PolicyPrecedence>0</PolicyPrecedence>
<AntiSpoofingSupport>3</AntiSpoofingSupport>
<TxDefaultDrop>false</TxDefaultDrop>
<TxDefaultMatchEvent>false</TxDefaultMatchEvent>
<TxDefaultCount>true</TxDefaultCount>
<RxDefaultDrop>false</RxDefaultDrop>
<RxDefaultMatchEvent>true</RxDefaultMatchEvent>
<RxDefaultCount>false</RxDefaultCount>
<Active>true</Active>
</Policy>
</ArrayOfPolicies>
</SystemDefensePolicySet>
'@
if($XMLConfig) {
[xml]$data = get-content $XMLConfig
} else {
[xml]$data = $defaultXML
}
$filterList = $data.selectnodes("/SystemDefensePolicySet/ArrayOfFilter/Filter")
$Results = @()
try
{
$Obj = new-object psobject
$Connection = New-Object Intel.Management.Wsman.WsmanConnection
if ($credential.username.Length -gt 0)
{
$Connection.SetCredentials($credential.Username, $credential.Password)
}
elseif ($username.length -gt 0)
{
if ($password.length -gt 0)
{
$passwd = ConvertTo-SecureString $Password -AsPlainText Force
$Connection.SetCredentials($Username, $passwd)
}
else
{
$cred = Get-Credential $username
$Connection.SetCredentials($cred.Username, $cred.Password)
}
}
if ($Port.Length -lt 1) {
if ($TLS.IsPresent) {
$Port = 16993;
}
else {
$Port = 16992;
}
}
if($AcceptSelfSignedCert.IsPresent)
{
$Connection.Options.AcceptSelfSignedCertificate=$true;
}
Foreach ($comp in $ComputerName)
{
$Connection.SetHost($comp, $port)
# Enable
$Obj | Add-Member -MemberType noteproperty -Name ComputerName -value $Comp
$Obj | Add-Member -MemberType noteproperty -Name Port -value $port
$EnabledInterfaces = ""
$cport = $Connection.NewReference("http://schemas.dmtf.org/wbem/wscim/1/cim-schema/2/CIM_EthernetPort")
try
{
$cportEnumeration = $cport.Enumerate($null, $null)
}
catch
{
$Obj | Add-Member -MemberType noteproperty -Name "Status" -value "Failed"
$Obj | Add-Member -MemberType noteproperty -Name "EnabledOnInterfaces" -value ""
$Results += $Obj
continue
}
Write-Output $Results
$filterTable = @{}
foreach($filter in $filterList)
{
if($filter.type -eq "AMT_Hdr8021Filter")
{
$AMT_Hdr8021Filter = $Connection.NewInstance("http://intel.com/wbem/wscim/1/amt-schema/1/AMT_Hdr8021Filter")
$AMT_Hdr8021Filter.AddProperty("InstanceID","0")
if($filter.Name)
{
$AMT_Hdr8021Filter.AddProperty("Name",$filter.Name)
}
if($filter.CreationClassName)
{
$AMT_Hdr8021Filter.AddProperty("CreationClassName",$filter.CreationClassName)
}
if($filter.SystemName)
{
$AMT_Hdr8021Filter.AddProperty("SystemName", $filter.SystemName)
}
if($filter.SystemCreationClassName)
{
$AMT_Hdr8021Filter.AddProperty("SystemCreationClassName", $filter.SystemCreationClassName)
}
if($filter.HdrProtocolID8021)
{
$AMT_Hdr8021Filter.AddProperty("HdrProtocolID8021", $filter.HdrProtocolID8021)
}
if($filter.FilterProfile)
{
$AMT_Hdr8021Filter.AddProperty("FilterProfile", $filter.FilterProfile)
}
if($filter.FilterDirection)
{
$AMT_Hdr8021Filter.AddProperty("FilterDirection", $filter.FilterDirection)
}
if($filter.ActionEventOnMatch)
{
$AMT_Hdr8021Filter.AddProperty("ActionEventOnMatch", $filter.ActionEventOnMatch)
}
if($filter.FilterProfileData)
{
$AMT_Hdr8021Filter.AddProperty("FilterProfileData", $filter.FilterProfileData)
}
$ID = $AMT_Hdr8021Filter.Create().Get().GetProperty("InstanceID").ToString()
$filterTable[$ID] = $filter.PolicyName
}
if($filter.type -eq "AMT_IPHeadersFilter")
{
$AMT_IPHeadersFilter = $Connection.NewInstance("http://intel.com/wbem/wscim/1/amt-schema/1/AMT_IPHeadersFilter")
$AMT_IPHeadersFilter.AddProperty("InstanceID","0")
if($filter.Name)
{
$AMT_IPHeadersFilter.AddProperty("Name",$filter.Name)
}
if($filter.CreationClassName)
{
$AMT_IPHeadersFilter.AddProperty("CreationClassName",$filter.CreationClassName)
}
if($filter.SystemName)
{
$AMT_IPHeadersFilter.AddProperty("SystemName", $filter.SystemName)
}
if($filter.SystemCreationClassName)
{
$AMT_IPHeadersFilter.AddProperty("SystemCreationClassName", $filter.SystemCreationClassName)
}
if($filter.FilterProfile)
{
$AMT_IPHeadersFilter.AddProperty("FilterProfile", $filter.FilterProfile)
}
if($filter.FilterDirection)
{
$AMT_IPHeadersFilter.AddProperty("FilterDirection", $filter.FilterDirection)
}
if($filter.ActionEventOnMatch)
{
$AMT_IPHeadersFilter.AddProperty("ActionEventOnMatch", $filter.ActionEventOnMatch)
}
if($filter.HdrIPVersion)
{
$AMT_IPHeadersFilter.AddProperty("HdrIPVersion", $filter.HdrIPVersion)
}
if($filter.HdrSrcAddress)
{
$AMT_IPHeadersFilter.AddProperty("HdrDestAddress", $filter.HdrDestAddress)
}
if($filter.HdrSrcMask)
{
$AMT_IPHeadersFilter.AddProperty("HdrDestMask", $filter.HdrDestMask)
}
if($filter.HdrDestAddress)
{
$AMT_IPHeadersFilter.AddProperty("HdrDestAddress", $filter.HdrDestAddress)
}
if($filter.HdrDestMask)
{
$AMT_IPHeadersFilter.AddProperty("HdrDestMask", $filter.HdrDestMask)
}
if($filter.HdrProtocolID)
{
$AMT_IPHeadersFilter.AddProperty("HdrProtocolID", $filter.HdrProtocolID)
}
if($filter.HdrSrcPortStart)
{
$AMT_IPHeadersFilter.AddProperty("HdrSrcPortStart", $filter.HdrSrcPortStart)
}
if($filter.HdrSrcPortEnd)
{
$AMT_IPHeadersFilter.AddProperty("HdrSrcPortEnd", $filter.HdrSrcPortEnd)
}
if($filter.HdrDestPortStart)
{
$AMT_IPHeadersFilter.AddProperty("HdrDestPortStart", $filter.HdrDestPortStart)
}
if($filter.HdrDestPortEnd)
{
$AMT_IPHeadersFilter.AddProperty("HdrDestPortEnd", $filter.HdrDestPortEnd)
}
if($filter.TCPFlagsOn)
{
$AMT_IPHeadersFilter.AddProperty("TCPFlagsOn ", $filter.TCPFlagsOn)
}
if($filter.TCPFlagsOff)
{
$AMT_IPHeadersFilter.AddProperty("TCPFlagsOff ", $filter.TCPFlagsOff)
}
if($filter.FilterProfileData)
{
$AMT_IPHeadersFilter.AddProperty("FilterProfileData ", $filter.FilterProfileData)
}
$ID = $AMT_IPHeadersFilter.Create().Get().GetProperty("InstanceID").ToString()
$filterTable[$ID] = $filter.PolicyName
}
}
$policyList= $data.selectnodes("/SystemDefensePolicySet/ArrayOfPolicies/Policy")
foreach($policy in $policyList)
{
$AMT_SystemDefensePolicy = $Connection.NewInstance("http://intel.com/wbem/wscim/1/amt-schema/1/AMT_SystemDefensePolicy")
$AMT_SystemDefensePolicy.AddProperty("InstanceID","n/a")
if($policy.PolicyName)
{
$AMT_SystemDefensePolicy.AddProperty("PolicyName", $policy.PolicyName)
}
if($policy.PolicyPrecedence)
{
$AMT_SystemDefensePolicy.AddProperty("PolicyPrecedence", $policy.PolicyPrecedence)
}
if($policy.AntiSpoofingSupport)
{
$AMT_SystemDefensePolicy.AddProperty("AntiSpoofingSupport", $policy.AntiSpoofingSupport)
}
if($policy.TxDefaultDrop)
{
$AMT_SystemDefensePolicy.AddProperty("TxDefaultDrop", $policy.TxDefaultDrop)
}
if($policy.TxDefaultMatchEvent)
{
$AMT_SystemDefensePolicy.AddProperty("TxDefaultMatchEvent", $policy.TxDefaultMatchEvent)
}
if($policy.TxDefaultCount)
{
$AMT_SystemDefensePolicy.AddProperty("TxDefaultCount", $policy.TxDefaultCount)
}
if($policy.RxDefaultDrop)
{
$AMT_SystemDefensePolicy.AddProperty("RxDefaultDrop", $policy.RxDefaultDrop)
}
if($policy.RxDefaultMatchEvent)
{
$AMT_SystemDefensePolicy.AddProperty("RxDefaultMatchEvent", $policy.RxDefaultMatchEvent)
}
if($policy.RxDefaultCount)
{
$AMT_SystemDefensePolicy.AddProperty("RxDefaultCount", $policy.RxDefaultCount)
}
foreach($filterID in $filterTable.GetEnumerator())
{
if($filterID.Value -eq $policy.policyName)
{
$AMT_SystemDefensePolicy.AddProperty("FilterCreationHandles", $FilterID.Name)
}
}
$Policy_EPR = $AMT_SystemDefensePolicy.Create()
if($policy.Active)
{
$ActivePolicy_EPR = $Policy_EPR
}
}
if($ActivePolicy_EPR)
{
while($cportEnumeration.HasNext)
{
$portReference = $cportEnumeration.Next().Object
[System.String[]] $EthernetPort_KeyNames = "CreationClassName", "DeviceID", "SystemCreationClassName", "SystemName"
$EthernetPort_EPR = $portReference.ToReference($EthernetPort_KeyNames)
$NetworkPolicy = $Connection.NewInstance("http://intel.com/wbem/wscim/1/amt-schema/1/AMT_NetworkPortSystemDefensePolicy")
$NetworkPolicy.AddProperty("Antecedent",$EthernetPort_EPR)
$NetworkPolicy.AddProperty("Dependent",$ActivePolicy_EPR)
$NetworkPolicy.AddProperty("Enabled","true")
$NetworkPolicy.AddProperty("Active","true")
$NetoworkPolicyObject = $NetworkPolicy.Create()
$EthernetPortName = $portReference.GetProperty("Description").ToString()
if($EnabledInterfaces -eq "")
{
$EnabledInterfaces = $EthernetPortName
}
else
{
$EnabledInterfaces = $EnabledInterfaces +", " + $EthernetPortName
}
}
$Obj | Add-Member -MemberType noteproperty -Name "Status" -value "Successful"
$Obj | Add-Member -MemberType noteproperty -Name "EnabledOnInterfaces" -value $EnabledInterfaces
$Results += $Obj
}
}
}
catch
{
$Obj | Add-Member -MemberType noteproperty -Name "Status" -value "Failed"
$Obj | Add-Member -MemberType noteproperty -Name "EnabledOnInterfaces" -value $EnabledInterfaces
$Obj | Add-Member -MemberType noteproperty -Name "Reason" -value $_.Exception.Message
$Results += $Obj
}
# Set back to false for the next cmdlet, if PS is still open
$Connection.Options.AcceptSelfSignedCertificate=$false;
Write-Output $Results
}
}
# SIG # Begin signature block
# MIItiwYJKoZIhvcNAQcCoIItfDCCLXgCAQExDzANBglghkgBZQMEAgEFADB5Bgor
# BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG
# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCDGCXgemKLheHLn
# E6Ny9lMex+X3iqUOj6Guuqm12cg7BqCCEX4wggVvMIIEV6ADAgECAhBI/JO0YFWU
# jTanyYqJ1pQWMA0GCSqGSIb3DQEBDAUAMHsxCzAJBgNVBAYTAkdCMRswGQYDVQQI
# DBJHcmVhdGVyIE1hbmNoZXN0ZXIxEDAOBgNVBAcMB1NhbGZvcmQxGjAYBgNVBAoM
# EUNvbW9kbyBDQSBMaW1pdGVkMSEwHwYDVQQDDBhBQUEgQ2VydGlmaWNhdGUgU2Vy
# dmljZXMwHhcNMjEwNTI1MDAwMDAwWhcNMjgxMjMxMjM1OTU5WjBWMQswCQYDVQQG
# EwJHQjEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMS0wKwYDVQQDEyRTZWN0aWdv
# IFB1YmxpYyBDb2RlIFNpZ25pbmcgUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEBAQUA
# A4ICDwAwggIKAoICAQCN55QSIgQkdC7/FiMCkoq2rjaFrEfUI5ErPtx94jGgUW+s
# hJHjUoq14pbe0IdjJImK/+8Skzt9u7aKvb0Ffyeba2XTpQxpsbxJOZrxbW6q5KCD
# J9qaDStQ6Utbs7hkNqR+Sj2pcaths3OzPAsM79szV+W+NDfjlxtd/R8SPYIDdub7
# P2bSlDFp+m2zNKzBenjcklDyZMeqLQSrw2rq4C+np9xu1+j/2iGrQL+57g2extme
# me/G3h+pDHazJyCh1rr9gOcB0u/rgimVcI3/uxXP/tEPNqIuTzKQdEZrRzUTdwUz
# T2MuuC3hv2WnBGsY2HH6zAjybYmZELGt2z4s5KoYsMYHAXVn3m3pY2MeNn9pib6q
# RT5uWl+PoVvLnTCGMOgDs0DGDQ84zWeoU4j6uDBl+m/H5x2xg3RpPqzEaDux5mcz
# mrYI4IAFSEDu9oJkRqj1c7AGlfJsZZ+/VVscnFcax3hGfHCqlBuCF6yH6bbJDoEc
# QNYWFyn8XJwYK+pF9e+91WdPKF4F7pBMeufG9ND8+s0+MkYTIDaKBOq3qgdGnA2T
# OglmmVhcKaO5DKYwODzQRjY1fJy67sPV+Qp2+n4FG0DKkjXp1XrRtX8ArqmQqsV/
# AZwQsRb8zG4Y3G9i/qZQp7h7uJ0VP/4gDHXIIloTlRmQAOka1cKG8eOO7F/05QID
# AQABo4IBEjCCAQ4wHwYDVR0jBBgwFoAUoBEKIz6W8Qfs4q8p74Klf9AwpLQwHQYD
# VR0OBBYEFDLrkpr/NZZILyhAQnAgNpFcF4XmMA4GA1UdDwEB/wQEAwIBhjAPBgNV
# HRMBAf8EBTADAQH/MBMGA1UdJQQMMAoGCCsGAQUFBwMDMBsGA1UdIAQUMBIwBgYE
# VR0gADAIBgZngQwBBAEwQwYDVR0fBDwwOjA4oDagNIYyaHR0cDovL2NybC5jb21v
# ZG9jYS5jb20vQUFBQ2VydGlmaWNhdGVTZXJ2aWNlcy5jcmwwNAYIKwYBBQUHAQEE
# KDAmMCQGCCsGAQUFBzABhhhodHRwOi8vb2NzcC5jb21vZG9jYS5jb20wDQYJKoZI
# hvcNAQEMBQADggEBABK/oe+LdJqYRLhpRrWrJAoMpIpnuDqBv0WKfVIHqI0fTiGF
# OaNrXi0ghr8QuK55O1PNtPvYRL4G2VxjZ9RAFodEhnIq1jIV9RKDwvnhXRFAZ/ZC
# J3LFI+ICOBpMIOLbAffNRk8monxmwFE2tokCVMf8WPtsAO7+mKYulaEMUykfb9gZ
# pk+e96wJ6l2CxouvgKe9gUhShDHaMuwV5KZMPWw5c9QLhTkg4IUaaOGnSDip0TYl
# d8GNGRbFiExmfS9jzpjoad+sPKhdnckcW67Y8y90z7h+9teDnRGWYpquRRPaf9xH
# +9/DUp/mBlXpnYzyOmJRvOwkDynUWICE5EV7WtgwggXpMIIEUaADAgECAhEA/lzU
# lQGKZRek0E74e2uTOjANBgkqhkiG9w0BAQwFADBUMQswCQYDVQQGEwJHQjEYMBYG
# A1UEChMPU2VjdGlnbyBMaW1pdGVkMSswKQYDVQQDEyJTZWN0aWdvIFB1YmxpYyBD
# b2RlIFNpZ25pbmcgQ0EgUjM2MB4XDTI0MDMxMzAwMDAwMFoXDTI1MDMxMzIzNTk1
# OVowWjELMAkGA1UEBhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExGjAYBgNVBAoM
# EUludGVsIENvcnBvcmF0aW9uMRowGAYDVQQDDBFJbnRlbCBDb3Jwb3JhdGlvbjCC
# AaIwDQYJKoZIhvcNAQEBBQADggGPADCCAYoCggGBAI69Cz15squYBdM5ZXnjFBNn
# vqzI4WUgaQ/PjBKog2t/IkSByXK+3K1m4CwQtTgqpMCD193E3A/xDHmWVEvpCKUB
# +xc8c/8FE6TymrIKA/0UH7jVesLgCo0AxfM0dkcqrvLKvnchseekdaM2b+E41NSj
# AhhWgGp1LoTZyrAOJNpGsPIfgA/0+J6RCECh9BARbXCRXAnzTuPtWDXfKlOwSa4+
# o2tJM7TPNALTJSLHoZbvfUOpgOh+0lWx49himoW6lfDt5cZDPOT8wNwpd5DWwB8M
# hzLfNEpbvR/85s8SP/dWRrAVkSRxS1wqIZa9OsxD+rjBBIe8JDR1Y9hjGBUKybMA
# Y30Pp8rDpFeH1Ya1A8gNeae8KRSlacroyoxhRviL9n8nCZIhiqL6Q0Qu9cJGwlYi
# L9mAMRyVPI3BHf0s6r6BRqt8yBYP/2dsgc4z9YV9DGJUaKz2kjwud1OJZupFDZio
# +shzbO/h78iJSQiMVHgMVFEVOZFERE3dVSEFsWdPAwIDAQABo4IBrjCCAaowHwYD
# VR0jBBgwFoAUDyrLIIcouOxvSK4rVKYpqhekzQwwHQYDVR0OBBYEFCjtPWp/OnUU
# 51aXAiBwcQ/gvYfGMA4GA1UdDwEB/wQEAwIHgDAMBgNVHRMBAf8EAjAAMBMGA1Ud
# JQQMMAoGCCsGAQUFBwMDMEoGA1UdIARDMEEwNQYMKwYBBAGyMQECAQMCMCUwIwYI
# KwYBBQUHAgEWF2h0dHBzOi8vc2VjdGlnby5jb20vQ1BTMAgGBmeBDAEEATBJBgNV
# HR8EQjBAMD6gPKA6hjhodHRwOi8vY3JsLnNlY3RpZ28uY29tL1NlY3RpZ29QdWJs
# aWNDb2RlU2lnbmluZ0NBUjM2LmNybDB5BggrBgEFBQcBAQRtMGswRAYIKwYBBQUH
# MAKGOGh0dHA6Ly9jcnQuc2VjdGlnby5jb20vU2VjdGlnb1B1YmxpY0NvZGVTaWdu
# aW5nQ0FSMzYuY3J0MCMGCCsGAQUFBzABhhdodHRwOi8vb2NzcC5zZWN0aWdvLmNv
# bTAjBgNVHREEHDAagRhwa2llbmdpbmVlcmluZ0BpbnRlbC5jb20wDQYJKoZIhvcN
# AQEMBQADggGBAB01WGV1cWjtTCQGkNtDRpmS08NuUis1F2+0cwIrk2dY8tXKiZ5R
# supkBKWfpjNSHdW79DvVCotBbyRYUdDSeFkQ8jRPm+vlzyFhRWuW4qSYcIlx6qia
# pGZEFsvmEEXMnwG9zEEeKsYlnM/ZSI23uLZCXyhJx35G2PpBr3tMym6gIvta5Dml
# 4S/XEJJI/ZvIKhPO5QUemCS07S9QN7SOKeEkk1LdV1ccCBNtRpAzmGVr4iYS4pbV
# r8yishYe25TSAPeWEy9PYEMnjZbQQS8lD8XFB6gfiTJLFCCzIKsHzMIk+FuJlwVl
# q4ec/Wrx0+fpVeo2SPJZI/iE82gtD5oywotprC47MdvVlcvbePYnHoJqqRtnhX+E
# 6jlGRtnhUCPV+BsRScp4v8DIUJGdV5AzS5rYu3YhJGDJgTgPGvBtmvaPeJtxcKzX
# UnMpPtanuJgW3o1ucSo9SKb9dNqFcLcOUVD2lDjh85Z0anJom924xhVm4cGNWSF7
# az8cVA6zH/Rc6DCCBhowggQCoAMCAQICEGIdbQxSAZ47kHkVIIkhHAowDQYJKoZI
# hvcNAQEMBQAwVjELMAkGA1UEBhMCR0IxGDAWBgNVBAoTD1NlY3RpZ28gTGltaXRl
# ZDEtMCsGA1UEAxMkU2VjdGlnbyBQdWJsaWMgQ29kZSBTaWduaW5nIFJvb3QgUjQ2
# MB4XDTIxMDMyMjAwMDAwMFoXDTM2MDMyMTIzNTk1OVowVDELMAkGA1UEBhMCR0Ix
# GDAWBgNVBAoTD1NlY3RpZ28gTGltaXRlZDErMCkGA1UEAxMiU2VjdGlnbyBQdWJs
# aWMgQ29kZSBTaWduaW5nIENBIFIzNjCCAaIwDQYJKoZIhvcNAQEBBQADggGPADCC
# AYoCggGBAJsrnVP6NT+OYAZDasDP9X/2yFNTGMjO02x+/FgHlRd5ZTMLER4ARkZs
# Q3hAyAKwktlQqFZOGP/I+rLSJJmFeRno+DYDY1UOAWKA4xjMHY4qF2p9YZWhhbeF
# pPb09JNqFiTCYy/Rv/zedt4QJuIxeFI61tqb7/foXT1/LW2wHyN79FXSYiTxcv+1
# 8Irpw+5gcTbXnDOsrSHVJYdPE9s+5iRF2Q/TlnCZGZOcA7n9qudjzeN43OE/TpKF
# 2dGq1mVXn37zK/4oiETkgsyqA5lgAQ0c1f1IkOb6rGnhWqkHcxX+HnfKXjVodTmm
# V52L2UIFsf0l4iQ0UgKJUc2RGarhOnG3B++OxR53LPys3J9AnL9o6zlviz5pzsgf
# rQH4lrtNUz4Qq/Va5MbBwuahTcWk4UxuY+PynPjgw9nV/35gRAhC3L81B3/bIaBb
# 659+Vxn9kT2jUztrkmep/aLb+4xJbKZHyvahAEx2XKHafkeKtjiMqcUf/2BG935A
# 591GsllvWwIDAQABo4IBZDCCAWAwHwYDVR0jBBgwFoAUMuuSmv81lkgvKEBCcCA2
# kVwXheYwHQYDVR0OBBYEFA8qyyCHKLjsb0iuK1SmKaoXpM0MMA4GA1UdDwEB/wQE
# AwIBhjASBgNVHRMBAf8ECDAGAQH/AgEAMBMGA1UdJQQMMAoGCCsGAQUFBwMDMBsG
# A1UdIAQUMBIwBgYEVR0gADAIBgZngQwBBAEwSwYDVR0fBEQwQjBAoD6gPIY6aHR0
# cDovL2NybC5zZWN0aWdvLmNvbS9TZWN0aWdvUHVibGljQ29kZVNpZ25pbmdSb290
# UjQ2LmNybDB7BggrBgEFBQcBAQRvMG0wRgYIKwYBBQUHMAKGOmh0dHA6Ly9jcnQu
# c2VjdGlnby5jb20vU2VjdGlnb1B1YmxpY0NvZGVTaWduaW5nUm9vdFI0Ni5wN2Mw
# IwYIKwYBBQUHMAGGF2h0dHA6Ly9vY3NwLnNlY3RpZ28uY29tMA0GCSqGSIb3DQEB
# DAUAA4ICAQAG/4Lhd2M2bnuhFSCbE/8E/ph1RGHDVpVx0ZE/haHrQECxyNbgcv2F
# ymQ5PPmNS6Dah66dtgCjBsULYAor5wxxcgEPRl05pZOzI3IEGwwsepp+8iGsLKaV
# pL3z5CmgELIqmk/Q5zFgR1TSGmxqoEEhk60FqONzDn7D8p4W89h8sX+V1imaUb69
# 3TGqWp3T32IKGfIgy9jkd7GM7YCa2xulWfQ6E1xZtYNEX/ewGnp9ZeHPsNwwviJM
# BZL4xVd40uPWUnOJUoSiugaz0yWLODRtQxs5qU6E58KKmfHwJotl5WZ7nIQuDT0m
# WjwEx7zSM7fs9Tx6N+Q/3+49qTtUvAQsrEAxwmzOTJ6Jp6uWmHCgrHW4dHM3ITpv
# G5Ipy62KyqYovk5O6cC+040Si15KJpuQ9VJnbPvqYqfMB9nEKX/d2rd1Q3DiuDex
# MKCCQdJGpOqUsxLuCOuFOoGbO7Uv3RjUpY39jkkp0a+yls6tN85fJe+Y8voTnbPU
# 1knpy24wUFBkfenBa+pRFHwCBB1QtS+vGNRhsceP3kSPNrrfN2sRzFYsNfrFaWz8
# YOdU254qNZQfd9O/VjxZ2Gjr3xgANHtM3HxfzPYF6/pKK8EE4dj66qKKtm2DTL1K
# FCg/OYJyfrdLJq1q2/HXntgr2GVw+ZWhrWgMTn8v1SjZsLlrgIfZHDGCG2Mwghtf
# AgEBMGkwVDELMAkGA1UEBhMCR0IxGDAWBgNVBAoTD1NlY3RpZ28gTGltaXRlZDEr
# MCkGA1UEAxMiU2VjdGlnbyBQdWJsaWMgQ29kZSBTaWduaW5nIENBIFIzNgIRAP5c
# 1JUBimUXpNBO+HtrkzowDQYJYIZIAWUDBAIBBQCgfDAQBgorBgEEAYI3AgEMMQIw
# ADAZBgkqhkiG9w0BCQMxDAYKKwYBBAGCNwIBBDAcBgorBgEEAYI3AgELMQ4wDAYK
# KwYBBAGCNwIBFTAvBgkqhkiG9w0BCQQxIgQgQwoWr0DnPQoIpGZJYbBgXUomBs7M
# N+l1Z41BFnEqmm4wDQYJKoZIhvcNAQEBBQAEggGAFLuvutNRdO6F8B0vlNw4SB7H
# UotsnbsSaSFD1/FAX/W8dQdtZ5+irwOJt8slhkupd2GDx10qX6p8lHO2V1qnyWcq
# JaDbxNmRqFd6bKrYus634i+rxwHgNYkj2BvuFmce2w6LyOsFEE01fhhKYo1rovm1
# WlmabBOn615ndT7HHovkWwKDuH18Pwgd5RPBiv9VRckPGdwBkQe5WE/gYrxB/D8q
# DHInnxP75RNe0P3DfU2se04nIdWVxuyLzPljAC4n8UMTDl6sx+n3A81ef51kOyPF
# oFdWRLDSpn5yqpX6kH+VuEGf7T8f213uTrPrWTlUa3p6Vlvn7VGPfnLWyd1UzGCU
# FyItqwN+Hl7cQwGDdYNI7uBFsE60k7Mtq+wuXCols9LwHGcjDSEc56M0qASn88Pb
# QqXCJmZ8LNIsVJxPFjqvFm6TizUBC/3RnJGiebwd0HLxknft/JzxVXsOgA6z8j9A
# P2UawrRwUEDun2BA7tnQ12hb3YVISWb0ljOsVHL8oYIYzTCCGMkGCisGAQQBgjcD
# AwExghi5MIIYtQYJKoZIhvcNAQcCoIIYpjCCGKICAQMxDzANBglghkgBZQMEAgIF
# ADCB8wYLKoZIhvcNAQkQAQSggeMEgeAwgd0CAQEGCisGAQQBsjECAQEwMTANBglg
# hkgBZQMEAgEFAAQgIjXZhNS3TwEdMx3Pn21ELC6EZjFRQvLeoxa/oeWJSBcCFCW4
# IVw33NqCLAkoAv0Bw7L5/8G1GA8yMDI1MDEyNzE5MDMyM1qgcqRwMG4xCzAJBgNV
# BAYTAkdCMRMwEQYDVQQIEwpNYW5jaGVzdGVyMRgwFgYDVQQKEw9TZWN0aWdvIExp
# bWl0ZWQxMDAuBgNVBAMTJ1NlY3RpZ28gUHVibGljIFRpbWUgU3RhbXBpbmcgU2ln
# bmVyIFIzNaCCEv8wggZdMIIExaADAgECAhA6UmoshM5V5h1l/MwS2OmJMA0GCSqG
# SIb3DQEBDAUAMFUxCzAJBgNVBAYTAkdCMRgwFgYDVQQKEw9TZWN0aWdvIExpbWl0
# ZWQxLDAqBgNVBAMTI1NlY3RpZ28gUHVibGljIFRpbWUgU3RhbXBpbmcgQ0EgUjM2
# MB4XDTI0MDExNTAwMDAwMFoXDTM1MDQxNDIzNTk1OVowbjELMAkGA1UEBhMCR0Ix
# EzARBgNVBAgTCk1hbmNoZXN0ZXIxGDAWBgNVBAoTD1NlY3RpZ28gTGltaXRlZDEw
# MC4GA1UEAxMnU2VjdGlnbyBQdWJsaWMgVGltZSBTdGFtcGluZyBTaWduZXIgUjM1
# MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAjdFn9MFIm739OEk6TWGB
# m8PY3EWlYQQ2jQae45iWgPXUGVuYoIa1xjTGIyuw3suUSBzKiyG0/c/Yn++d5mG6
# IyayljuGT9DeXQU9k8GWWj2/BPoamg2fFctnPsdTYhMGxM06z1+Ft0Bav8ybww21
# ii/faiy+NhiUM195+cFqOtCpJXxZ/lm9tpjmVmEqpAlRpfGmLhNdkqiEuDFTuD1G
# sV3jvuPuPGKUJTam3P53U4LM0UCxeDI8Qz40Qw9TPar6S02XExlc8X1YsiE6ETcT
# z+g1ImQ1OqFwEaxsMj/WoJT18GG5KiNnS7n/X4iMwboAg3IjpcvEzw4AZCZowHyC
# zYhnFRM4PuNMVHYcTXGgvuq9I7j4ke281x4e7/90Z5Wbk92RrLcS35hO30TABcGx
# 3Q8+YLRy6o0k1w4jRefCMT7b5mTxtq5XPmKvtgfPuaWPkGZ/tbxInyNDA7YgOgcc
# ULjp4+D56g2iuzRCsLQ9ac6AN4yRbqCYsG2rcIQ5INTyI2JzA2w1vsAHPRbUTeqV
# LDuNOY2gYIoKBWQsPYVoyzaoBVU6O5TG+a1YyfWkgVVS9nXKs8hVti3VpOV3aeua
# HnjgC6He2CCDL9aW6gteUe0AmC8XCtWwpePx6QW3ROZo8vSUe9AR7mMdu5+FzTmW
# 8K13Bt8GX/YBFJO7LWzwKAUCAwEAAaOCAY4wggGKMB8GA1UdIwQYMBaAFF9Y7Uwx
# eqJhQo1SgLqzYZcZojKbMB0GA1UdDgQWBBRo76QySWm2Ujgd6kM5LPQUap4MhTAO
# BgNVHQ8BAf8EBAMCBsAwDAYDVR0TAQH/BAIwADAWBgNVHSUBAf8EDDAKBggrBgEF
# BQcDCDBKBgNVHSAEQzBBMDUGDCsGAQQBsjEBAgEDCDAlMCMGCCsGAQUFBwIBFhdo
# dHRwczovL3NlY3RpZ28uY29tL0NQUzAIBgZngQwBBAIwSgYDVR0fBEMwQTA/oD2g
# O4Y5aHR0cDovL2NybC5zZWN0aWdvLmNvbS9TZWN0aWdvUHVibGljVGltZVN0YW1w
# aW5nQ0FSMzYuY3JsMHoGCCsGAQUFBwEBBG4wbDBFBggrBgEFBQcwAoY5aHR0cDov
# L2NydC5zZWN0aWdvLmNvbS9TZWN0aWdvUHVibGljVGltZVN0YW1waW5nQ0FSMzYu
# Y3J0MCMGCCsGAQUFBzABhhdodHRwOi8vb2NzcC5zZWN0aWdvLmNvbTANBgkqhkiG
# 9w0BAQwFAAOCAYEAsNwuyfpPNkyKL/bJT9XvGE8fnw7Gv/4SetmOkjK9hPPa7/Ns
# v5/MHuVus+aXwRFqM5Vu51qfrHTwnVExcP2EHKr7IR+m/Ub7PamaeWfle5x8D0x/
# MsysICs00xtSNVxFywCvXx55l6Wg3lXiPCui8N4s51mXS0Ht85fkXo3auZdo1O4l
# HzJLYX4RZovlVWD5EfwV6Ve1G9UMslnm6pI0hyR0Zr95QWG0MpNPP0u05SHjq/Yk
# PlDee3yYOECNMqnZ+j8onoUtZ0oC8CkbOOk/AOoV4kp/6Ql2gEp3bNC7DOTlaCmH
# 24DjpVgryn8FMklqEoK4Z3IoUgV8R9qQLg1dr6/BjghGnj2XNA8ujta2Jyoxpqpv
# yETZCYIUjIs69YiDjzftt37rQVwIZsfCYv+DU5sh/StFL1x4rgNj2t8GccUfa/V3
# iFFW9lfIJWWsvtlC5XOOOQswr1UmVdNWQem4LwrlLgcdO/YAnHqY52QwnBLiAuUn
# uBeshWmfEb5oieIYMIIGFDCCA/ygAwIBAgIQeiOu2lNplg+RyD5c9MfjPzANBgkq
# hkiG9w0BAQwFADBXMQswCQYDVQQGEwJHQjEYMBYGA1UEChMPU2VjdGlnbyBMaW1p
# dGVkMS4wLAYDVQQDEyVTZWN0aWdvIFB1YmxpYyBUaW1lIFN0YW1waW5nIFJvb3Qg
# UjQ2MB4XDTIxMDMyMjAwMDAwMFoXDTM2MDMyMTIzNTk1OVowVTELMAkGA1UEBhMC
# R0IxGDAWBgNVBAoTD1NlY3RpZ28gTGltaXRlZDEsMCoGA1UEAxMjU2VjdGlnbyBQ
# dWJsaWMgVGltZSBTdGFtcGluZyBDQSBSMzYwggGiMA0GCSqGSIb3DQEBAQUAA4IB
# jwAwggGKAoIBgQDNmNhDQatugivs9jN+JjTkiYzT7yISgFQ+7yavjA6Bg+OiIjPm
# /N/t3nC7wYUrUlY3mFyI32t2o6Ft3EtxJXCc5MmZQZ8AxCbh5c6WzeJDB9qkQVa4
# 6xiYEpc81KnBkAWgsaXnLURoYZzksHIzzCNxtIXnb9njZholGw9djnjkTdAA83ab
# EOHQ4ujOGIaBhPXG2NdV8TNgFWZ9BojlAvflxNMCOwkCnzlH4oCw5+4v1nssWeN1
# y4+RlaOywwRMUi54fr2vFsU5QPrgb6tSjvEUh1EC4M29YGy/SIYM8ZpHadmVjbi3
# Pl8hJiTWw9jiCKv31pcAaeijS9fc6R7DgyyLIGflmdQMwrNRxCulVq8ZpysiSYNi
# 79tw5RHWZUEhnRfs/hsp/fwkXsynu1jcsUX+HuG8FLa2BNheUPtOcgw+vHJcJ8Hn
# JCrcUWhdFczf8O+pDiyGhVYX+bDDP3GhGS7TmKmGnbZ9N+MpEhWmbiAVPbgkqykS
# kzyYVr15OApZYK8CAwEAAaOCAVwwggFYMB8GA1UdIwQYMBaAFPZ3at0//QET/xah
# bIICL9AKPRQlMB0GA1UdDgQWBBRfWO1MMXqiYUKNUoC6s2GXGaIymzAOBgNVHQ8B
# Af8EBAMCAYYwEgYDVR0TAQH/BAgwBgEB/wIBADATBgNVHSUEDDAKBggrBgEFBQcD
# CDARBgNVHSAECjAIMAYGBFUdIAAwTAYDVR0fBEUwQzBBoD+gPYY7aHR0cDovL2Ny
# bC5zZWN0aWdvLmNvbS9TZWN0aWdvUHVibGljVGltZVN0YW1waW5nUm9vdFI0Ni5j
# cmwwfAYIKwYBBQUHAQEEcDBuMEcGCCsGAQUFBzAChjtodHRwOi8vY3J0LnNlY3Rp
# Z28uY29tL1NlY3RpZ29QdWJsaWNUaW1lU3RhbXBpbmdSb290UjQ2LnA3YzAjBggr
# BgEFBQcwAYYXaHR0cDovL29jc3Auc2VjdGlnby5jb20wDQYJKoZIhvcNAQEMBQAD
# ggIBABLXeyCtDjVYDJ6BHSVY/UwtZ3Svx2ImIfZVVGnGoUaGdltoX4hDskBMZx5N
# Y5L6SCcwDMZhHOmbyMhyOVJDwm1yrKYqGDHWzpwVkFJ+996jKKAXyIIaUf5JVKjc
# cev3w16mNIUlNTkpJEor7edVJZiRJVCAmWAaHcw9zP0hY3gj+fWp8MbOocI9Zn78
# xvm9XKGBp6rEs9sEiq/pwzvg2/KjXE2yWUQIkms6+yslCRqNXPjEnBnxuUB1fm6b
# PAV+Tsr/Qrd+mOCJemo06ldon4pJFbQd0TQVIMLv5koklInHvyaf6vATJP4DfPtK
# zSBPkKlOtyaFTAjD2Nu+di5hErEVVaMqSVbfPzd6kNXOhYm23EWm6N2s2ZHCHVhl
# UgHaC4ACMRCgXjYfQEDtYEK54dUwPJXV7icz0rgCzs9VI29DwsjVZFpO4ZIVR33L
# wXyPDbYFkLqYmgHjR3tKVkhh9qKV2WCmBuC27pIOx6TYvyqiYbntinmpOqh/QPAn
# hDgexKG9GX/n1PggkGi9HCapZp8fRwg8RftwS21Ln61euBG0yONM6noD2XQPrFwp
# m3GcuqJMf0o8LLrFkSLRQNwxPDDkWXhW+gZswbaiie5fd/W2ygcto78XCSPfFWve
# UOSZ5SqK95tBO8aTHmEa4lpJVD7HrTEn9jb1EGvxOb1cnn0CMIIGgjCCBGqgAwIB
# AgIQNsKwvXwbOuejs902y8l1aDANBgkqhkiG9w0BAQwFADCBiDELMAkGA1UEBhMC
# VVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4w
# HAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVz
# dCBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMjEwMzIyMDAwMDAwWhcN
# MzgwMTE4MjM1OTU5WjBXMQswCQYDVQQGEwJHQjEYMBYGA1UEChMPU2VjdGlnbyBM
# aW1pdGVkMS4wLAYDVQQDEyVTZWN0aWdvIFB1YmxpYyBUaW1lIFN0YW1waW5nIFJv
# b3QgUjQ2MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAiJ3YuUVnnR3d
# 6LkmgZpUVMB8SQWbzFoVD9mUEES0QUCBdxSZqdTkdizICFNeINCSJS+lV1ipnW5i
# hkQyC0cRLWXUJzodqpnMRs46npiJPHrfLBOifjfhpdXJ2aHHsPHggGsCi7uE0awq
# KggE/LkYw3sqaBia67h/3awoqNvGqiFRJ+OTWYmUCO2GAXsePHi+/JUNAax3kpqs
# tbl3vcTdOGhtKShvZIvjwulRH87rbukNyHGWX5tNK/WABKf+Gnoi4cmisS7oSimg
# HUI0Wn/4elNd40BFdSZ1EwpuddZ+Wr7+Dfo0lcHflm/FDDrOJ3rWqauUP8hsokDo
# I7D/yUVI9DAE/WK3Jl3C4LKwIpn1mNzMyptRwsXKrop06m7NUNHdlTDEMovXAIDG
# AvYynPt5lutv8lZeI5w3MOlCybAZDpK3Dy1MKo+6aEtE9vtiTMzz/o2dYfdP0KWZ
# wZIXbYsTIlg1YIetCpi5s14qiXOpRsKqFKqav9R1R5vj3NgevsAsvxsAnI8Oa5s2
# oy25qhsoBIGo/zi6GpxFj+mOdh35Xn91y72J4RGOJEoqzEIbW3q0b2iPuWLA911c
# RxgY5SJYubvjay3nSMbBPPFsyl6mY4/WYucmyS9lo3l7jk27MAe145GWxK4O3m3g
# EFEIkv7kRmefDR7Oe2T1HxAnICQvr9sCAwEAAaOCARYwggESMB8GA1UdIwQYMBaA
# FFN5v1qqK0rPVIDh2JvAnfKyA2bLMB0GA1UdDgQWBBT2d2rdP/0BE/8WoWyCAi/Q
# Cj0UJTAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zATBgNVHSUEDDAK
# BggrBgEFBQcDCDARBgNVHSAECjAIMAYGBFUdIAAwUAYDVR0fBEkwRzBFoEOgQYY/
# aHR0cDovL2NybC51c2VydHJ1c3QuY29tL1VTRVJUcnVzdFJTQUNlcnRpZmljYXRp
# b25BdXRob3JpdHkuY3JsMDUGCCsGAQUFBwEBBCkwJzAlBggrBgEFBQcwAYYZaHR0
# cDovL29jc3AudXNlcnRydXN0LmNvbTANBgkqhkiG9w0BAQwFAAOCAgEADr5lQe1o
# RLjlocXUEYfktzsljOt+2sgXke3Y8UPEooU5y39rAARaAdAxUeiX1ktLJ3+lgxto
# LQhn5cFb3GF2SSZRX8ptQ6IvuD3wz/LNHKpQ5nX8hjsDLRhsyeIiJsms9yAWnvdY
# OdEMq1W61KE9JlBkB20XBee6JaXx4UBErc+YuoSb1SxVf7nkNtUjPfcxuFtrQdRM
# Ri/fInV/AobE8Gw/8yBMQKKaHt5eia8ybT8Y/Ffa6HAJyz9gvEOcF1VWXG8OMeM7
# Vy7Bs6mSIkYeYtddU1ux1dQLbEGur18ut97wgGwDiGinCwKPyFO7ApcmVJOtlw9F
# VJxw/mL1TbyBns4zOgkaXFnnfzg4qbSvnrwyj1NiurMp4pmAWjR+Pb/SIduPnmFz
# bSN/G8reZCL4fvGlvPFk4Uab/JVCSmj59+/mB2Gn6G/UYOy8k60mKcmaAZsEVkhO
# Fuoj4we8CYyaR9vd9PGZKSinaZIkvVjbH/3nlLb0a7SBIkiRzfPfS9T+JesylbHa
# 1LtRV9U/7m0q7Ma2CQ/t392ioOssXW7oKLdOmMBl14suVFBmbzrt5V5cQPnwtd3U
# OTpS9oCG+ZZheiIvPgkDmA8FzPsnfXW5qHELB43ET7HHFHeRPRYrMBKjkb8/IN7P
# o0d0hQoF4TeMM+zYAJzoKQnVKOLg8pZVPT8xggSRMIIEjQIBATBpMFUxCzAJBgNV
# BAYTAkdCMRgwFgYDVQQKEw9TZWN0aWdvIExpbWl0ZWQxLDAqBgNVBAMTI1NlY3Rp
# Z28gUHVibGljIFRpbWUgU3RhbXBpbmcgQ0EgUjM2AhA6UmoshM5V5h1l/MwS2OmJ
# MA0GCWCGSAFlAwQCAgUAoIIB+TAaBgkqhkiG9w0BCQMxDQYLKoZIhvcNAQkQAQQw
# HAYJKoZIhvcNAQkFMQ8XDTI1MDEyNzE5MDMyM1owPwYJKoZIhvcNAQkEMTIEMFE6
# CnbrXTJPV0AizxhWWvLu7ti7Bkj/o+tzgHIRqNkd9k0I8ovGyVqikHilTbciMDCC
# AXoGCyqGSIb3DQEJEAIMMYIBaTCCAWUwggFhMBYEFPhgmBmm+4gs9+hSl/KhGVIa
# FndfMIGHBBTGrlTkeIbxfD1VEkiMacNKevnC3TBvMFukWTBXMQswCQYDVQQGEwJH
# QjEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMS4wLAYDVQQDEyVTZWN0aWdvIFB1
# YmxpYyBUaW1lIFN0YW1waW5nIFJvb3QgUjQ2AhB6I67aU2mWD5HIPlz0x+M/MIG8
# BBSFPWMtk4KCYXzQkDXEkd6SwULaxzCBozCBjqSBizCBiDELMAkGA1UEBhMCVVMx
# EzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYD
# VQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBS
# U0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkCEDbCsL18Gzrno7PdNsvJdWgwDQYJ
# KoZIhvcNAQEBBQAEggIAeubvuTk+sLyHu7wd3muZfLH/dHWQl9GIqobTn4dNKuNN
# 1EUO43pnM276Jbf3MKPcdTLwAoM30EEOJpLzkEjKcvFK3lVeOYtvQfjuvHU90Pc5
# moa4nQAU8lboUMqdpZoBxqLYE9UR03XS+OHHSLumIcGNxgzQpBUwgleqNokvupwn
# oOyH+ft5E2DVpPs9nGjQv3AoT29rW8NJYNJba6VgnkDXCkbrX51ZqePs1KScuHIB
# nZ8gXm7NHF7NKxy2jyqVusds1IH3Xw3B3zywCTVbV6YzrRAWN2qyBkMYPLW5gENl
# g0+f6F0ZetADeGmdgO8XbE0cLSaLRX46ghL1Mbmv0WlVTkZhUzB5321UtfOoRidH
# +HlwpTjl+LIw12/KMV6BLHnuiG6RQI9uVUxQlZjdZmlI7GdDGUcLiU0+NV0uxeFK
# sJWPjV0wK/WO4MTjnv8sjKFcIrRvAlxqaPb1OHduvrvBemiThVY4GRKJeKrbrtfb
# DNNlRgOnx76tkkg4CSFTIKpdVmO5o4rcygBIdnHDQll8ZeaS1G/+I9NEhNodEEBK
# b+U5DBGQu7+ztlHY33AeD5vBDEPSP55jNdYO+KV5noKQMdZ+wxdglBXecNnnZLKA
# D6Id1yk9bMOJikYA+qLBzR2tTgca8AjRxBQWYrwbIoDxVNS7kB0otSJTglq4JQw=
# SIG # End signature block