AWS Elemental MediaConnect が IAM と連動する方法
MediaConnect へのアクセスを管理するために IAM を使用する前に、MediaConnect でどの IAM 機能が使用できるかを理解しておく必要があります。MediaConnect および他の AWS サービスと IAM の連携について概要を把握するには、IAM ユーザーガイドの IAM と連携するAWS サービスを参照してください。
MediaConnect での ID ベースのポリシー
IAM のアイデンティティベースポリシーでは、許可または拒否するアクションとリソース、またアクションを許可または拒否する条件を指定できます。MediaConnect は、特定のアクション、リソース、および条件キーをサポートしています。JSON ポリシーで使用するすべての要素については、「IAM ユーザーガイド」の「IAM JSON ポリシーの要素のリファレンス」を参照してください。
アクション
管理者は AWS JSON ポリシーを使用して、誰が何にアクセスできるかを指定できます。つまり、どのプリンシパルがどのリソースに対してどのような条件下でアクションを実行できるかということです。
JSON ポリシーの Action
要素には、ポリシー内のアクセスを許可または拒否するために使用できるアクションが記述されます。ポリシーアクションの名前は通常、関連する AWS API オペレーションと同じです。一致する API オペレーションのない許可のみのアクションなど、いくつかの例外があります。また、ポリシーに複数のアクションが必要なオペレーションもあります。これらの追加アクションは、依存アクションと呼ばれます。
このアクションは、関連付けられたオペレーションを実行するための許可を付与するポリシーで使用されます。
MediaConnect のポリシーアクションでは、プレフィックス mediaconnect:
をそのアクションに前置します。例えば、MediaConnect ListEntitlements
APIオペレーションを使用して使用権限のリストを表示する許可を付与するには、そのポリシーに mediaconnect:ListEntitlements
アクションを含めます。ポリシーステートメントには、Action
または NotAction
要素を含める必要があります。MediaConnect は、このサービスで実行できるタスクを記述する独自のアクションのセットを定義します。
単一のステートメントに複数のアクションを指定するには、次のようにカンマで区切ります。
"Action": [ "mediaconnect:action1", "mediaconnect:action2"
ワイルドカード (*) を使用して複数のアクションを指定することができます。たとえば、List
という単語で始まるすべてのアクションを指定するには、次のアクションを含めます。
"Action": "mediaconnect:List*"
MediaConnect アクションのリストを表示するには、「IAM ユーザーガイド」の「AWS Elemental MediaConnect によって定義されたアクション」を参照してください。
リソース
管理者は AWS JSON ポリシーを使用して、誰が何にアクセスできるかを指定できます。つまり、どのプリンシパルがどのリソースに対してどのような条件下でアクションを実行できるかということです。
Resource
JSON ポリシー要素は、オブジェクトあるいはアクションが適用されるオブジェクトを指定します。ステートメントには、Resource
または NotResource
要素を含める必要があります。ベストプラクティスとして、Amazon リソースネーム (ARN) を使用してリソースを指定します。これは、リソースレベルの許可と呼ばれる特定のリソースタイプをサポートするアクションに対して実行できます。
オペレーションのリスト化など、リソースレベルの許可をサポートしないアクションの場合は、ステートメントがすべてのリソースに適用されることを示すために、ワイルドカード (*) を使用します。
"Resource": "*"
MediaConnect には次の ARN があります。
arn:${Partition}:mediaconnect:${Region}:${Account}:entitlement:${resourceID}:${resourceName} arn:${Partition}:mediaconnect:${Region}:${Account}:flow:${resourceID}:${resourceName} arn:${Partition}:mediaconnect:${Region}:${Account}:output:${resourceID}:${resourceName} arn:${Partition}:mediaconnect:${Region}:${Account}:source:${resourceID}:${resourceName}
ARN の形式の詳細については、「Amazon リソースネーム (ARN) と AWS サービスの名前空間」を参照してください。
たとえば、ステートメントで 1-23aBC45dEF67hiJ8-12AbC34DE5fG
フローを指定するには、次の ARN を使用します。
"Resource": "arn:aws:mediaconnect:us-east-1:111122223333:flow:1-23aBC45dEF67hiJ8-12AbC34DE5fG:BasketballGame"
特定のアカウントに属するすべてのフローを指定するには、ワイルドカード (*) を使用します。
"Resource": "arn:aws:mediaconnect:us-east-1:111122223333:flow:*"
特定のリソースでは、リソースの作成など一部の MediaConnect アクションを実行できません。このような場合は、ワイルドカード (*) を使用する必要があります。
"Resource": "*"
MediaConnect API アクションの多くが複数のリソースと関連します。たとえば、RemoveFlowOutput
は特定のフローの出力を削除するため、IAM ユーザーはフローおよび出力のアクセス許可が必要です。複数のリソースを単一のステートメントで指定するには、ARN をカンマで区切ります。
"Resource": [ "resource1", "resource2"
MediaConnect リソースタイプとその ARN のリストを表示するには、「IAM ユーザーガイド」の「AWS Elemental MediaConnect によって定義されたリソース」を参照してください。どのアクションで各リソースの ARN を指定できるかについては、「AWS Elemental MediaConnect によって定義されたアクション」を参照してください。
条件キー
管理者は AWS JSON ポリシーを使用して、誰が何にアクセスできるかを指定できます。つまり、どのプリンシパルがどのリソースに対してどのような条件下でアクションを実行できるかということです。
Condition
要素 (または Condition
ブロック) を使用すると、ステートメントが有効な条件を指定できます。Condition
要素はオプションです。イコールや未満などの条件演算子を使用して条件式を作成することで、ポリシーの条件とリクエスト内の値を一致させることができます。
1 つのステートメントに複数の Condition
要素を指定する場合、または 1 つの Condition
要素に複数のキーを指定する場合、AWS では AND
論理演算子を使用してそれらを評価します。単一の条件キーに複数の値を指定する場合、AWS では OR
論理演算子を使用して条件を評価します。ステートメントの許可が付与される前にすべての条件が満たされる必要があります。
条件を指定する際にプレースホルダー変数も使用できます。例えば IAM ユーザーに、IAM ユーザー名がタグ付けされている場合のみリソースにアクセスできる許可を付与することができます。詳細については、IAM ユーザーガイドの「IAM ポリシーの要素: 変数およびタグ」を参照してください。
AWS はグローバル条件キーとサービス固有の条件キーをサポートしています。すべての AWS グローバル条件キーを確認するには、IAM ユーザーガイドの「AWS グローバル条件コンテキストキー」を参照してください。
例
MediaConnect アイデンティティベースのポリシーの例については、AWS Elemental MediaConnect のアイデンティティベースのポリシーの例 を参照してください。
MediaConnect リソースベースのポリシー
AWS Elemental MediaConnect は、リソースベースのポリシーをサポートしません。
MediaConnect タグに基づく認証
AWS Elemental MediaConnect は、リソースのタグ付けやタグに基づいたアクセスの制御をサポートしていません。
MediaConnect IAM ロール
IAM ロールは AWS アカウント内のエンティティで、特定の許可を持っています。
MediaConnect での一時認証情報の使用
一時的な認証情報を使用して、フェデレーションでサインインする、IAM ロールを引き受ける、またはクロスアカウントロールを引き受けることができます。一時的なセキュリティ認証情報を取得するには、AssumeRole または GetFederationToken などの AWS STS API オペレーションを呼び出します。
MediaConnect は、一時認証情報の使用をサポートしています。
サービスにリンクされたロール
サービスにリンクされたロールは、AWS サービスが他のサービスのリソースにアクセスして自動的にアクションを完了することを許可します。サービスにリンクされたロールは IAM アカウント内に表示され、サービスによって所有されます。IAM 管理者は、サービスにリンクされたロールの許可を表示できますが、編集することはできません。
MediaConnect は、サービスにリンクされたロールをサポートしていません。
サービスロール
この機能により、ユーザーに代わってサービスがサービスロールを引き受けることが許可されます。このロールにより、サービスがユーザーに代わって他のサービスのリソースにアクセスし、アクションを完了することが許可されます。サービスロールは、IAM アカウントに表示され、アカウントによって所有されます。つまり、IAM 管理者が、このロールの許可を変更することができます。ただし、これを行うことにより、サービスの機能が損なわれる場合があります。
MediaConnect はサービスロールをサポートしていません。