

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# タグを使用した CodeArtifact リソースへのアクセスのコントロール
<a name="tag-based-access-control"></a>

IAM ユーザーポリシーステートメントの条件は、CodeArtifact アクションに必要なリソースへのアクセス許可を指定するために使用する構文の一部です。条件内でタグを使用することは、リソースとリクエストへのアクセスをコントロールするひとつの方法です。CodeArtifact リソースのタグ付けの詳細については、[リソースのタグ付け](tag-resources.md) を参照してください。このトピックでは、タグベースのアクセスコントロールについて説明します。

IAM ポリシーの設計時に特定のリソースへのアクセス権を付与することで、詳細なアクセス許可を設定できます。管理するリソースの数が増えるに従って、このタスクはより困難になります。リソースにタグ付けしてポリシーステートメント条件でタグを使用することにより、このタスクをより容易にすることができます。特定のタグを使用して任意のリソースへのアクセス権を一括して付与します。次に、作成時や以降の段階で、このタグを関連リソースに繰り返し適用します。

タグは、リソースにアタッチしたり、タグ付けをサポートするサービスへのリクエストに渡したりすることができます。CodeArtifact では、リソースにタグを付けることができ、一部のアクションにタグを含めることができます。IAM ポリシーを作成するときに、タグ条件キーを使用して以下をコントロールできます。
+ どのユーザーがドメインやリポジトリのリソースに対してアクションを実行できるか、既に付けられているタグに基づいて表示します。
+ どのタグをアクションのリクエストで渡すことができるか。
+ リクエストで特定のタグキーを使用できるかどうか。

タグ条件キーの完全な構文と意味については、[[IAM ユーザーガイド]](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_tags.html)の *[タグを使用したアクセスコントロール]*」を参照してください。

**重要**  
リソースのタグを使用してアクションを制限する場合、タグはアクションが実行されるリソース上にある必要があります。例えば、タグを使用して `DescribeRepository` 権限を拒否するには、ドメインではなく各リポジトリにタグ付けする必要があります。CodeArtifact のアクションとそれらが実行されるリソースのリストについては、「[AWS CodeArtifact アクセス許可リファレンス](auth-and-access-control-permissions-reference.md)」を参照してください。

## タグベースのアクセスコントロールの例
<a name="tag-based-access-control-examples"></a>

次の例は、CodeArtifact ユーザー用のポリシーでタグ条件を指定する方法を示しています。

**Example 1: リクエストのタグに基づいてアクションを制限する**  
`AWSCodeArtifactAdminAccess`マネージドユーザーポリシーは、すべてのリソースに対して任意の CodeArtifact アクションを実行する無制限のアクセス許可をユーザーに付与します。  
次のポリシーでは、リクエストに特定のタグが含まれていない限り、この権限を制限し、未認証のユーザーに対してリポジトリを作成するアクセス許可を拒否します。そのために、`1` または `2` の値のいずれかを持つ `costcenter` という名前のタグをこのリクエストが指定していない場合、`CreateRepository` アクションを拒否します。お客様の管理者は、未認証の IAM ユーザーには、マネージドユーザーポリシーに加えて、この IAM ポリシーをアタッチする必要があります。    
****  

```
{
  "Version":"2012-10-17",		 	 	 
  "Statement": [
    {
      "Effect": "Deny",
      "Action": "codeartifact:CreateRepository",
      "Resource": "*",
      "Condition": {
        "Null": {
          "aws:RequestTag/costcenter": "true"
        }
      }
    },
    {
      "Effect": "Deny",
      "Action": "codeartifact:CreateRepository",
      "Resource": "*",
      "Condition": {
          "ForAnyValue:StringNotEquals": {
              "aws:RequestTag/costcenter": [
                  "1",
                  "2"
              ]
          }
      }
  }
  ]
}
```

**Example 2: リソースタグに基づいてアクションを制限する**  
`AWSCodeArtifactAdminAccess`マネージドユーザーポリシーは、すべてのリソースに対して任意の CodeArtifact アクションを実行する無制限のアクセス許可をユーザーに付与します。  
次のポリシーでは、この権限を制限し、未認証のユーザーが指定したリポジトリに対してアクションを実行するアクセス許可を拒否します。そのために、`Value1` または `Value2` の値のいずれかを持つ `Key1` という名前のタグをこのリソースが持つ場合、一部のアクションを拒否します。(この`aws:ResourceTag` 条件キーを使用して、それらのリソースのタグに基づいて、このリソースへのアクセスをコントロールします)。お客様の管理者は、未認証の IAM ユーザーには、マネージドユーザーポリシーに加えて、この IAM ポリシーをアタッチする必要があります。    
****  

```
{
  "Version":"2012-10-17",		 	 	 
  "Statement": [
    {
      "Effect": "Deny",
      "Action": [
        "codeartifact:TagResource",
        "codeartifact:UntagResource",
        "codeartifact:DescribeDomain",
        "codeartifact:DescribeRepository",
        "codeartifact:PutDomainPermissionsPolicy",
        "codeartifact:PutRepositoryPermissionsPolicy",
        "codeartifact:ListRepositoriesInDomain",
        "codeartifact:UpdateRepository",
        "codeartifact:ReadFromRepository",
        "codeartifact:ListPackages",
        "codeartifact:ListTagsForResource"
      ],
      "Resource": "*",
      "Condition": {
        "StringEquals": {
          "aws:ResourceTag/Key1": ["Value1", "Value2"]
        }
      }
    }
  ]
}
```

**Example 3: リソースタグに基づいてアクションを許可する**  
次のポリシーは、CodeArtifact のリポジトリやパッケージについてアクションを実行し、情報を取得するアクセス許可をユーザーに付与します。  
そのために、`Value1` という値を持つ `Key1` という名前のタグをこのリポジトリが持つ場合に、特定のアクションを許可します。(この `aws:RequestTag` 条件キーを使用して、IAM リクエストで渡すことができるタグをコントロールします)。`aws:TagKeys` 条件は、タグキーの大文字と小文字を区別します。このポリシーは、`AWSCodeArtifactAdminAccess` マネージドユーザーポリシーが添付されていない IAM ユーザーに便利です。このマネージドポリシーは、すべてのリソースに対して任意の CodeArtifact アクションを実行する無制限の許可をユーザーに付与します。    
****  

```
{
  "Version":"2012-10-17",		 	 	 
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "codeartifact:UpdateRepository",
        "codeartifact:DeleteRepository",
        "codeartifact:ListPackages"
      ],
      "Resource": "*",
      "Condition": {
        "StringEquals": {
          "aws:ResourceTag/Key1": "Value1"
        }
      }
    }
  ]
}
```

**Example 4: リクエストのタグに基づいてアクションを許可する**  
次のポリシーでは、CodeArtifact の指定されたドメインにリポジトリを作成するアクセス許可をユーザーに付与します。  
そのために、`Value1` という値を持つ `Key1` という名前のタグをこのリクエストのリソース作成 API が指定する場合に、`CreateRepository` アクションと `TagResource` アクションを許可します。(この `aws:RequestTag` 条件キーを使用して、IAM リクエストで渡すことができるタグをコントロールします)。`aws:TagKeys` 条件は、タグキーの大文字と小文字を区別します。このポリシーは、`AWSCodeArtifactAdminAccess` マネージドユーザーポリシーが添付されていない IAM ユーザーに便利です。このマネージドポリシーは、すべてのリソースに対して任意の CodeArtifact アクションを実行する無制限の許可をユーザーに付与します。    
****  

```
{
  "Version":"2012-10-17",		 	 	 
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "codeartifact:CreateRepository",
        "codeartifact:TagResource"
      ],
      "Resource": "*",
      "Condition": {
        "StringEquals": {
          "aws:RequestTag/Key1": "Value1"
        }
      }
    }
  ]
}
```