- vừa được xem lúc

AWS Certified Solutions Architect Professional - Identity Federation - Organizations Service Control Policies

0 0 8

Người đăng: Quân Huỳnh

Theo Viblo Asia

Introduction

A quick note about AWS Organizations Service Control Policies. This post is a quick note from the course Ultimate AWS Certified Solutions Architect Professional by Stephane Maarek. The only purpose of this post is a summary, if you want detailed learning, please buy a course by Stephane Maarek.

image.png

Service Control Policies

Service control policies (SCPs) are a type of organization policy that you can use to manage permissions in your organization.

SCPs offer central control over the maximum available permissions for all accounts in your organization.

SCP only applies to the OU or Account level, it does not apply to the Management Accounts.

SCP is applied to all the Users and Roles in the account, including the Root user. The SCP does not affect Service-linked roles.

Use cases:

  • Restrict access to certain services.
  • Deny access to AWS based on the requested AWS Region.
  • Block service access for the root user.

SCP Hierarchy Inheritance

You can attach policies to organization entities (Root OU, Organizational Unit (OU), or Account) in your organization:

  • When you attach a policy to the Root OU, all OUs and accounts in the organization inherit that policy.
  • You can’t attach a policy to the Management Account.
  • When you attach a policy to a specific OU, accounts that are directly under that OU or any child OU inherit the policy.
  • When you attach a policy to a specific account, it affects only that account.

For example, we have an AWS Organization below.

image.png

Management Account:

  • Can do anything.
  • (no SCP apply).

Account A:

  • Can do anything.
  • EXCEPT for access Redshift (explicit Deny from Prod OU).

Account B:

  • Can do anything.
  • EXCEPT for access Redshift (explicit Deny from Prod OU).
  • EXCEPT for access Lambda (explicit Deny from HR OU).

Account C:

  • Can do anything.
  • EXCEPT for access Redshift (explicit Deny from Prod OU).

Strategies for using SCPs

You can configure the service control policies (SCPs) in your organization to work as either of the following:

  • A deny list: actions are allowed by default, and you specify what services and actions are prohibited.
  • An allow list: actions are prohibited by default, and you specify what services and actions are allowed.

For example, deny list strategy.

{ "Version": "2012-10-17", "Statement": [ { "Sid": "AllowsAllActions", "Effect": "Allow", "Action": "*", "Resource": "*" }, { "Sid": "DenyDynamoDB", "Effect": "Deny", "Action": "dynamodb:*", "Resource": "*" } ]
}

This policy enables full permissions for the account except for DynamoDB.

Example allow list strategy.

{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "ec2:*", "cloudwatch:*" ], "Resource": "*" } ]
}

This policy enables permissions for the account to access EC2 and Cloudwatch.

IAM Policy Evaluation Logic

image.png

Deny evaluation: By default, all requests are denied. This is called an implicit deny.

Organizations SCPs: Then the code evaluates AWS Organization service control policies (SCPs) that apply to the request. If the enforcement code does not find any applicable Allow statements in the SCPs, then the request is implicitly denied. The code returns a final decision of Deny. If there is no SCP, or if the SCP allows the requested action, the code continues.

Resource-based policies: Depending on the type of principal, an Allow in a resource-based policy can result in a final decision of Allow , even if an implicit deny in an identity-based policy, permissions boundary, or session policy is present.

Identity-based policies: The code then checks the identity-based policies for the principal. If there are no identity-based policies or no statements in identity-based policies that allow the requested action, then the request is implicitly denied and the code returns a final decision of Deny. If any statement in any applicable identity-based policies allows the requested action, the code continues.

IAM permissions boundaries: The code then checks whether the IAM entity that is used by the principal has a permissions boundary. If the policy that is used to set the permissions boundary does not allow the requested action, then the request is implicitly denied.

Session policies: The code then checks whether the principal is a session principal.

Restricting Tags with IAM Policies

You can restrict specific Tags on AWS resources. Using the aws:TagKeys Condition Key.

For example, allow IAM users to create EBS Volumes only if it has the “Env” and “CostCenter” Tags. Use either ForAllValues (must have all keys) or ForAnyValue (must have any of these keys at a minimum).

ForAllValues.

{ "Version": "2012-10-17", "Statement": [{ "Effect": "Allow", "Action": "ec2:CreateVolume", "Resource": "*", "Condition": {"ForAllValues:StringEquals": {"aws:TagKeys": ["Env", "CostCenter"]}} }]
}

ForAnyValue.

{ "Version": "2012-10-17", "Statement": [{ "Effect": "Allow", "Action": "ec2:CreateVolume", "Resource": "*", "Condition": {"ForAnyValue:StringEquals": {"aws:TagKeys": ["Env", "CostCenter"]}} }]
}

Using SCP to Restrict Creating Resources

You can prevent IAM Users/Roles in the affected Member accounts from creating resources if they don’t have specific Tags.

For example, restrict IAM users to create EBS Volumes if it doesn’t have the “CostCenter” Tags.

{ "Version": "2012-10-17", "Statement": [{ "Effect": "Deny", "Action": "ec2:CreateVolume", "Resource": "*", "Condition": {"Null": {"aws:RequestTag": "true"}} }]
}

Tag Policies

Helps you standardize tags across resources in an AWS Organization. Ensure consistent tags, audit tagged resources, and maintain proper resource categorization.

You define Tag keys and their allowed values. Helps with AWS Cost Allocation Tags and Attribute-based Access Control.

Backup Policies

AWS Backup enables you to create Backup Plans that define how to backup your AWS resources. Backup policies in AWS Organizations combine all of those pieces into JSON text documents.

You can attach a backup policy to any of the elements in your organization’s structure, such as the root, organizational units (OUs), and individual accounts.

Backup policies give you granular control over backing up your resources at whatever level your organization requires. For example, you can specify in a policy attached to the organization’s root that all Amazon DynamoDB tables must be backed up.

The effective backup plan for each AWS account in the organization appears in the AWS Backup console as an immutable plan for that account (view only).

End

End a quick note about AWS Organizations Service Control Policies.

Bình luận

Bài viết tương tự

- vừa được xem lúc

PDF Export, cẩn thận với những input có thể truyền vào

Giới thiệu. Dạo gần đây mình tình cờ gặp rất nhiều lỗi XSS, tuy nhiên trang đó lại có sử dụng dữ liệu người dùng input vào để export ra PDF.

0 0 66

- vừa được xem lúc

Giới thiệu về AWS Batch

Khi sử dụng hệ thống cloud service, điều chúng ta thường phải quan tâm đến không chỉ là hiệu suất hoạt động (performance) mà còn phải chú ý đến cả chi phí bỏ ra để duy trì hoạt động của hệ thống. Chắn hẳn là hệ thống lớn hay nhỏ nào cũng đã từng phải dùng đến những instance chuyên để chạy batch thực

0 0 143

- vừa được xem lúc

Tìm hiểu về AWS KMS

1. AWS KMS là gì. Ở KMS bạn có thể lựa chọn tạo symetric key (khóa đối xứng) hoặc asymetric key (khóa bất đối xứng) để làm CMK (Customer Master Key). Sau khi tạo key thì có thể thiết đặt key policy để control quyền access và sử dụng key.

0 0 66

- vừa được xem lúc

AWS VPC cho người mới bắt đầu

Tuần này, tôi trình bày lại những gì tôi đã học được về Virtual Private Cloud (VPC) của Amazon. Nếu bạn muốn xem những gì tôi đã học được về AWS, hãy xem Tổng quan về DynamoDB và Tổng quan về S3. VPC là gì. Những điều cần lưu ý:.

0 0 84

- vừa được xem lúc

AWS Essentials (Phần 6): Guildline SNS Basic trên AWS

Tiếp tục với chuỗi bài viết về Basic AWS Setting, chúng ta tiếp tục tìm hiểu tiếp tới SNS (Simple Notification Service). Đây là một service của AWS cho phép người dùng setting thực hiện gửi email, text message hay push notification tự động tới mobile device dựa trên event người dùng setting phía AWS

0 0 145

- vừa được xem lúc

Sử dụng Amazon CloudFront Content Delivery Network với Private S3 Bucket — Signing URLs

Trong nhiều trường hợp, thì việc sử dụng CDN là bắt buộc. Mình đã trải nghiệm với một số CDN nhưng cuối cùng mình lựa chọn sử dụng AWS CloudFront.

0 0 118