経緯
Configルールの修復機能で使えそうなパターンなのでやってみました。
設定
IAMポリシーの作成
セキュリティポリシーから指定されたルールを削除するポリシー(RevokeSecurityGroupIngress)を作成します。
IAMサービスより、[ポリシー]メニューを選択して「ポリシーの作成」をクリックします。
data:image/s3,"s3://crabby-images/ab46e/ab46eed511d2aa46f58a571234bedfdeaae4dc7d" alt=""
ビジュアルエディタでポリシーを作成します。
下記の内容でポリシーを作成します。
[サービス]:EC2
[アクション]:RevokeSecurityGroupIngress
[リソース]:全て
[名前]:RevokeSecurityGroupIngress
data:image/s3,"s3://crabby-images/810c9/810c9d10a34928032160a6655b22374b4562049b" alt=""
IAM Roleの作成
先ほど作成したポリシーをロールに割り当てます。
IAMサービスより、[ロール]メニューを選択して「ロールの作成」をクリックします。
data:image/s3,"s3://crabby-images/076ba/076ba1405e2ce1aab1b79159c16e016fdda68e88" alt=""
[AWSサービス]、[SystemManager]を選択します。
(SSMのAutomation機能で修復する為)
data:image/s3,"s3://crabby-images/d8810/d881071ae8a6280942fc1f09a42133774a1eefe2" alt=""
作成済みのポリシー(RevokeSecurityGroupIngress)を選択します。
data:image/s3,"s3://crabby-images/51f40/51f409fcb788b1f34dcc81c78ec53cbfaa6ed290" alt=""
タグは何も指定せず次へ
data:image/s3,"s3://crabby-images/efe84/efe840603438e3ba2168018a5991a6cbc447683f" alt=""
ロール名は”RemovePublicAccessForSSM”として作成しました。
data:image/s3,"s3://crabby-images/19622/19622504f2459f40aae0ab56dd3b42f6db19bce3" alt=""
Configルールの作成
Configサービスの[ルール]メニューより「ルールの追加」ボタンをクリックします。
data:image/s3,"s3://crabby-images/63a4c/63a4c80f6d65b38cf51f88c7595ec6a6abd16000" alt=""
“restricted-ssh”を選択します。
data:image/s3,"s3://crabby-images/7a10b/7a10bba922ce405ee685e88575f9f000db601dcb" alt=""
[修復アクション]:AWS-DisablePublicAccessForSecurityGroup
[自動修復]:はい、1再試行まで180秒
[リソースIDパラメタ]:GroupId
[パラメータ(GroupId)]:作成したIAM RoleのARN
GroupId(今回であれば修正すべきセキュリティグループのID)をパラメタとしてSSM Automationに渡します。
また、セキュリティグループを修正するためのIAM Role ARNをパラメタとして指定します。
data:image/s3,"s3://crabby-images/e9846/e9846b85325dda557b0643afd68c44635dec2f4b" alt=""
確認
セキュリティグループの作成
それではテスト用のセキュリティグループを作成します。
VPCサービスより、[セキュリティグループ]より「セキュリティグループを作成」ボタンをクリックします。
data:image/s3,"s3://crabby-images/ed662/ed662860fb21d9f4c51a511c661aed2e186b9d3c" alt=""
下記の項目を入力してセキュリティグループ作成します。
[セキュリティグループ名]:sg_test
[説明]:test
[VPC]:適時選択してください
インバウンドは下記を登録しました。
- SSH 0.0.0.0/0,::/0
- RDP 0.0.0.0
- RDP ,::/0
- SSH 1.2.3.0/24
data:image/s3,"s3://crabby-images/7ee82/7ee8261e860a3b832d0967bc4e5f23adae31ea08" alt=""
Configルールの確認
Configサービスのルールページで暫くすると”restricted-ssh”が非準拠となりました。
data:image/s3,"s3://crabby-images/5e10c/5e10cdbd6907b02641464f07eb7ddd4e777f0b61" alt=""
”restricted-ssh”の詳細画面で確認すると、[アクションステータス]項目が”アクションが正常に実行されました”と表示されました。
data:image/s3,"s3://crabby-images/d543e/d543e7336af00a8f2caac683df39b0d8b512698f" alt=""
セキュリティグループの確認
セキュリティグループも確認します。
パブリック公開されていたSSHとRDPが削除され、特定IPからのSSH接続だけ許可されてました。
data:image/s3,"s3://crabby-images/8d699/8d6992963122258dc53a5e4c4997aa77df12dc85" alt=""