AWS CLI version 2, the latest major version of AWS CLI, is now stable and recommended for general use. To view this page for the AWS CLI version 2, click here. For more information see the AWS CLI version 2 installation instructions and migration guide.
[ aws . accessanalyzer ]
Creates an access preview that allows you to preview IAM Access Analyzer findings for your resource before deploying resource permissions.
See also: AWS API Documentation
create-access-preview
--analyzer-arn <value>
--configurations <value>
[--client-token <value>]
[--cli-input-json <value>]
[--generate-cli-skeleton <value>]
[--debug]
[--endpoint-url <value>]
[--no-verify-ssl]
[--no-paginate]
[--output <value>]
[--query <value>]
[--profile <value>]
[--region <value>]
[--version <value>]
[--color <value>]
[--no-sign-request]
[--ca-bundle <value>]
[--cli-read-timeout <value>]
[--cli-connect-timeout <value>]
--analyzer-arn
(string)
The ARN of the account analyzer used to generate the access preview. You can only create an access preview for analyzers with anAccount
type andActive
status.
--configurations
(map)
Access control configuration for your resource that is used to generate the access preview. The access preview includes findings for external access allowed to the resource with the proposed access control configuration. The configuration must contain exactly one element.
key -> (string)
value -> (tagged union structure)
Access control configuration structures for your resource. You specify the configuration as a type-value pair. You can specify only one type of access control configuration.
Note
This is a Tagged Union structure. Only one of the following top level keys can be set:ebsSnapshot
,ecrRepository
,iamRole
,efsFileSystem
,kmsKey
,rdsDbClusterSnapshot
,rdsDbSnapshot
,secretsManagerSecret
,s3Bucket
,snsTopic
,sqsQueue
,s3ExpressDirectoryBucket
,dynamodbStream
,dynamodbTable
.ebsSnapshot -> (structure)
The access control configuration is for an Amazon EBS volume snapshot.
userIds -> (list)
The IDs of the Amazon Web Services accounts that have access to the Amazon EBS volume snapshot.
- If the configuration is for an existing Amazon EBS volume snapshot and you do not specify the
userIds
, then the access preview uses the existing shareduserIds
for the snapshot.- If the access preview is for a new resource and you do not specify the
userIds
, then the access preview considers the snapshot without anyuserIds
.- To propose deletion of existing shared
accountIds
, you can specify an empty list foruserIds
.(string)
groups -> (list)
The groups that have access to the Amazon EBS volume snapshot. If the value
all
is specified, then the Amazon EBS volume snapshot is public.
- If the configuration is for an existing Amazon EBS volume snapshot and you do not specify the
groups
, then the access preview uses the existing sharedgroups
for the snapshot.- If the access preview is for a new resource and you do not specify the
groups
, then the access preview considers the snapshot without anygroups
.- To propose deletion of existing shared
groups
, you can specify an empty list forgroups
.(string)
kmsKeyId -> (string)
The KMS key identifier for an encrypted Amazon EBS volume snapshot. The KMS key identifier is the key ARN, key ID, alias ARN, or alias name for the KMS key.
- If the configuration is for an existing Amazon EBS volume snapshot and you do not specify the
kmsKeyId
, or you specify an empty string, then the access preview uses the existingkmsKeyId
of the snapshot.- If the access preview is for a new resource and you do not specify the
kmsKeyId
, the access preview considers the snapshot as unencrypted.ecrRepository -> (structure)
The access control configuration is for an Amazon ECR repository.
repositoryPolicy -> (string)
The JSON repository policy text to apply to the Amazon ECR repository. For more information, see Private repository policy examples in the Amazon ECR User Guide .iamRole -> (structure)
The access control configuration is for an IAM role.
trustPolicy -> (string)
The proposed trust policy for the IAM role.efsFileSystem -> (structure)
The access control configuration is for an Amazon EFS file system.
fileSystemPolicy -> (string)
The JSON policy definition to apply to the Amazon EFS file system. For more information on the elements that make up a file system policy, see Amazon EFS Resource-based policies .kmsKey -> (structure)
The access control configuration is for a KMS key.
keyPolicies -> (map)
Resource policy configuration for the KMS key. The only valid value for the name of the key policy is
default
. For more information, see Default key policy .key -> (string)
value -> (string)
grants -> (list)
A list of proposed grant configurations for the KMS key. If the proposed grant configuration is for an existing key, the access preview uses the proposed list of grant configurations in place of the existing grants. Otherwise, the access preview uses the existing grants for the key.
(structure)
A proposed grant configuration for a KMS key. For more information, see CreateGrant .
operations -> (list)
A list of operations that the grant permits.
(string)
granteePrincipal -> (string)
The principal that is given permission to perform the operations that the grant permits.retiringPrincipal -> (string)
The principal that is given permission to retire the grant by using RetireGrant operation.constraints -> (structure)
Use this structure to propose allowing cryptographic operations in the grant only when the operation request includes the specified encryption context .
encryptionContextEquals -> (map)
A list of key-value pairs that must match the encryption context in the cryptographic operation request. The grant allows the operation only when the encryption context in the request is the same as the encryption context specified in this constraint.
key -> (string)
value -> (string)
encryptionContextSubset -> (map)
A list of key-value pairs that must be included in the encryption context of the cryptographic operation request. The grant allows the cryptographic operation only when the encryption context in the request includes the key-value pairs specified in this constraint, although it can include additional key-value pairs.
key -> (string)
value -> (string)
issuingAccount -> (string)
The Amazon Web Services account under which the grant was issued. The account is used to propose KMS grants issued by accounts other than the owner of the key.rdsDbClusterSnapshot -> (structure)
The access control configuration is for an Amazon RDS DB cluster snapshot.
attributes -> (map)
The names and values of manual DB cluster snapshot attributes. Manual DB cluster snapshot attributes are used to authorize other Amazon Web Services accounts to restore a manual DB cluster snapshot. The only valid value for
AttributeName
for the attribute map isrestore
key -> (string)
value -> (tagged union structure)
The values for a manual Amazon RDS DB cluster snapshot attribute.
Note
This is a Tagged Union structure. Only one of the following top level keys can be set:accountIds
.accountIds -> (list)
The Amazon Web Services account IDs that have access to the manual Amazon RDS DB cluster snapshot. If the value
all
is specified, then the Amazon RDS DB cluster snapshot is public and can be copied or restored by all Amazon Web Services accounts.
- If the configuration is for an existing Amazon RDS DB cluster snapshot and you do not specify the
accountIds
inRdsDbClusterSnapshotAttributeValue
, then the access preview uses the existing sharedaccountIds
for the snapshot.- If the access preview is for a new resource and you do not specify the specify the
accountIds
inRdsDbClusterSnapshotAttributeValue
, then the access preview considers the snapshot without any attributes.- To propose deletion of existing shared
accountIds
, you can specify an empty list foraccountIds
in theRdsDbClusterSnapshotAttributeValue
.(string)
kmsKeyId -> (string)
The KMS key identifier for an encrypted Amazon RDS DB cluster snapshot. The KMS key identifier is the key ARN, key ID, alias ARN, or alias name for the KMS key.
- If the configuration is for an existing Amazon RDS DB cluster snapshot and you do not specify the
kmsKeyId
, or you specify an empty string, then the access preview uses the existingkmsKeyId
of the snapshot.- If the access preview is for a new resource and you do not specify the specify the
kmsKeyId
, then the access preview considers the snapshot as unencrypted.rdsDbSnapshot -> (structure)
The access control configuration is for an Amazon RDS DB snapshot.
attributes -> (map)
The names and values of manual DB snapshot attributes. Manual DB snapshot attributes are used to authorize other Amazon Web Services accounts to restore a manual DB snapshot. The only valid value for
attributeName
for the attribute map is restore.key -> (string)
value -> (tagged union structure)
The name and values of a manual Amazon RDS DB snapshot attribute. Manual DB snapshot attributes are used to authorize other Amazon Web Services accounts to restore a manual DB snapshot.
Note
This is a Tagged Union structure. Only one of the following top level keys can be set:accountIds
.accountIds -> (list)
The Amazon Web Services account IDs that have access to the manual Amazon RDS DB snapshot. If the value
all
is specified, then the Amazon RDS DB snapshot is public and can be copied or restored by all Amazon Web Services accounts.
- If the configuration is for an existing Amazon RDS DB snapshot and you do not specify the
accountIds
inRdsDbSnapshotAttributeValue
, then the access preview uses the existing sharedaccountIds
for the snapshot.- If the access preview is for a new resource and you do not specify the specify the
accountIds
inRdsDbSnapshotAttributeValue
, then the access preview considers the snapshot without any attributes.- To propose deletion of an existing shared
accountIds
, you can specify an empty list foraccountIds
in theRdsDbSnapshotAttributeValue
.(string)
kmsKeyId -> (string)
The KMS key identifier for an encrypted Amazon RDS DB snapshot. The KMS key identifier is the key ARN, key ID, alias ARN, or alias name for the KMS key.
- If the configuration is for an existing Amazon RDS DB snapshot and you do not specify the
kmsKeyId
, or you specify an empty string, then the access preview uses the existingkmsKeyId
of the snapshot.- If the access preview is for a new resource and you do not specify the specify the
kmsKeyId
, then the access preview considers the snapshot as unencrypted.secretsManagerSecret -> (structure)
The access control configuration is for a Secrets Manager secret.
kmsKeyId -> (string)
The proposed ARN, key ID, or alias of the KMS key.secretPolicy -> (string)
The proposed resource policy defining who can access or manage the secret.s3Bucket -> (structure)
The access control configuration is for an Amazon S3 bucket.
bucketPolicy -> (string)
The proposed bucket policy for the Amazon S3 bucket.bucketAclGrants -> (list)
The proposed list of ACL grants for the Amazon S3 bucket. You can propose up to 100 ACL grants per bucket. If the proposed grant configuration is for an existing bucket, the access preview uses the proposed list of grant configurations in place of the existing grants. Otherwise, the access preview uses the existing grants for the bucket.
(structure)
A proposed access control list grant configuration for an Amazon S3 bucket. For more information, see How to Specify an ACL .
permission -> (string)
The permissions being granted.grantee -> (tagged union structure)
The grantee to whom you’re assigning access rights.
Note
This is a Tagged Union structure. Only one of the following top level keys can be set:id
,uri
.id -> (string)
The value specified is the canonical user ID of an Amazon Web Services account.uri -> (string)
Used for granting permissions to a predefined group.bucketPublicAccessBlock -> (structure)
The proposed block public access configuration for the Amazon S3 bucket.
ignorePublicAcls -> (boolean)
Specifies whether Amazon S3 should ignore public ACLs for this bucket and objects in this bucket.restrictPublicBuckets -> (boolean)
Specifies whether Amazon S3 should restrict public bucket policies for this bucket.accessPoints -> (map)
The configuration of Amazon S3 access points or multi-region access points for the bucket. You can propose up to 10 new access points per bucket.
key -> (string)
value -> (structure)
The configuration for an Amazon S3 access point or multi-region access point for the bucket. You can propose up to 10 access points or multi-region access points per bucket. If the proposed Amazon S3 access point configuration is for an existing bucket, the access preview uses the proposed access point configuration in place of the existing access points. To propose an access point without a policy, you can provide an empty string as the access point policy. For more information, see Creating access points . For more information about access point policy limits, see Access points restrictions and limitations .
accessPointPolicy -> (string)
The access point or multi-region access point policy.publicAccessBlock -> (structure)
The proposed
S3PublicAccessBlock
configuration to apply to this Amazon S3 access point or multi-region access point.ignorePublicAcls -> (boolean)
Specifies whether Amazon S3 should ignore public ACLs for this bucket and objects in this bucket.restrictPublicBuckets -> (boolean)
Specifies whether Amazon S3 should restrict public bucket policies for this bucket.networkOrigin -> (tagged union structure)
The proposed
Internet
andVpcConfiguration
to apply to this Amazon S3 access point.VpcConfiguration
does not apply to multi-region access points. If the access preview is for a new resource and neither is specified, the access preview usesInternet
for the network origin. If the access preview is for an existing resource and neither is specified, the access preview uses the exiting network origin.Note
This is a Tagged Union structure. Only one of the following top level keys can be set:vpcConfiguration
,internetConfiguration
.vpcConfiguration -> (structure)
The proposed virtual private cloud (VPC) configuration for the Amazon S3 access point. VPC configuration does not apply to multi-region access points. For more information, see VpcConfiguration .
vpcId -> (string)
If this field is specified, this access point will only allow connections from the specified VPC ID.internetConfiguration -> (structure)
The configuration for the Amazon S3 access point or multi-region access point with anInternet
origin.snsTopic -> (structure)
The access control configuration is for an Amazon SNS topic
topicPolicy -> (string)
The JSON policy text that defines who can access an Amazon SNS topic. For more information, see Example cases for Amazon SNS access control in the Amazon SNS Developer Guide .sqsQueue -> (structure)
The access control configuration is for an Amazon SQS queue.
queuePolicy -> (string)
The proposed resource policy for the Amazon SQS queue.s3ExpressDirectoryBucket -> (structure)
The access control configuration is for an Amazon S3 directory bucket.
bucketPolicy -> (string)
The proposed bucket policy for the Amazon S3 directory bucket.dynamodbStream -> (structure)
The access control configuration is for a DynamoDB stream.
streamPolicy -> (string)
The proposed resource policy defining who can access or manage the DynamoDB stream.dynamodbTable -> (structure)
The access control configuration is for a DynamoDB table or index.
tablePolicy -> (string)
The proposed resource policy defining who can access or manage the DynamoDB table.
JSON Syntax:
{"string": {
"ebsSnapshot": {
"userIds": ["string", ...],
"groups": ["string", ...],
"kmsKeyId": "string"
},
"ecrRepository": {
"repositoryPolicy": "string"
},
"iamRole": {
"trustPolicy": "string"
},
"efsFileSystem": {
"fileSystemPolicy": "string"
},
"kmsKey": {
"keyPolicies": {"string": "string"
...},
"grants": [
{
"operations": ["CreateGrant"|"Decrypt"|"DescribeKey"|"Encrypt"|"GenerateDataKey"|"GenerateDataKeyPair"|"GenerateDataKeyPairWithoutPlaintext"|"GenerateDataKeyWithoutPlaintext"|"GetPublicKey"|"ReEncryptFrom"|"ReEncryptTo"|"RetireGrant"|"Sign"|"Verify", ...],
"granteePrincipal": "string",
"retiringPrincipal": "string",
"constraints": {
"encryptionContextEquals": {"string": "string"
...},
"encryptionContextSubset": {"string": "string"
...}
},
"issuingAccount": "string"
}
...
]
},
"rdsDbClusterSnapshot": {
"attributes": {"string": {
"accountIds": ["string", ...]
}
...},
"kmsKeyId": "string"
},
"rdsDbSnapshot": {
"attributes": {"string": {
"accountIds": ["string", ...]
}
...},
"kmsKeyId": "string"
},
"secretsManagerSecret": {
"kmsKeyId": "string",
"secretPolicy": "string"
},
"s3Bucket": {
"bucketPolicy": "string",
"bucketAclGrants": [
{
"permission": "READ"|"WRITE"|"READ_ACP"|"WRITE_ACP"|"FULL_CONTROL",
"grantee": {
"id": "string",
"uri": "string"
}
}
...
],
"bucketPublicAccessBlock": {
"ignorePublicAcls": true|false,
"restrictPublicBuckets": true|false
},
"accessPoints": {"string": {
"accessPointPolicy": "string",
"publicAccessBlock": {
"ignorePublicAcls": true|false,
"restrictPublicBuckets": true|false
},
"networkOrigin": {
"vpcConfiguration": {
"vpcId": "string"
},
"internetConfiguration": {
}
}
}
...}
},
"snsTopic": {
"topicPolicy": "string"
},
"sqsQueue": {
"queuePolicy": "string"
},
"s3ExpressDirectoryBucket": {
"bucketPolicy": "string"
},
"dynamodbStream": {
"streamPolicy": "string"
},
"dynamodbTable": {
"tablePolicy": "string"
}
}
...}
--client-token
(string)
A client token.
--cli-input-json
(string)
Performs service operation based on the JSON string provided. The JSON string follows the format provided by --generate-cli-skeleton
. If other arguments are provided on the command line, the CLI values will override the JSON-provided values. It is not possible to pass arbitrary binary values using a JSON-provided value as the string will be taken literally.
--generate-cli-skeleton
(string)
Prints a JSON skeleton to standard output without sending an API request. If provided with no value or the value input
, prints a sample input JSON that can be used as an argument for --cli-input-json
. If provided with the value output
, it validates the command inputs and returns a sample output JSON for that command.
--debug
(boolean)
Turn on debug logging.
--endpoint-url
(string)
Override command's default URL with the given URL.
--no-verify-ssl
(boolean)
By default, the AWS CLI uses SSL when communicating with AWS services. For each SSL connection, the AWS CLI will verify SSL certificates. This option overrides the default behavior of verifying SSL certificates.
--no-paginate
(boolean)
Disable automatic pagination. If automatic pagination is disabled, the AWS CLI will only make one call, for the first page of results.
--output
(string)
The formatting style for command output.
--query
(string)
A JMESPath query to use in filtering the response data.
--profile
(string)
Use a specific profile from your credential file.
--region
(string)
The region to use. Overrides config/env settings.
--version
(string)
Display the version of this tool.
--color
(string)
Turn on/off color output.
--no-sign-request
(boolean)
Do not sign requests. Credentials will not be loaded if this argument is provided.
--ca-bundle
(string)
The CA certificate bundle to use when verifying SSL certificates. Overrides config/env settings.
--cli-read-timeout
(int)
The maximum socket read time in seconds. If the value is set to 0, the socket read will be blocking and not timeout. The default value is 60 seconds.
--cli-connect-timeout
(int)
The maximum socket connect time in seconds. If the value is set to 0, the socket connect will be blocking and not timeout. The default value is 60 seconds.
To use the following examples, you must have the AWS CLI installed and configured. See the Getting started guide in the AWS CLI User Guide for more information.
Unless otherwise stated, all examples have unix-like quotation rules. These examples will need to be adapted to your terminal's quoting rules. See Using quotation marks with strings in the AWS CLI User Guide .
To create an access preview that allows you to preview IAM Access Analyzer findings for your resource before deploying resource permissions
The following create-access-preview
example creates an access preview that allows you to preview IAM Access Analyzer findings for your resource before deploying resource permissions in your AWS account.
aws accessanalyzer create-access-preview \
--analyzer-arn arn:aws:access-analyzer:us-west-2:111122223333:analyzer/ConsoleAnalyzer-account \
--configurations file://myfile.json
Contents of myfile.json
:
{
"arn:aws:s3:::amzn-s3-demo-bucket": {
"s3Bucket": {
"bucketPolicy": "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Effect\":\"Allow\",\"Principal\":{\"AWS\":[\"arn:aws:iam::111122223333:root\"]},\"Action\":[\"s3:PutObject\",\"s3:PutObjectAcl\"],\"Resource\":\"arn:aws:s3:::amzn-s3-demo-bucket/*\"}]}",
"bucketPublicAccessBlock": {
"ignorePublicAcls": true,
"restrictPublicBuckets": true
},
"bucketAclGrants": [
{
"grantee": {
"id": "79a59df900b949e55d96a1e698fbacedfd6e09d98eacf8f8d5218e7cd47ef2be"
},
"permission": "READ"
}
]
}
}
}
Output:
{
"id": "3c65eb13-6ef9-4629-8919-a32043619e6b"
}
For more information, see Previewing access with IAM Access Analyzer APIs in the AWS IAM User Guide.