JEA에 대한 감사 및 보고
JEA를 배포한 후에는 JEA 구성을 정기적으로 감사해야 합니다. 감사를 통해 올바른 사용자에게 JEA 엔드포인트에 대한 액세스 권한이 있는지와 할당된 해당 역할이 여전히 적절한지를 평가할 수 있습니다.
컴퓨터에서 등록된 JEA 세션 찾기
컴퓨터에 등록된 JEA 세션을 검사 위해 Get-PSSessionConfiguration cmdlet을 사용합니다.
# Filter for sessions that are configured as 'RestrictedRemoteServer' to
# find JEA-like session configurations
Get-PSSessionConfiguration | Where-Object { $_.SessionType -eq 'RestrictedRemoteServer' }
Name : JEAMaintenance
PSVersion : 5.1
StartupScript :
RunAsUser :
Permission : CONTOSO\JEA_DNS_ADMINS AccessAllowed, CONTOSO\JEA_DNS_OPERATORS AccessAllowed,
CONTOSO\JEA_DNS_AUDITORS AccessAllowed
엔드포인트에 대한 유효 권한은 Permission 속성에 나열됩니다. 이러한 사용자는 JEA 엔드포인트에 연결할 수 있는 권한을 가집니다. 그러나 액세스 권한이 있는 역할 및 명령은 엔드포인트를 등록하는 데 사용된 세션 구성 파일의 RoleDefinitions 속성에 의해 결정됩니다. RoleDefinitions 속성을 확장하여 등록된 JEA 엔드포인트에서 역할 매핑을 평가합니다.
# Get the desired session configuration
$jea = Get-PSSessionConfiguration -Name 'JEAMaintenance'
# Enumerate users/groups and which roles they have access to
$jea.RoleDefinitions.GetEnumerator() | Select-Object Name, @{
Name = 'Role Capabilities'
Expression = { $_.Value.RoleCapabilities }
}
컴퓨터에서 사용 가능한 역할 기능 찾기
JEA는 PowerShell 모듈 내 .psrc
RoleCapabilities 폴더에 저장된 파일에서 역할 기능을 가져옵니다. 다음 함수는 컴퓨터에서 사용할 수 있는 모든 역할 기능을 찾습니다.
function Find-LocalRoleCapability {
$results = @()
# Find modules with a "RoleCapabilities" subfolder and add any PSRC files to the result set
Get-Module -ListAvailable | ForEach-Object {
$psrcpath = Join-Path -Path $_.ModuleBase -ChildPath 'RoleCapabilities'
if (Test-Path $psrcpath) {
$results += Get-ChildItem -Path $psrcpath -Filter *.psrc
}
}
# Format the results nicely to make it easier to read
$results | Select-Object @{ Name = 'Name'; Expression = { $_.Name.TrimEnd('.psrc') }}, @{
Name = 'Path'; Expression = { $_.FullName }
} | Sort-Object Name
}
참고 항목
여러 역할 기능이 동일한 이름을 공유하는 경우 이 함수의 결과 순서가 반드시 역할 기능을 선택하는 순서는 아닙니다.
특정 사용자에 대한 유효 권한 확인
Get-PSSessionCapability cmdlet은 사용자의 그룹 멤버 자격에 따라 JEA 엔드포인트에서 사용할 수 있는 모든 명령을 열거합니다. 출력은 JEA 세션에서 실행 중인 Get-Command -CommandType All
지정된 사용자의 출력 Get-PSSessionCapability
과 동일합니다.
Get-PSSessionCapability -ConfigurationName 'JEAMaintenance' -Username 'CONTOSO\Alice'
사용자가 추가 JEA 권한을 부여하는 그룹의 영구 멤버가 아닌 경우 이 cmdlet은 이러한 추가 권한을 반영하지 않을 수 있습니다. 이는 Just-In-Time 권한 있는 액세스 관리 시스템을 사용하여 사용자가 보안 그룹에 일시적으로 속할 수 있도록 하는 경우에 발생합니다. 사용자가 해당 작업을 성공적으로 수행하는 데 필요한 액세스 수준만 가져올 수 있도록 역할 및 기능에 대한 사용자 매핑을 신중하게 평가합니다.
PowerShell 이벤트 로그
시스템에서 모듈 또는 스크립트 블록 로깅을 사용하도록 설정한 경우 사용자가 JEA 세션에서 실행하는 각 명령에 대한 Windows 이벤트 로그에서 이벤트를 볼 수 있습니다. 이러한 이벤트를 찾으려면 Microsoft-Windows-PowerShell/Operational 이벤트 로그를 열고 이벤트 ID가 4104인 이벤트를 찾습니다.
각 이벤트 로그 항목에는 명령이 실행된 세션에 대한 정보가 포함됩니다. JEA 세션의 경우 이벤트에는 커넥트edUser 및 RunAsUser에 대한 정보가 포함됩니다. ConnectedUser는 JEA 세션을 만든 실제 사용자입니다. RunAsUser는 명령을 실행하는 데 사용되는 계정 JEA입니다.
애플리케이션 이벤트 로그는 RunAsUser에서 변경된 내용을 표시합니다. 따라서 모듈 및 스크립트 로깅을 사용하도록 설정하면 ConnectedUser로 특정 명령 호출을 다시 추적해야 합니다.
애플리케이션 이벤트 로그
외부 애플리케이션 또는 서비스와 상호 작용하는 JEA 세션에서 실행되는 명령은 이벤트를 자체 이벤트 로그에 기록할 수 있습니다. PowerShell 로그 및 스크립트와 달리 다른 로깅 메커니즘은 JEA 세션의 연결된 사용자를 캡처하지 않습니다. 대신 이러한 애플리케이션은 가상 실행 사용자만 기록합니다. 명령을 실행한 사용자를 확인하려면 세션 기록을 참조하거나 PowerShell 이벤트 로그를 애플리케이션 이벤트 로그에 표시된 시간 및 사용자와 상호 연결해야 합니다.
WinRM 로그는 애플리케이션 이벤트 로그에서 연결한 사용자와 실행 사용자를 연결하는 데 도움을 줄 수도 있습니다. Microsoft-Windows-Windows Remote Management/Operational 로그의 이벤트 ID 193은 새 JEA 세션마다 연결하는 사용자와 실행하는 사용자의 SID(보안 식별자) 및 계정 이름을 기록합니다.
세션 대본
각 사용자 세션에 대한 대본을 만들도록 JEA를 구성한 경우 모든 사용자 작업의 텍스트 복사본이 지정된 폴더에 저장됩니다.
다음 명령(관리자)은 모든 대본 디렉터리를 찾습니다.
Get-PSSessionConfiguration |
Where-Object { $_.TranscriptDirectory -ne $null } |
Format-Table Name, TranscriptDirectory
각 대본은 세션이 시작된 시간, 세션에 연결된 사용자 및 할당된 JEA ID에 대한 정보로 시작합니다.
**********************
Windows PowerShell transcript start
Start time: 20160710144736
Username: CONTOSO\Alice
RunAs User: WinRM Virtual Users\WinRM VA_1_CONTOSO_Alice
Machine: SERVER01 (Microsoft Windows NT 10.0.14393.0)
[...]
대본 본문에는 사용자가 호출한 각 명령에 대한 정보가 포함됩니다. PowerShell 원격에 대한 명령이 변환되는 방식으로 인해 JEA 세션에서 사용된 명령의 정확한 구문을 사용할 수 없습니다. 그러나 실행된 유효 명령은 여전히 확인할 수 있습니다. JEA 세션에서 Get-Service Dns
를 실행한 사용자의 예제 기록 코드 조각은 다음과 같습니다.
PS>CommandInvocation(Get-Service): "Get-Service"
>> ParameterBinding(Get-Service): name="Name"; value="Dns"
>> CommandInvocation(Out-Default): "Out-Default"
>> ParameterBinding(Out-Default): name="InputObject"; value="Dns"
Running Dns DNS Server
CommandInvocation 줄은 사용자가 실행하는 각 명령에 대해 작성됩니다. ParameterBindings는 명령과 함께 제공되는 각 매개 변수와 값을 기록합니다. 이전 예제에서는 매개 변수 이름 에 cmdlet에 대한 값 Dns 가 제공된 것을 Get-Service
볼 수 있습니다.
각 명령의 출력은 일반적으로 CommandInvocation을 트리거합니다Out-Default
. InputObject는 Out-Default
명령에서 반환된 PowerShell 개체입니다. 해당 개체의 세부 정보는 아래 몇 줄로 인쇄되어 사용자가 본 것을 자세히 모방합니다.
참고 항목
PowerShell