3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

CloudFront の OAC 機能

Posted at

概要

S3 で公開しているコンテンツを、CloudFront からのアクセスのみに制限するには OAI という機能で実現していました。

ざっくり言うと、セキュリティ面が強化され、以下の点が強化されたようです。

  • AWS Signature Version 4(SigV4)
  • SSE-KMS

SigV4

  1. クライアントが CloudFront に HTTP または HTTPS のリクエストを送信する。
  2. CloudFront のエッジロケーションはリクエストを受信する。
    リクエストされたオブジェクトがまだキャッシュされていない場合、CloudFront は OAC 署名プロトコル(SigV4)を使用してリクエストに署名する。
    OAC を設定する際、
    「リクエストに署名しない」
    「リクエストに署名する」
    「リクエストに署名する(リクエストに署名するが認証ヘッダーを上書きしない)」
    という 3 つの署名動作を選択することができる。

リクエストに署名しない

  • オリジンアクセス制御を使用しないことと同じことになる。

署名リクエスト(推奨)

  • 受信したリクエストがすでにクライアントアプリケーションによって署名された認証ヘッダーを持っている場合でも、CloudFront は常にクライアントから受信したリクエストに署名する。
  • CloudFront はクライアントの認証ヘッダーを削除し、CloudFront のクレデンシャルでリクエストに再署名し、新しい認証ヘッダーを生成してS3オリジンに送信する。
  • CloudFront がリクエストに署名することで、クライアントと CloudFront 間のデータ転送が少なくなり、アプリケーションのパフォーマンスが向上する。

認証ヘッダーを上書きしない

  • 受信リクエストに認証ヘッダーがある場合は上書きしない。

OAC を設定する(新規)

CloudFront ディストリビューションの、S3 バケットアクセスで、Origin access contorol settings があります。
スクリーンショット 2022-09-03 17.32.00.png

「コントロール設定を作成」を開くと、以下の通り、署名動作を選択できます。
スクリーンショット 2022-09-03 17.36.28.png

ディストリビューションが作成されたら、「ポリシーをコピー」からコピーし、S3バケットポリシーを更新してあげます。

スクリーンショット 2022-09-03 18.07.46.png

{
        "Version": "2008-10-17",
        "Id": "Policy",
        "Statement": [
            {
                "Sid": "AllowCloudFront",
                "Effect": "Allow",
                "Principal": {
                    "Service": "cloudfront.amazonaws.com"
                },
                "Action": "s3:GetObject",
                "Resource": "arn:aws:s3:::XXX/*",
                "Condition": {
                    "StringEquals": {
                      "AWS:SourceArn": "arn:aws:cloudfront::XXX:distribution/XXX"
                    }
                }
            }
        ]
      }

SSE-KMS

  • SSE-KMS 暗号化を使用して S3 バケットに保存されたコンテンツを暗号化することを要求する場合、SSE-KMS で暗号化された S3 オブジェクトにアクセスするために OAC を使用することができる。
  • CloudFront の IAM サービスプリンシパルが KMS キーにアクセスできるように、KMS ポリシーを設定する必要がある。

設定

1.KMS からカスタマーキーを作成する。

2.S3 で、1.で作成した SSE-KMS を指定する。

3.CloudFront にアクセスできるように、KMSキーポリシーを更新(既存のものに追加)する。

        {
            "Sid": "AllowCloudFrontServicePrincipalSSE-KMS",
            "Effect": "Allow",
            "Principal": {
                "Service": "cloudfront.amazonaws.com",
                "AWS": "arn:aws:iam::XXX:root"
            },
            "Action": [
                "kms:Decrypt",
                "kms:Encrypt",
                "kms:GenerateDataKey*"
            ],
            "Resource": "*",
            "Condition": {
                "StringEquals": {
                    "AWS:SourceArn": "arn:aws:cloudfront::XXX:distribution/XXX"
                }
            }
        }
3
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?