Policy.Autorest/custom/Helpers.ps1
# ---------------------------------------------------------------------------------- # Copyright (c) Microsoft Corporation. All rights reserved. # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # http://www.apache.org/licenses/LICENSE-2.0 # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # Code generated by Microsoft (R) AutoRest Code Generator.Changes may cause incorrect behavior and will be lost if the code # is regenerated. # ---------------------------------------------------------------------------------- # split policy ids into usable parts function ParsePolicyId { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] # the resource Id of a policy definition param($resourceId, $policyType) # validate args if (!$resourceId) { throw 'ParsePolicyId(resourceId, policyType) argument error: resourceId must be provided.' } if (!$policyType) { # extract policyType $temp = $resourceId -split '/providers/Microsoft.Authorization/' if ($temp.Length -lt 2) { throw 'parsePolicy(resourceId, policyType) argument error: resourceId is not a Microsoft.Authorization resource type' } $policyType = ($temp[1] -split '/')[0] } if (!$policyType) { throw 'ParsePolicyId(resourceId, policyType) argument error: unable to find type name.' } $mark = "/providers/Microsoft.Authorization/$($policyType)/" $parts = $resourceId -split $mark $scope = $parts[0] $name = '' if ($parts.Length -gt 1) { $parts = $parts[1] -split '/' $name = $parts[0] if (($parts.Length -gt 2) -and ($parts[1] -eq 'versions')) { $parsedVersion = ParsePolicyVersion $parts[2] } } $scopeType = 'none' $subId = '' $mgName = '' $rgName = '' $resource = '' $resNamespace = '' $resType = '' $resName = '' if (!$scope) { $scopeType = 'builtin' } elseif ($scope -like '/providers/Microsoft.Management/managementGroups/*') { $scopeType = 'mgname' $mgName = ($scope -split '/providers/Microsoft.Management/managementGroups/')[1] } elseif ($scope -like '/subscriptions/*/resourceGroups/*/*') { $scopeType = 'resource' $temp = ($scope -split '/subscriptions/')[1] $temp = ($temp -split '/resourceGroups/') $subId = $temp[0] $temp = ($temp[1] -split '/providers/') $rgName = $temp[0] $temp = $temp[1] -split '/' if ($temp.Length -gt 2) { $resNamespace = $temp[0] $resType = $temp[1..($temp.Length-2)] -join '/' $resName = $temp[$temp.Length-1] } $resource = $scope } elseif ($scope -like '/subscriptions/*/resourceGroups/*') { $scopeType = 'rgname' $temp = ($scope -split '/subscriptions/')[1] $temp = ($temp -split '/resourceGroups/') $subId = $temp[0] $rgName = $temp[1] } elseif ($scope -like '/subscriptions/*') { $scopeType = 'subId' $subId = ($scope -split '/subscriptions/')[1] } $artifactRef = '' $artifact = $scope + $mark + $name if ($parsedVersion.VersionRef) { $artifactRef = "$artifact/versions/$($parsedVersion.VersionRef)" } return @{ PolicyType = $policyType Scope = $scope ScopeType = $scopeType SubscriptionId = $subId ManagementGroupName = $mgName ResourceGroupName = $rgName Resource = $resource ResourceNamespace = $resNamespace ResourceType = $resType ResourceName = $resName Name = $name Artifact = $artifact ArtifactRef = $artifactRef Version = $parsedVersion.Version Major = $parsedVersion.Major Minor = $parsedVersion.Minor Patch = $parsedVersion.Patch Suffix = $parsedVersion.Suffix VersionRef = $parsedVersion.VersionRef VersionMajorRef = $parsedVersion.VersionMajorRef VersionMinorRef = $parsedVersion.VersionMinorRef } } # parse policy version with format: (ddd|*).(ddd|*).(ddd|*)[-suffix] function ParsePolicyVersion { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] # the resource Id of a policy definition param($version) $parts = $version -split '\.' $major = $parts[0] $minor = '' if ($parts.Length -gt 1) { $minor = $parts[1] } $patch = '' $suffix = '' if ($parts.Length -gt 2) { $parts = $parts[2] -split '-' $patch = $parts[0] if ($parts.Length -gt 1) { $suffix = $parts[1] } } $versionMinorRef = '' $versionMajorRef = @($major,'*','*') -join '.' if ($minor -ne '*') { $versionMinorRef = @($major,$minor,'*') -join '.' } if ($suffix) { if ($versionMinorRef) { $versionMinorRef = $versionMinorRef + '-' + $suffix } $versionMajorRef = $versionMajorRef + '-' + $suffix } $versionRef = '' if ($versionMinorRef) { $versionRef = $versionMinorRef } else { $versionRef = $versionMajorRef } return @{ Version = $version Major = $major Minor = $minor Patch = $patch Suffix = $suffix VersionRef = $versionRef VersionMajorRef = $versionMajorRef VersionMinorRef = $versionMinorRef } } # split policy definition resourceId into its parts (used externally) function ParsePolicyDefinitionId { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] # the resource Id of a policy definition param($ResourceId) ParsePolicyId $ResourceId 'policyDefinitions' } # split policy set definition resourceId into its parts function ParsePolicySetDefinitionId { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] # the resource Id of a policy set definition param($ResourceId) ParsePolicyId $ResourceId 'policySetDefinitions' } # split policy assignment resourceId into its parts function ParsePolicyAssignmentId { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] # the resource Id of a policy set definition param($ResourceId) ParsePolicyId $ResourceId 'policyAssignments' } # split policy assignment resourceId into its parts function ParsePolicyExemptionId { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] # the resource Id of a policy set definition param($resourceId) ParsePolicyId $ResourceId 'policyExemptions' } # Wrapper for JSON -> PSObject conversion that works on both Core and Desktop editions function ConvertFrom-JsonSafe { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [Parameter(ValueFromPipeline)] $InputObject, [switch]$AsHashtable = $false ) if ($PSVersionTable.PSEdition -eq 'Core') { ConvertFrom-Json $InputObject -AsHashtable:$AsHashtable } elseif ($AsHashtable) { # ConvertFrom-Json on Windows Powershell doesn't support -AsHashtable parameter $converted = ConvertParameterInput ($InputObject | ConvertFrom-Json) if (($converted -is [array]) -and ($converted.Count -eq 1)) { return $converted[0] } else { return $converted } } else { ConvertFrom-Json $InputObject } } # convert the parameter object (could be either hashtable or PSCustomObject) to policy-formatted hashtable suitable for autorest serializers function ConvertParameterObject { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param ($InputObject) $returnValue = @{} if ($InputObject -is [hashtable]) { foreach ($key in $InputObject.Keys) { $returnValue[$key] = @{ value = (ConvertParameterInput -InputObject $InputObject[$key]) } } } else { foreach ($property in $InputObject.PSObject.Properties) { $returnValue[$property.Name] = @{ value = (ConvertParameterInput -InputObject $InputObject.PSObject.Properties[$property.Name]) } } } return $returnValue } # Convert input parameter value to hashtable type expected by the autorest serializers function ConvertParameterArray { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param ($InputObject) if ($InputObject -is [array]) { $collection = @( foreach ($object in $InputObject) { ConvertParameterArray $object } ) Write-Output -NoEnumerate $collection } elseif ($InputObject -is [hashtable]) { return $InputObject } elseif ($InputObject -is [PSObject]) { $hash = @{} foreach ($property in $InputObject.PSObject.Properties) { $hash[$property.Name] = (ConvertParameterArray $property.Value).PSObject.BaseObject } $hash } else { return $InputObject } } # convert various parameter input formats to policy-formatted hashtable suitable for autorest serializers function ConvertParameterInput { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param ($InputObject) # traverse collections to ensure nested values are all processed if ($InputObject -is [hashtable]) { $returnValue = @{} foreach ($key in $InputObject.Keys) { $returnValue[$key] = (ConvertParameterInput $InputObject[$key]) } return $returnValue } elseif ($InputObject -is [array]) { $returnValue = @() foreach ($object in $InputObject) { $returnValue += (ConvertParameterInput $object) } return ,$returnValue } elseif ($InputObject -is [PSObject]) { $returnValue = @{} foreach ($property in $InputObject.PSObject.Properties) { $returnValue[$property.Name] = (ConvertParameterInput $property.Value) } return $returnValue } else { return $InputObject } } # Convert output hashtable object output by autorest serializers to PSCustomObject format for legacy support function ConvertObjectToPSObject { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param($InputObject) if ($null -eq $InputObject) { return [PSCustomObject]$null } if ($InputObject -is [array]) { return ,@(foreach ($obj in $InputObject) { ConvertObjectToPSObject $obj }) } if (!$InputObject.ToJsonString) { return [PSCustomObject]$InputObject } $jsonString = $InputObject.ToJsonString() if ($jsonString -is [array]) { $jsonString = "[$([System.String]::Join(',', $jsonString))]" } ConvertFrom-JsonSafe $jsonString } function GetPSObjectProperty { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param ( [PSObject]$PropertyObject, [string]$PropertyPath ) $propertyNames = $PropertyPath.Split('.') $tmpObject = $PropertyObject foreach ($propertyName in $propertyNames) { $propertyInfo = $tmpObject.PSObject.Properties[$propertyName] if ($propertyInfo) { if ($propertyInfo.Value -is [PSObject]) { $tmpObject = [PSObject]$propertyInfo.Value continue } return $propertyInfo.Value } } return $tmpObject } # tests whether the given string is a Uri function Test-Uri { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param([string]$Value) $uri = '' [System.Uri]::TryCreate($Value, [System.UriKind]::Absolute, [ref]$uri) } # issues a GET to the given address and returns the contents function Get-UriContent { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param([string]$UriAddress) $response = Invoke-WebRequest $UriAddress -DisableKeepAlive -Method Get if ($response.StatusCode -eq 200) { return $response.Content } } # if the given string is a file path or URI, returns the contents of the file or web page # otherwise returns the original string function GetFileUriOrStringParameterValue { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param([string]$parameterValue) if (Test-Path $parameterValue) { Get-Content $parameterValue | Out-String } else { if (Test-Uri $parameterValue) { Get-UriContent $parameterValue } else { $parameterValue } } } function ResolvePolicyParameter { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [string]$ParameterName, [string]$ParameterValue, [bool]$Debug = $false ) $policy = GetFileUriOrStringParameterValue $ParameterValue if ($debug) { Write-Host -ForegroundColor Cyan "Parameter ${ParameterName}:" $policy } $policyParameter = ConvertFrom-JsonSafe -AsHashtable $policy if ($policyParameter.properties) { return $policyParameter.properties } else { return $policyParameter } } function ResolvePolicyMetadataParameter { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( $MetadataValue, [bool]$Debug = $false ) if ($metadataValue -is [hashtable]) { return $metadataValue } if ([System.String]::IsNullOrEmpty($metadataValue)) { return $metadataValue } $metadata = (GetFileUriOrStringParameterValue $metadataValue).Trim() if ($debug) { Write-Host -ForegroundColor Cyan Metadata: $metadata } if ($metadata -like '@{*') { # probably a PSCustomObject, try converting to hashtable return (Invoke-Expression($metadata.Replace('=',"='").Replace(';',"';").Replace('}',"'}"))) } # otherwise it should be a JSON string if ($metadata -like '{*}') { return $metadata | ConvertFrom-JsonSafe -AsHashtable } throw "Unrecognized metadata format - value: [$($metadataValue)], type: [$($metadataValue.GetType())]" } # construct the full Id of a resource given the various parts (only used internally in this file) function resolvePolicyArtifact { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [string]$name, [string]$subscriptionId, [string]$managementGroupName, [string]$id, [string]$policyType ) $scope = '' $scopeType = 'none' $scopeName = '' $resourceId = '<invalid>' if ($id -and !$subscriptionId -and !$managementGroupName) { $resolved = ParsePolicyId $id $policyType $scope = $resolved.Scope $scopeType = $resolved.ScopeType switch ($scopeType) { 'subId' { $subscriptionId = $resolved.SubscriptionId $scopeName = "subscription $($subscriptionId)" } 'mgName' { $managementGroupName = $resolved.ManagementGroupName $scopeName = "management group $($managementGroupName)" } 'rgname' { $subscriptionId = $resolved.SubscriptionId $scopeName = "resource group $($resolved.ResourceGroupName) (subId: $($subscriptionId))" } 'resource' { $subscriptionId = $resolved.SubscriptionId $scopeName = "resource id $($resolved.Resource)" } 'none' { $scopeName = "scope $($scope)" } } $name = $resolved.Name $resourceId = $id } else { if ($name) { if ($managementGroupName) { $scopeType = 'mgName' $scopeName = "management group $($managementGroupName)" $scope = "/providers/Microsoft.Management/managementGroups/$($managementGroupName)" } else { if (!$subscriptionId) { $subscriptionId = (Get-SubscriptionId) } $scopeType = 'subId' $scopeName = "subscription $($subscriptionId)" $scope = "/subscriptions/$($subscriptionId)" } $resourceId = "$($scope)/providers/Microsoft.Authorization/$($policyType)/$($name)" } } return @{ Scope = $scope; ScopeType = $scopeType ScopeName = $scopeName; Name = $name; SubscriptionId = $subscriptionId ManagementGroupName = $managementGroupName ResourceId = $resourceId ResourceGroupName = $resolved.ResourceGroupName ResourceNamespace = $resolved.ResourceNamespace ResourceType = $resolved.ResourceType ResourceName = $resolved.ResourceName } } function ResolvePolicyDefinition { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [string]$Name, [string]$SubscriptionId, [string]$ManagementGroupName, [string]$Id ) resolvePolicyArtifact $Name $SubscriptionId $ManagementGroupName $Id 'policyDefinitions' } function ResolvePolicySetDefinition { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [string]$Name, [string]$SubscriptionId, [string]$ManagementGroupName, [string]$Id ) resolvePolicyArtifact $Name $SubscriptionId $ManagementGroupName $Id 'policySetDefinitions' } function ResolvePolicyAssignment { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [string]$Name, [string]$Scope, [string]$Id ) if ($Id) { $resourceId = $Id } elseif ($Scope) { $resourceId = "$($Scope)/providers/Microsoft.Authorization/policyAssignments/$($Name)" } else { $resourceId = "/subscriptions/$($(Get-SubscriptionId))/providers/Microsoft.Authorization/policyAssignments/$($Name)" } resolvePolicyArtifact $null $null $null $resourceId 'policyAssignments' } function ResolvePolicyExemption { [Microsoft.Azure.PowerShell.Cmdlets.Policy.DoNotExportAttribute()] param( [string]$Name, [string]$Scope, [string]$Id ) if ($Id) { $resourceId = $Id } elseif ($Scope) { $resourceId = "$($Scope)/providers/Microsoft.Authorization/policyExemptions/$($Name)" } else { $resourceId = "/subscriptions/$($(Get-SubscriptionId))/providers/Microsoft.Authorization/policyExemptions/$($Name)" } resolvePolicyArtifact $null $null $null $resourceId 'policyExemptions' } function LocationCompleter( $commandName, $parameterName, $wordToComplete, $commandAst, $fakeBoundParameter ) { if ($global:AzPSPolicyCachedLocations.Count -le 0) { $response = Invoke-AzRestMethod -Uri "https://management.azure.com/subscriptions/$($(Get-SubscriptionId))/locations?api-version=2022-12-01" -Method GET $global:AzPSPolicyCachedLocations = ($response.Content | ConvertFrom-JsonSafe).value | Sort-Object -Property name | Select-Object -ExpandProperty name } # If you see the following error, it means your context access has expired # The given key 'AzureAttestationServiceEndpointSuffix' was not present in the dictionary. $global:AzPSPolicyCachedLocations | Where-Object { $_ -like "$wordToComplete*" } } function Get-SubscriptionId { $script = Resolve-Path "$PSScriptRoot/../utils/Get-SubscriptionIdTestSafe.ps1" return . $script } function Get-ExtraParameters ( $DefaultProfile, $Break, $HttpPipelineAppend, $HttpPipelinePrepend, $Proxy, $ProxyCredential, $ProxyUseDefaultCredentials ) { $parms = @{} if ($PSBoundParameters['DefaultProfile']) { $parms['DefaultProfile'] = $PSBoundParameters['DefaultProfile'] } if ($PSBoundParameters['Break']) { $parms['Break'] = $PSBoundParameters['Break'] } if ($PSBoundParameters['HttpPipelineAppend']) { $parms['HttpPipelineAppend'] = $PSBoundParameters['HttpPipelineAppend'] } if ($PSBoundParameters['HttpPipelinePrepend']) { $parms['HttpPipelinePrepend'] = $PSBoundParameters['HttpPipelinePrepend'] } if ($PSBoundParameters['Proxy']) { $parms['Proxy'] = $PSBoundParameters['Proxy'] } if ($PSBoundParameters['ProxyCredential']) { $parms['ProxyCredential'] = $PSBoundParameters['ProxyCredential'] } if ($PSBoundParameters['ProxyUseDefaultCredentials']) { $parms['ProxyUseDefaultCredentials'] = $PSBoundParameters['ProxyUseDefaultCredentials'] } return $parms } # register the location completer for New-AzPolicyAssignment Register-ArgumentCompleter -CommandName New-AzPolicyAssignment -ParameterName Location -ScriptBlock ${function:LocationCompleter} # cache Azure locations to be used by the location completer (Get-AzLocation is not available in this context, need to use REST) $global:AzPSPolicyCachedLocations = @() # SIG # Begin signature block # MIIoUgYJKoZIhvcNAQcCoIIoQzCCKD8CAQExDzANBglghkgBZQMEAgEFADB5Bgor # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG # KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCBRWJHiPFSzVUmy # YAzOthfFwcRPrdM1+OO8qiC/IkP3/KCCDYUwggYDMIID66ADAgECAhMzAAAEA73V # lV0POxitAAAAAAQDMA0GCSqGSIb3DQEBCwUAMH4xCzAJBgNVBAYTAlVTMRMwEQYD # VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy # b3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNpZ25p # bmcgUENBIDIwMTEwHhcNMjQwOTEyMjAxMTEzWhcNMjUwOTExMjAxMTEzWjB0MQsw # CQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9u # ZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMR4wHAYDVQQDExVNaWNy # b3NvZnQgQ29ycG9yYXRpb24wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB # AQCfdGddwIOnbRYUyg03O3iz19XXZPmuhEmW/5uyEN+8mgxl+HJGeLGBR8YButGV # LVK38RxcVcPYyFGQXcKcxgih4w4y4zJi3GvawLYHlsNExQwz+v0jgY/aejBS2EJY # oUhLVE+UzRihV8ooxoftsmKLb2xb7BoFS6UAo3Zz4afnOdqI7FGoi7g4vx/0MIdi # kwTn5N56TdIv3mwfkZCFmrsKpN0zR8HD8WYsvH3xKkG7u/xdqmhPPqMmnI2jOFw/ # /n2aL8W7i1Pasja8PnRXH/QaVH0M1nanL+LI9TsMb/enWfXOW65Gne5cqMN9Uofv # ENtdwwEmJ3bZrcI9u4LZAkujAgMBAAGjggGCMIIBfjAfBgNVHSUEGDAWBgorBgEE # AYI3TAgBBggrBgEFBQcDAzAdBgNVHQ4EFgQU6m4qAkpz4641iK2irF8eWsSBcBkw # VAYDVR0RBE0wS6RJMEcxLTArBgNVBAsTJE1pY3Jvc29mdCBJcmVsYW5kIE9wZXJh # dGlvbnMgTGltaXRlZDEWMBQGA1UEBRMNMjMwMDEyKzUwMjkyNjAfBgNVHSMEGDAW # gBRIbmTlUAXTgqoXNzcitW2oynUClTBUBgNVHR8ETTBLMEmgR6BFhkNodHRwOi8v # d3d3Lm1pY3Jvc29mdC5jb20vcGtpb3BzL2NybC9NaWNDb2RTaWdQQ0EyMDExXzIw # MTEtMDctMDguY3JsMGEGCCsGAQUFBwEBBFUwUzBRBggrBgEFBQcwAoZFaHR0cDov # L3d3dy5taWNyb3NvZnQuY29tL3BraW9wcy9jZXJ0cy9NaWNDb2RTaWdQQ0EyMDEx # XzIwMTEtMDctMDguY3J0MAwGA1UdEwEB/wQCMAAwDQYJKoZIhvcNAQELBQADggIB # AFFo/6E4LX51IqFuoKvUsi80QytGI5ASQ9zsPpBa0z78hutiJd6w154JkcIx/f7r # EBK4NhD4DIFNfRiVdI7EacEs7OAS6QHF7Nt+eFRNOTtgHb9PExRy4EI/jnMwzQJV # NokTxu2WgHr/fBsWs6G9AcIgvHjWNN3qRSrhsgEdqHc0bRDUf8UILAdEZOMBvKLC # rmf+kJPEvPldgK7hFO/L9kmcVe67BnKejDKO73Sa56AJOhM7CkeATrJFxO9GLXos # oKvrwBvynxAg18W+pagTAkJefzneuWSmniTurPCUE2JnvW7DalvONDOtG01sIVAB # +ahO2wcUPa2Zm9AiDVBWTMz9XUoKMcvngi2oqbsDLhbK+pYrRUgRpNt0y1sxZsXO # raGRF8lM2cWvtEkV5UL+TQM1ppv5unDHkW8JS+QnfPbB8dZVRyRmMQ4aY/tx5x5+ # sX6semJ//FbiclSMxSI+zINu1jYerdUwuCi+P6p7SmQmClhDM+6Q+btE2FtpsU0W # +r6RdYFf/P+nK6j2otl9Nvr3tWLu+WXmz8MGM+18ynJ+lYbSmFWcAj7SYziAfT0s # IwlQRFkyC71tsIZUhBHtxPliGUu362lIO0Lpe0DOrg8lspnEWOkHnCT5JEnWCbzu # iVt8RX1IV07uIveNZuOBWLVCzWJjEGa+HhaEtavjy6i7MIIHejCCBWKgAwIBAgIK # YQ6Q0gAAAAAAAzANBgkqhkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxEzARBgNV # BAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jv # c29mdCBDb3Jwb3JhdGlvbjEyMDAGA1UEAxMpTWljcm9zb2Z0IFJvb3QgQ2VydGlm # aWNhdGUgQXV0aG9yaXR5IDIwMTEwHhcNMTEwNzA4MjA1OTA5WhcNMjYwNzA4MjEw # OTA5WjB+MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UE # BxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSgwJgYD # VQQDEx9NaWNyb3NvZnQgQ29kZSBTaWduaW5nIFBDQSAyMDExMIICIjANBgkqhkiG # 9w0BAQEFAAOCAg8AMIICCgKCAgEAq/D6chAcLq3YbqqCEE00uvK2WCGfQhsqa+la # UKq4BjgaBEm6f8MMHt03a8YS2AvwOMKZBrDIOdUBFDFC04kNeWSHfpRgJGyvnkmc # 6Whe0t+bU7IKLMOv2akrrnoJr9eWWcpgGgXpZnboMlImEi/nqwhQz7NEt13YxC4D # dato88tt8zpcoRb0RrrgOGSsbmQ1eKagYw8t00CT+OPeBw3VXHmlSSnnDb6gE3e+ # lD3v++MrWhAfTVYoonpy4BI6t0le2O3tQ5GD2Xuye4Yb2T6xjF3oiU+EGvKhL1nk # kDstrjNYxbc+/jLTswM9sbKvkjh+0p2ALPVOVpEhNSXDOW5kf1O6nA+tGSOEy/S6 # A4aN91/w0FK/jJSHvMAhdCVfGCi2zCcoOCWYOUo2z3yxkq4cI6epZuxhH2rhKEmd # X4jiJV3TIUs+UsS1Vz8kA/DRelsv1SPjcF0PUUZ3s/gA4bysAoJf28AVs70b1FVL # 5zmhD+kjSbwYuER8ReTBw3J64HLnJN+/RpnF78IcV9uDjexNSTCnq47f7Fufr/zd # sGbiwZeBe+3W7UvnSSmnEyimp31ngOaKYnhfsi+E11ecXL93KCjx7W3DKI8sj0A3 # T8HhhUSJxAlMxdSlQy90lfdu+HggWCwTXWCVmj5PM4TasIgX3p5O9JawvEagbJjS # 4NaIjAsCAwEAAaOCAe0wggHpMBAGCSsGAQQBgjcVAQQDAgEAMB0GA1UdDgQWBBRI # bmTlUAXTgqoXNzcitW2oynUClTAZBgkrBgEEAYI3FAIEDB4KAFMAdQBiAEMAQTAL # BgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBRyLToCMZBD # uRQFTuHqp8cx0SOJNDBaBgNVHR8EUzBRME+gTaBLhklodHRwOi8vY3JsLm1pY3Jv # c29mdC5jb20vcGtpL2NybC9wcm9kdWN0cy9NaWNSb29DZXJBdXQyMDExXzIwMTFf # MDNfMjIuY3JsMF4GCCsGAQUFBwEBBFIwUDBOBggrBgEFBQcwAoZCaHR0cDovL3d3 # dy5taWNyb3NvZnQuY29tL3BraS9jZXJ0cy9NaWNSb29DZXJBdXQyMDExXzIwMTFf # MDNfMjIuY3J0MIGfBgNVHSAEgZcwgZQwgZEGCSsGAQQBgjcuAzCBgzA/BggrBgEF # BQcCARYzaHR0cDovL3d3dy5taWNyb3NvZnQuY29tL3BraW9wcy9kb2NzL3ByaW1h # cnljcHMuaHRtMEAGCCsGAQUFBwICMDQeMiAdAEwAZQBnAGEAbABfAHAAbwBsAGkA # YwB5AF8AcwB0AGEAdABlAG0AZQBuAHQALiAdMA0GCSqGSIb3DQEBCwUAA4ICAQBn # 8oalmOBUeRou09h0ZyKbC5YR4WOSmUKWfdJ5DJDBZV8uLD74w3LRbYP+vj/oCso7 # v0epo/Np22O/IjWll11lhJB9i0ZQVdgMknzSGksc8zxCi1LQsP1r4z4HLimb5j0b # pdS1HXeUOeLpZMlEPXh6I/MTfaaQdION9MsmAkYqwooQu6SpBQyb7Wj6aC6VoCo/ # KmtYSWMfCWluWpiW5IP0wI/zRive/DvQvTXvbiWu5a8n7dDd8w6vmSiXmE0OPQvy # CInWH8MyGOLwxS3OW560STkKxgrCxq2u5bLZ2xWIUUVYODJxJxp/sfQn+N4sOiBp # mLJZiWhub6e3dMNABQamASooPoI/E01mC8CzTfXhj38cbxV9Rad25UAqZaPDXVJi # hsMdYzaXht/a8/jyFqGaJ+HNpZfQ7l1jQeNbB5yHPgZ3BtEGsXUfFL5hYbXw3MYb # BL7fQccOKO7eZS/sl/ahXJbYANahRr1Z85elCUtIEJmAH9AAKcWxm6U/RXceNcbS # oqKfenoi+kiVH6v7RyOA9Z74v2u3S5fi63V4GuzqN5l5GEv/1rMjaHXmr/r8i+sL # gOppO6/8MO0ETI7f33VtY5E90Z1WTk+/gFcioXgRMiF670EKsT/7qMykXcGhiJtX # cVZOSEXAQsmbdlsKgEhr/Xmfwb1tbWrJUnMTDXpQzTGCGiMwghofAgEBMIGVMH4x # CzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRt # b25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01p # Y3Jvc29mdCBDb2RlIFNpZ25pbmcgUENBIDIwMTECEzMAAAQDvdWVXQ87GK0AAAAA # BAMwDQYJYIZIAWUDBAIBBQCgga4wGQYJKoZIhvcNAQkDMQwGCisGAQQBgjcCAQQw # HAYKKwYBBAGCNwIBCzEOMAwGCisGAQQBgjcCARUwLwYJKoZIhvcNAQkEMSIEIHLj # 33Iu4rfOCQUwaxlHI2d0FJWSMd6MlwXnZE/U8CVPMEIGCisGAQQBgjcCAQwxNDAy # oBSAEgBNAGkAYwByAG8AcwBvAGYAdKEagBhodHRwOi8vd3d3Lm1pY3Jvc29mdC5j # b20wDQYJKoZIhvcNAQEBBQAEggEAa3PsQvXMuBy5ZbS99MPwZC2cWZN/T7XK0ICu # 2cuUtnFhXDg6plWEOR3MU7ENiCSNEJ6ytNH5XdOO1Le+6poqQvUX/VkXgP9akhl+ # WO3CGBs1I0wuYPpFvY0urM8tazd1oln+x2dY2NbgbLwXTvmzNGau/L2cDAV3u5MG # XA0mYckBQ2UYnIkq+LMWmgLqPmgEecAbp0CJbQ3D0Zj8P80PSTK53+XuMqGDVmEs # areZ83/RvCfGQalpIOQqNEYhXxnzu9hANS2ZBtNnRfO6PCaQMRZ1lv6IINfMY08J # IKuqtvXHLFSr6BofaiJlVwt3BTzEYQq1pfRq3BEK5JlmNEW4V6GCF60wghepBgor # BgEEAYI3AwMBMYIXmTCCF5UGCSqGSIb3DQEHAqCCF4YwgheCAgEDMQ8wDQYJYIZI # AWUDBAIBBQAwggFaBgsqhkiG9w0BCRABBKCCAUkEggFFMIIBQQIBAQYKKwYBBAGE # WQoDATAxMA0GCWCGSAFlAwQCAQUABCAMhNaGpTiYj+j/VDikC5QwT7hPNpJWmRl6 # 9Zq3zAKC4gIGZ7YsQOeXGBMyMDI1MDIyNTA3MDMzMi4wNjNaMASAAgH0oIHZpIHW # MIHTMQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMH # UmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQL # EyRNaWNyb3NvZnQgSXJlbGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJzAlBgNVBAsT # Hm5TaGllbGQgVFNTIEVTTjozMjFBLTA1RTAtRDk0NzElMCMGA1UEAxMcTWljcm9z # b2Z0IFRpbWUtU3RhbXAgU2VydmljZaCCEfswggcoMIIFEKADAgECAhMzAAAB+KOh # JgwMQEj+AAEAAAH4MA0GCSqGSIb3DQEBCwUAMHwxCzAJBgNVBAYTAlVTMRMwEQYD # VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy # b3NvZnQgQ29ycG9yYXRpb24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1w # IFBDQSAyMDEwMB4XDTI0MDcyNTE4MzEwOFoXDTI1MTAyMjE4MzEwOFowgdMxCzAJ # BgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25k # MR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xLTArBgNVBAsTJE1pY3Jv # c29mdCBJcmVsYW5kIE9wZXJhdGlvbnMgTGltaXRlZDEnMCUGA1UECxMeblNoaWVs # ZCBUU1MgRVNOOjMyMUEtMDVFMC1EOTQ3MSUwIwYDVQQDExxNaWNyb3NvZnQgVGlt # ZS1TdGFtcCBTZXJ2aWNlMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA # xR23pXYnD2BuODdeXs2Cu/T5kKI+bAw8cbtN50Cm/FArjXyL4RTqMe6laQ/CqeMT # xgckvZr1JrW0Mi4F15rx/VveGhKBmob45DmOcV5xyx7h9Tk59NAl5PNMAWKAIWf2 # 70SWAAWxQbpVIhhPWCnVV3otVvahEad8pMmoSXrT5Z7Nk1RnB70A2bq9Hk8wIeC3 # vBuxEX2E8X50IgAHsyaR9roFq3ErzUEHlS8YnSq33ui5uBcrFOcFOCZILuVFVTgE # qSrX4UiX0etqi7jUtKypgIflaZcV5cI5XI/eCxY8wDNmBprhYMNlYxdmQ9aLRDcT # KWtddWpnJtyl5e3gHuYoj8xuDQ0XZNy7ESRwJIK03+rTZqfaYyM4XSK1s0aa+mO6 # 9vo/NmJ4R/f1+KucBPJ4yUdbqJWM3xMvBwLYycvigI/WK4kgPog0UBNczaQwDVXp # cU+TMcOvWP8HBWmWJQImTZInAFivXqUaBbo3wAfPNbsQpvNNGu/12pg0F8O/CdRf # gPHfOhIWQ0D8ALCY+LsiwbzcejbrVl4N9fn2wOg2sDa8RfNoD614I0pFjy/lq1Ns # Bo9V4GZBikzX7ZjWCRgd1FCBXGpfpDikHjQ05YOkAakdWDT2bGSaUZJGVYtepIpP # TAs1gd/vUogcdiL51o7shuHIlB6QSUiQ24XYhRbbQCECAwEAAaOCAUkwggFFMB0G # A1UdDgQWBBS9zsZzz57QlT5nrt/oitLv1OQ7tjAfBgNVHSMEGDAWgBSfpxVdAF5i # XYP05dJlpxtTNRnpcjBfBgNVHR8EWDBWMFSgUqBQhk5odHRwOi8vd3d3Lm1pY3Jv # c29mdC5jb20vcGtpb3BzL2NybC9NaWNyb3NvZnQlMjBUaW1lLVN0YW1wJTIwUENB # JTIwMjAxMCgxKS5jcmwwbAYIKwYBBQUHAQEEYDBeMFwGCCsGAQUFBzAChlBodHRw # Oi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3BzL2NlcnRzL01pY3Jvc29mdCUyMFRp # bWUtU3RhbXAlMjBQQ0ElMjAyMDEwKDEpLmNydDAMBgNVHRMBAf8EAjAAMBYGA1Ud # JQEB/wQMMAoGCCsGAQUFBwMIMA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQsF # AAOCAgEAYfk8GzzpEVnGl7y6oXoytCb42Hx6TOA0+dkaBI36ftDE9tLubUa/xMbH # B5rcNiRhFHZ93RefdPpc4+FF0DAl5lP8xKAO+293RWPKDFOFIxgtZY08t8D9cSQp # gGUzyw3lETZebNLEA17A/CTpA2F9uh8j84KygeEbj+bidWDiEfayoH2A5/5ywJJx # IuLzFVHacvWxSCKoF9hlSrZSG5fXWS3namf4tt690UT6AGyWLFWe895coFPxm/m0 # UIMjjp9VRFH7nb3Ng2Q4gPS9E5ZTMZ6nAlmUicDj0NXAs2wQuQrnYnbRAJ/DQW35 # qLo7Daw9AsItqjFhbMcG68gDc4j74L2KYe/2goBHLwzSn5UDftS1HZI0ZRsqmNHI # 0TZvvUWX9ajm6SfLBTEtoTo6gLOX0UD/9rrhGjdkiCw4SwU5osClgqgiNMK5ndk2 # gxFlDXHCyLp5qB6BoPpc82RhO0yCzoP9gv7zv2EocAWEsqE5+0Wmu5uarmfvcziL # fU1SY240OZW8ld4sS8fnybn/jDMmFAhazV1zH0QERWEsfLSpwkOXaImWNFJ5lmcn # f1VTm6cmfasScYtElpjqZ9GooCmk1XFApORPs/PO43IcFmPRwagt00iQSw+rBeIH # 00KQq+FJT/62SB70g9g/R8TS6k6b/wt2UWhqrW+Q8lw6Xzgex/YwggdxMIIFWaAD # AgECAhMzAAAAFcXna54Cm0mZAAAAAAAVMA0GCSqGSIb3DQEBCwUAMIGIMQswCQYD # VQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEe # MBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTIwMAYDVQQDEylNaWNyb3Nv # ZnQgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgMjAxMDAeFw0yMTA5MzAxODIy # MjVaFw0zMDA5MzAxODMyMjVaMHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNo # aW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29y # cG9yYXRpb24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEw # MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA5OGmTOe0ciELeaLL1yR5 # vQ7VgtP97pwHB9KpbE51yMo1V/YBf2xK4OK9uT4XYDP/XE/HZveVU3Fa4n5KWv64 # NmeFRiMMtY0Tz3cywBAY6GB9alKDRLemjkZrBxTzxXb1hlDcwUTIcVxRMTegCjhu # je3XD9gmU3w5YQJ6xKr9cmmvHaus9ja+NSZk2pg7uhp7M62AW36MEBydUv626GIl # 3GoPz130/o5Tz9bshVZN7928jaTjkY+yOSxRnOlwaQ3KNi1wjjHINSi947SHJMPg # yY9+tVSP3PoFVZhtaDuaRr3tpK56KTesy+uDRedGbsoy1cCGMFxPLOJiss254o2I # 5JasAUq7vnGpF1tnYN74kpEeHT39IM9zfUGaRnXNxF803RKJ1v2lIH1+/NmeRd+2 # ci/bfV+AutuqfjbsNkz2K26oElHovwUDo9Fzpk03dJQcNIIP8BDyt0cY7afomXw/ # TNuvXsLz1dhzPUNOwTM5TI4CvEJoLhDqhFFG4tG9ahhaYQFzymeiXtcodgLiMxhy # 16cg8ML6EgrXY28MyTZki1ugpoMhXV8wdJGUlNi5UPkLiWHzNgY1GIRH29wb0f2y # 1BzFa/ZcUlFdEtsluq9QBXpsxREdcu+N+VLEhReTwDwV2xo3xwgVGD94q0W29R6H # XtqPnhZyacaue7e3PmriLq0CAwEAAaOCAd0wggHZMBIGCSsGAQQBgjcVAQQFAgMB # AAEwIwYJKwYBBAGCNxUCBBYEFCqnUv5kxJq+gpE8RjUpzxD/LwTuMB0GA1UdDgQW # BBSfpxVdAF5iXYP05dJlpxtTNRnpcjBcBgNVHSAEVTBTMFEGDCsGAQQBgjdMg30B # ATBBMD8GCCsGAQUFBwIBFjNodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3Bz # L0RvY3MvUmVwb3NpdG9yeS5odG0wEwYDVR0lBAwwCgYIKwYBBQUHAwgwGQYJKwYB # BAGCNxQCBAweCgBTAHUAYgBDAEEwCwYDVR0PBAQDAgGGMA8GA1UdEwEB/wQFMAMB # Af8wHwYDVR0jBBgwFoAU1fZWy4/oolxiaNE9lJBb186aGMQwVgYDVR0fBE8wTTBL # oEmgR4ZFaHR0cDovL2NybC5taWNyb3NvZnQuY29tL3BraS9jcmwvcHJvZHVjdHMv # TWljUm9vQ2VyQXV0XzIwMTAtMDYtMjMuY3JsMFoGCCsGAQUFBwEBBE4wTDBKBggr # BgEFBQcwAoY+aHR0cDovL3d3dy5taWNyb3NvZnQuY29tL3BraS9jZXJ0cy9NaWNS # b29DZXJBdXRfMjAxMC0wNi0yMy5jcnQwDQYJKoZIhvcNAQELBQADggIBAJ1Vffwq # reEsH2cBMSRb4Z5yS/ypb+pcFLY+TkdkeLEGk5c9MTO1OdfCcTY/2mRsfNB1OW27 # DzHkwo/7bNGhlBgi7ulmZzpTTd2YurYeeNg2LpypglYAA7AFvonoaeC6Ce5732pv # vinLbtg/SHUB2RjebYIM9W0jVOR4U3UkV7ndn/OOPcbzaN9l9qRWqveVtihVJ9Ak # vUCgvxm2EhIRXT0n4ECWOKz3+SmJw7wXsFSFQrP8DJ6LGYnn8AtqgcKBGUIZUnWK # NsIdw2FzLixre24/LAl4FOmRsqlb30mjdAy87JGA0j3mSj5mO0+7hvoyGtmW9I/2 # kQH2zsZ0/fZMcm8Qq3UwxTSwethQ/gpY3UA8x1RtnWN0SCyxTkctwRQEcb9k+SS+ # c23Kjgm9swFXSVRk2XPXfx5bRAGOWhmRaw2fpCjcZxkoJLo4S5pu+yFUa2pFEUep # 8beuyOiJXk+d0tBMdrVXVAmxaQFEfnyhYWxz/gq77EFmPWn9y8FBSX5+k77L+Dvk # txW/tM4+pTFRhLy/AsGConsXHRWJjXD+57XQKBqJC4822rpM+Zv/Cuk0+CQ1Zyvg # DbjmjJnW4SLq8CdCPSWU5nR0W2rRnj7tfqAxM328y+l7vzhwRNGQ8cirOoo6CGJ/ # 2XBjU02N7oJtpQUQwXEGahC0HVUzWLOhcGbyoYIDVjCCAj4CAQEwggEBoYHZpIHW # MIHTMQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMH # UmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQL # EyRNaWNyb3NvZnQgSXJlbGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJzAlBgNVBAsT # Hm5TaGllbGQgVFNTIEVTTjozMjFBLTA1RTAtRDk0NzElMCMGA1UEAxMcTWljcm9z # b2Z0IFRpbWUtU3RhbXAgU2VydmljZaIjCgEBMAcGBSsOAwIaAxUAtkQt/ebWSQ5D # nG+aKRzPELCFE9GggYMwgYCkfjB8MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2Fz # aGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENv # cnBvcmF0aW9uMSYwJAYDVQQDEx1NaWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAx # MDANBgkqhkiG9w0BAQsFAAIFAOtnQdcwIhgPMjAyNTAyMjQxOTA3MDNaGA8yMDI1 # MDIyNTE5MDcwM1owdDA6BgorBgEEAYRZCgQBMSwwKjAKAgUA62dB1wIBADAHAgEA # AgId6TAHAgEAAgITcTAKAgUA62iTVwIBADA2BgorBgEEAYRZCgQCMSgwJjAMBgor # BgEEAYRZCgMCoAowCAIBAAIDB6EgoQowCAIBAAIDAYagMA0GCSqGSIb3DQEBCwUA # A4IBAQA0tciEMQ0TV4co8NSnnsxUjOEkw4K74agPl5DClvBTXNw9RfED4VhgLuzm # t6JeCDHeF3FGonQdAlYCqi0fZBS6zMzP1+xEKqDcCx7XQj1QrqnKb7ZAPu+hXf7S # I+GAwwibVrYtLOGAbPJXctLUThg5QnoobfBJD4c7YecHmPmO5WMJF40ZUb8ZB1Do # 1q+uN1PqTAv27ff0ucx0ITYRlT2U+w5dyihvyuy4CIsEYf/quXs4sh/yy9uvWRoK # zOrREjFzIulV5ExkZG0pJqYtaQhNXgyrk5GiEuwvSCiztReU+aI2zDuhq8A3nDxd # ymlZRcSZ7zIsM/1VyK2i8knTqXf4MYIEDTCCBAkCAQEwgZMwfDELMAkGA1UEBhMC # VVMxEzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNV # BAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRp # bWUtU3RhbXAgUENBIDIwMTACEzMAAAH4o6EmDAxASP4AAQAAAfgwDQYJYIZIAWUD # BAIBBQCgggFKMBoGCSqGSIb3DQEJAzENBgsqhkiG9w0BCRABBDAvBgkqhkiG9w0B # CQQxIgQgorWDX6ROqdbSeuNMvYCbqVyWUzMbEFRi8PIbFN+q/MEwgfoGCyqGSIb3 # DQEJEAIvMYHqMIHnMIHkMIG9BCDvzDPyXw1UkAUFYt8bR4UdjM90Qv5xnVaiKD3I # 0Zz3WjCBmDCBgKR+MHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9u # MRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRp # b24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwAhMzAAAB # +KOhJgwMQEj+AAEAAAH4MCIEIJVggWP1VL9W6Bl4hJL958t+C0gnFrXP+DclWHt4 # V4OKMA0GCSqGSIb3DQEBCwUABIICACofcxTCPb8U7xH/eqBKop/Ctu07ZzirrOiD # c/gCSTwkI5f9LTrsH93enR9gL1j11UaShLcgYoO4LG+FPxJl80rN+PpuX0OwCyxW # kIpe1xhaqyTs20VbWBsHDLvWMfsh6jTfBJWYe+uxB5REt0Pzd2UTtYsfI4Mr3gIn # ZMwEF+qqp9ErMkcJP21ajKADjrMCArxAhpSO/JgrWG3vkw38+gMOwjihVHV1IkSv # QXdORameXz/Q/HfmSbWiAypNgU5ODWpWQ4Ikk61WaVvpsiPgKAsVfjggD7soja/g # I5QVMsxXMSqb0wifMwxCpKZ2V8S+sb8dpPaqGwVBKMfV8HKNU+JYFC5LqlrnQLwG # UDZfioZizYKEtPZ0gfeXrdP8OQ0XTgJuwLFVe0ciHYkAQamWzBSbe+C6DeU130Aa # lHozwW3zV0vfeTuCNzCEQ9H5TBf6725zauNE/cspeT19dm79JUdz3/WuKayMHety # nqVvjA1kGrPc6aq1vboOXEvIhdomZPI3zEYTDERkgOaSHz6q7zx+cgT0c727+nNQ # rjoO+rNMUiJaEmwQsukSxWjLuxVPKz2n0PJcJCtmtfWTEqFfcLjWNP3ttJtf/g8B # ORoyVq6YW2/5GycgcwCKKg9Z+6XXtzjRltPe3s4NOnrMTe5xFrqMgPSZ1dzgQp3e # OzRPmgvZ # SIG # End signature block |