class Arn
Language | Type name |
---|---|
.NET | Amazon.CDK.Arn |
Go | github.com/aws/aws-cdk-go/awscdk/v2#Arn |
Java | software.amazon.awscdk.Arn |
Python | aws_cdk.Arn |
TypeScript (source) | aws-cdk-lib » Arn |
Methods
Name | Description |
---|---|
static extract | Extract the full resource name from an ARN. |
static format(components, stack?) | Creates an ARN from components. |
static split(arn, arnFormat) | Splits the provided ARN into its components. |
ResourceName(arn, resourceType)
static extractpublic static extractResourceName(arn: string, resourceType: string): string
Parameters
- arn
string
- resourceType
string
Returns
string
Extract the full resource name from an ARN.
Necessary for resource names (paths) that may contain the separator, like
arn:aws:iam::111111111111:role/path/to/role/name
.
Only works if we statically know the expected resourceType
beforehand, since we're going
to use that to split the string on ':
We can't extract the 'resourceType' from the ARN at hand, because CloudFormation Expressions
only allow literals in the 'separator' argument to { Fn::Split }
, and so it can't be
{ Fn::Select: [5, { Fn::Split: [':', ARN] }}
.
Only necessary for ARN formats for which the type-name separator is /
.
static format(components, stack?)
public static format(components: ArnComponents, stack?: Stack): string
Parameters
- components
Arn
Components - stack
Stack
Returns
string
Creates an ARN from components.
If partition
, region
or account
are not specified, the stack's
partition, region and account will be used.
If any component is the empty string, an empty string will be inserted into the generated ARN at the location that component corresponds to.
The ARN will be formatted as follows:
arn:{partition}:{service}:{region}:{account}:{resource}{sep}{resource-name}
The required ARN pieces that are omitted will be taken from the stack that the 'scope' is attached to. If all ARN pieces are supplied, the supplied scope can be 'undefined'.
static split(arn, arnFormat)
public static split(arn: string, arnFormat: ArnFormat): ArnComponents
Parameters
- arn
string
— the ARN to split into its components. - arnFormat
Arn
— the expected format of 'arn' - depends on what format the service 'arn' represents uses.Format
Returns
Splits the provided ARN into its components.
Works both if 'arn' is a string like 'arn:aws:s3:::bucket', and a Token representing a dynamic CloudFormation expression (in which case the returned components will also be dynamic CloudFormation expressions, encoded as Tokens).