Amazon AppStream 2.0 교차 서비스 혼동된 대리자 방지 - 아마존 AppStream 2.0

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

Amazon AppStream 2.0 교차 서비스 혼동된 대리자 방지

혼동된 대리자 문제는 작업을 수행할 권한이 없는 엔터티가 권한이 더 많은 엔터티에게 작업을 수행하도록 강요하는 보안 문제입니다. AWS에서는 교차 서비스 가장으로 인해 계정 리소스가 혼동된 대리자 문제에 취약할 수 있습니다. 교차 서비스 가장은 한 서비스(직접적으로 호출하는 서비스)가 다른 서비스(직접적으로 호출되는 서비스)를 직접적으로 호출할 때 발생합니다. 호출하는 서비스는 호출된 서비스가 권한을 사용하여 고객의 리소스에서 호출하는 서비스가 직접 수행할 권한이 없는 방식으로 작동하도록 조작할 수 있습니다. 이를 방지하기 위해 AWS에서는 계정의 리소스에 대한 액세스 권한이 있는 서비스 보안 주체를 사용하여 모든 서비스에 대한 데이터를 보호하는 데 도움이 되는 도구를 제공합니다.

이러한 리소스에 액세스할 때 권한을 제한하려면 리소스 정책에서 aws:SourceArnaws:SourceAccount 전역 조건 컨텍스트 키를 사용하는 것이 좋습니다. 다음 지침에는 이러한 키를 사용하여 리소스를 보호할 때의 권장 사항 및 요구 사항이 자세히 설명되어 있습니다.

  • 하나의 리소스만 교차 서비스 액세스와 연결하려는 경우 aws:SourceArn을 사용합니다.

  • 지정된 계정의 모든 리소스가 교차 서비스 사용과 연결되게 하려는 경우 aws:SourceAccount를 사용합니다.

  • 만약 aws:SourceArn 키에 계정 ID가 포함되어 있지 않은 경우 권한을 제한하려면 두 전역 조건 컨텍스트 키(aws:SourceArnaws:SourceAccount)를 모두 사용해야 합니다.

  • 두 전역 조건 컨텍스트 키를 사용하고 aws:SourceArn 값에 계정 ID가 포함된 경우 동일한 정책 문에서 사용할 경우 aws:SourceAccount 키는 동일한 계정 ID를 사용해야 합니다.

혼동된 대리자 문제로부터 보호하는 가장 효과적인 방법은 허용하려는 리소스와 동일한 Amazon 리소스 이름(ARN)을 사용하는 것입니다. 리소스의 전체 ARN을 모를 경우 ARN의 알 수 없는 부분에 대해 와일드카드(예: *)를 포함한 aws:SourceArn 전역 조건 컨텍스트 키를 사용합니다. 여러 리소스를 지정하려는 경우 ARN에서 와일드카드를 사용할 수도 있습니다. 예를 들어 ARN의 형식을 arn:aws:servicename::region-name::your AWS 계정 ID:*와 같이 지정할 수 있습니다.

예: AppStream 2.0 서비스 역할 교차 서비스 혼동된 대리자 방지

AppStream 2.0은 다양한 리소스 ARN을 사용하여 서비스 역할을 맡기 때문에 조건문이 복잡해집니다. 예상치 못한 AppStream 2.0 리소스 장애를 방지하려면 와일드카드 리소스 유형을 사용하는 것이 좋습니다.

aws:SourceAccount 조건:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": [ "appstream.amazonaws.com" ] }, "Action": "sts:AssumeRole", "Condition": { "StringEquals": { "aws:SourceAccount": "your AWS 계정 ID" } } } ] }
aws:SourceArn 조건:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": [ "appstream.amazonaws.com" ] }, "Action": "sts:AssumeRole", "Condition": { "ArnLike": { "aws:SourceArn": "arn:{aws partition}:appstream:{your region name}:{your AWS 계정 ID}:*" } } } ] }

예: AppStream 2.0 플릿 시스템 역할 교차 서비스 혼동된 대리자 방지

aws:SourceAccount 조건:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": [ "appstream.amazonaws.com" ] }, "Action": "sts:AssumeRole", "Condition": { "StringEquals": { "aws:SourceAccount": "your AWS 계정 ID" } } } ] }
aws:SourceArn 조건:
참고

여러 플릿에 대해 하나의 IAM 역할을 사용하려는 경우 여러 AppStream 2.0 플릿 리소스와 일치하도록 와일드카드(*)와 함께 aws:SourceArn 전역 컨텍스트 조건 키를 사용하는 것이 좋습니다.

{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": [ "appstream.amazonaws.com" ] }, "Action": "sts:AssumeRole", "Condition": { "ArnLike": { "aws:SourceArn": "arn:{aws partition}:appstream:{your region name}:{your AWS 계정 ID}:fleet/{your fleet name}" } } } ] }

예: AppStream 2.0 Elastic 플릿 세션 스크립트 Amazon S3 버킷 정책 교차 서비스 혼동된 대리자 방지

aws:SourceAccount 조건:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": [ "appstream.amazonaws.com" ] }, "Action": "s3:GetObject", "Resource": "your session script S3 path", "Condition": { "StringEquals": { "aws:SourceAccount": "your AWS 계정 ID" } } } ] }
aws:SourceArn 조건:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": [ "appstream.amazonaws.com" ] }, "Action": "s3:GetObject", "Resource": "your session script S3 path", "Condition": { "ArnLike": { "aws:SourceArn": "arn:{aws partition}:appstream:{your region name}:{your AWS 계정 ID}:fleet/{your fleet name}" } } } ] }

예: AppStream 2.0 애플리케이션 Amazon S3 버킷 정책 교차 서비스 혼동된 대리자 방지

Amazon S3 버킷에 데이터를 저장하는 경우 버킷이 혼동된 대리자 문제에 노출될 수 있습니다. 이로 인해 Elastic 플릿, 앱 블록, 설정 스크립트, 애플리케이션 아이콘, 세션 스크립트와 같은 데이터가 악의적인 행위자에게 취약해질 수 있습니다.

혼동된 대리자 문제를 방지하기 위해 ELASTIC-FLEET-EXAMPLE-BUCKET에 대한 Amazon S3 버킷 정책에 aws:SourceAccount 조건 또는 aws:SourceArn 조건을 지정할 수 있습니다.

아래 리소스 정책은 다음 중 하나로 혼동된 대리자 문제를 방지하는 방법을 보여줍니다.

  • AWS 계정 ID가 있는 aws:SourceAccount

  • 전역 조건 컨텍스트 키 aws:SourceArn

AppStream 2.0은 현재 애플리케이션 아이콘에 대한 혼동된 대리자 방지 기능을 지원하지 않습니다. 이 서비스는 VHD 파일 및 설정 스크립트만 지원합니다. 애플리케이션 아이콘에 추가 조건을 추가하려고 하면 아이콘이 최종 사용자에게 표시되지 않습니다.

다음 예시에서 버킷 정책은 소유자 계정의 AppStream 2.0 Elastic 플릿 리소스만 ELASTIC_FLEET_EXAMPLE_BUCKET에 액세스할 수 있도록 허용합니다.

{ "Version": "2012-10-17", "Statement": [ { "Sid": "ConfusedDeputyPreventionExamplePolicy", "Effect": "Allow", "Principal": { "Service": "appstream.amazonaws.com" }, "Action": "s3:GetObject", "Resource": [ "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/vhd-folder/*", "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/scripts/*" ], "Condition": { "StringEquals": { "aws:SourceAccount": "your AWS 계정 ID" } } }, { "Sid": "AllowRetrievalPermissionsToS3AppIconsForAppStream", "Effect": "Allow", "Principal": { "Service": "appstream.amazonaws.com" }, "Action": "s3:GetObject", "Resource": "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/app-icons/*" } ] }

aws:SourceArn 조건을 사용하여 특정 리소스에 대한 리소스 액세스를 제한할 수도 있습니다.

참고

리소스의 전체 ARN을 모를 경우 또는 여러 리소스를 지정하려는 경우, ARN의 알 수 없는 부분에 대해 와일드카드(*)를 포함한 aws:SourceArn 전역 조건 컨텍스트 키를 사용합니다.

{ "Version": "2012-10-17", "Statement": [ { "Sid": "ConfusedDeputyPreventionExamplePolicy", "Effect": "Allow", "Principal": { "Service": "appstream.amazonaws.com" }, "Action": "s3:GetObject", "Resource": [ "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/vhd-folder/*", "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/scripts/*" ], "Condition": { "ArnLike": { "aws:SourceArn": "arn:{aws-partition}:appstream:{your region name}:{your AWS account ID}:app-block/*" } } }, { "Sid": "AllowRetrievalPermissionsToS3AppIconsForAppStream", "Effect": "Allow", "Principal": { "Service": "appstream.amazonaws.com" }, "Action": "s3:GetObject", "Resource": "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/app-icons/*" } ] }

aws:SourceArnaws:SourceAccount 조건을 사용하여 특정 리소스 및 계정에 대한 리소스 액세스를 제한할 수도 있습니다.

참고

리소스의 전체 ARN을 모를 경우 또는 여러 리소스를 지정하려는 경우, ARN의 알 수 없는 부분에 대해 와일드카드(*)를 포함한 aws:SourceArn 전역 조건 컨텍스트 키를 사용합니다.

{ "Version": "2012-10-17", "Statement": [ { "Sid": "ConfusedDeputyPreventionExamplePolicy", "Effect": "Allow", "Principal": { "Service": "appstream.amazonaws.com" }, "Action": "s3:GetObject", "Resource": [ "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/vhd-folder/*", "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/scripts/*" ], "Condition": { "ArnLike": { "aws:SourceArn": "arn:{aws partition}:appstream:{your region name}:{your AWS account ID}:app-block/*" }, "StringEquals": { "aws:SourceAccount": "your AWS account ID" } } }, { "Sid": "AllowRetrievalPermissionsToS3AppIconsForAppStream", "Effect": "Allow", "Principal": { "Service": "appstream.amazonaws.com" }, "Action": "s3:GetObject", "Resource": "arn:aws:s3:::ELASTIC-FLEET-EXAMPLE-BUCKET/app-icons/*" } ] }