Quiero utilizar la función intrínseca Fn::Sub en AWS CloudFormation con Fn::FindInMap, Fn::ImportValue u otras funciones compatibles.
Descripción breve
Puede utilizar la función intrínseca Fn::Sub para sustituir funciones compatibles o para sustituir variables de una cadena de entrada por los valores que especifique.
Para sustituir el valor de las funciones compatibles, debe utilizar el mapa de variables con el nombre y el valor como se muestra a continuación:
JSON:
{ "Fn::Sub" : [ String, { Var1Name: Var1Value, Var2Name: Var2Value } ] }
YAML:
!Sub
- String
- Var1Name: Var1Value
Var2Name: Var2Value
Solución
Uso de Fn::Sub con la función Ref
El siguiente ejemplo utiliza un mapeo para sustituir la variable Domain por el valor resultante de la función Ref.
JSON:
{
"Parameters": {
"RootDomainName": {
"Type": "String",
"Default": "example123.com"
}
},
"Resources": {
"DNS": {
"Type": "AWS::Route53::HostedZone",
"Properties": {
"Name": {
"Fn::Sub": [
"www.${Domain}",
{
"Domain": {
"Ref": "RootDomainName"
}
}
]
}
}
}
}
}
YAML:
Parameters:
RootDomainName:
Type: String
Default: example123.com
Resources:
DNS:
Type: 'AWS::Route53::HostedZone'
Properties:
Name: !Sub
- 'www.${Domain}'
- Domain: !Ref RootDomainName
Uso de Fn::Sub con la función Fn::FindInMap
El siguiente ejemplo utiliza un mapeo para sustituir la variable log_group_name por el valor resultante de la función Fn::FindInMap.
JSON:
{
"Mappings": {
"LogGroupMapping": {
"Test": {
"Name": "test_log_group"
},
"Prod": {
"Name": "prod_log_group"
}
}
},
"Resources": {
"myLogGroup": {
"Type": "AWS::Logs::LogGroup",
"Properties": {
"LogGroupName": {
"Fn::Sub": [
"cloud_watch_${log_group_name}",
{
"log_group_name": {
"Fn::FindInMap": [
"LogGroupMapping",
"Test",
"Name"
]
}
}
]
}
}
}
}
}
YAML:
Mappings:
LogGroupMapping:
Test:
Name: test_log_group
Prod:
Name: prod_log_group
Resources:
myLogGroup:
Type: 'AWS::Logs::LogGroup'
Properties:
LogGroupName: !Sub
- 'cloud_watch_${log_group_name}'
- log_group_name: !FindInMap
- LogGroupMapping
- Test
- Name
Uso de Fn::Sub con la función Fn::ImportValue
El siguiente ejemplo utiliza un mapeo para sustituir la variable Domain por el valor resultante de la función Fn::ImportValue.
Nota: «DomainName» es el nombre del resultado exportado por otra pila de CloudFormation.
JSON:
{
"Resources": {
"DNS": {
"Type": "AWS::Route53::HostedZone",
"Properties": {
"Name": {
"Fn::Sub": [
"www.${Domain}",
{
"Domain": {
"Fn::ImportValue": "DomainName"
}
}
]
}
}
}
}
}
YAML:
Resources:
DNS:
Type: 'AWS::Route53::HostedZone'
Properties:
Name: !Sub
- 'www.${Domain}'
- Domain: !ImportValue DomainName