ADFS上で以下のPowerShellを実行すると、Relying Party(証明書利用者信頼)の構成情報がデスクトップに出力されます。
#Requires -Version 5
<#
.DISCLAIMER
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) Microsoft Corporation. All rights reserved.
#>
Function Remove-InvalidFileNameChars
{
param(
[Parameter(Mandatory=$true,
Position=0,
ValueFromPipeline=$true,
ValueFromPipelineByPropertyName=$true)]
[String]$Name
)
$invalidChars = [IO.Path]::GetInvalidFileNameChars() -join ''
$re = "[{0}]" -f [RegEx]::Escape($invalidChars)
return ($Name -replace $re)
}
$filePathBase = "$env:USERPROFILE/Desktop/ADFS/apps/"
$zipfileBase = "$env:USERPROFILE/Desktop/ADFS/zip/"
$zipfileName = $zipfileBase + "ADFSApps.zip"
mkdir $filePathBase -ErrorAction SilentlyContinue
mkdir $zipfileBase -ErrorAction SilentlyContinue
$AdfsRelyingPartyTrusts = Get-AdfsRelyingPartyTrust
foreach ($AdfsRelyingPartyTrust in $AdfsRelyingPartyTrusts)
{
$RPfileName = $AdfsRelyingPartyTrust.Name.ToString()
$CleanedRPFileName = Remove-InvalidFileNameChars -Name $RPfileName
$RPName = "RPT - " + $CleanedRPFileName
$filePath = $filePathBase + $RPName + '.xml'
$AdfsRelyingPartyTrust | Export-Clixml $filePath -ErrorAction SilentlyContinue
}
$AdfsClaimsProviderTrusts = Get-AdfsClaimsProviderTrust
foreach ($AdfsClaimsProviderTrust in $AdfsClaimsProviderTrusts)
{
$CPfileName = $AdfsClaimsProviderTrust.Name.ToString()
$CleanedCPFileName = Remove-InvalidFileNameChars -Name $CPfileName
$CPTName = "CPT - " + $CleanedCPFileName
$filePath = $filePathBase + $CPTName + '.xml'
$AdfsClaimsProviderTrust | Export-Clixml $filePath -ErrorAction SilentlyContinue
}
Compress-Archive -Path $filePathBase -DestinationPath $zipfileName
invoke-item $zipfileBase
Compress-Archiveが利用不可
# For PowerShell version below 5
<#
.DISCLAIMER
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) Microsoft Corporation. All rights reserved.
#>
Function Remove-InvalidFileNameChars
{
param(
[Parameter(Mandatory=$true,
Position=0,
ValueFromPipeline=$true,
ValueFromPipelineByPropertyName=$true)]
[String]$Name
)
$invalidChars = [IO.Path]::GetInvalidFileNameChars() -join ''
$re = "[{0}]" -f [RegEx]::Escape($invalidChars)
return ($Name -replace $re)
}
$filePathBase = "$env:USERPROFILE/Desktop/ADFS/apps/"
$zipfileBase = "$env:USERPROFILE/Desktop/ADFS/zip/"
#$zipfileName = $zipfileBase + "ADFSApps.zip"
mkdir $filePathBase -ErrorAction SilentlyContinue
mkdir $zipfileBase -ErrorAction SilentlyContinue
$AdfsRelyingPartyTrusts = Get-AdfsRelyingPartyTrust
foreach ($AdfsRelyingPartyTrust in $AdfsRelyingPartyTrusts)
{
$RPfileName = $AdfsRelyingPartyTrust.Name.ToString()
$CleanedRPFileName = Remove-InvalidFileNameChars -Name $RPfileName
$RPName = "RPT - " + $CleanedRPFileName
$filePath = $filePathBase + $RPName + '.xml'
$AdfsRelyingPartyTrust | Export-Clixml $filePath -ErrorAction SilentlyContinue
}
$AdfsClaimsProviderTrusts = Get-AdfsClaimsProviderTrust
foreach ($AdfsClaimsProviderTrust in $AdfsClaimsProviderTrusts)
{
$CPfileName = $AdfsClaimsProviderTrust.Name.ToString()
$CleanedCPFileName = Remove-InvalidFileNameChars -Name $CPfileName
$CPTName = "CPT - " + $CleanedCPFileName
$filePath = $filePathBase + $CPTName + '.xml'
$AdfsClaimsProviderTrust | Export-Clixml $filePath -ErrorAction SilentlyContinue
}
#Compress-Archive -Path $filePathBase -DestinationPath $zipfileName
invoke-item $filePathBase