Referências de funções intrínsecas em DeletionPolicy e atributos de UpdateReplacePolicy - AWS CloudFormation

Referências de funções intrínsecas em DeletionPolicy e atributos de UpdateReplacePolicy

Quando você adiciona a transformação AWS::LanguageExtensions em um modelo AWS CloudFormation, pode usar funções intrínsecas para definir os atributos de recursos Atributo DeletionPolicy e Atributo UpdateReplacePolicy.

nota

A função intrínseca deve ser resolvida como Opções de DeletionPolicy ou Opções de UpdateReplacePolicy válidas.

Declaração

JSON

{ "DeletionPolicy": IntrinsicFunction }
{ "UpdateReplacePolicy": IntrinsicFunction }

YAML

DeletionPolicy: IntrinsicFunction
UpdateReplacePolicy: IntrinsicFunction

Parâmetros

IntrinsicFunction

A função intrínseca que é resolvida como uma opção válida Atributo DeletionPolicy ou Atributo UpdateReplacePolicy.

Exemplos

Defina DeletionPolicy e UpdateReplacePolicy usando a função intrínseca Fn:If

O exemplo a seguir define os atributos Atributo DeletionPolicy e Atributo UpdateReplacePolicy com base na condição definida na função intrínseca Fn::If. Se o parâmetro Stage for Prod, os atributos DeletionPolicy e UpdateReplacePolicy serão definidos como Retain.

JSON

{ "AWSTemplateFormatVersion": "2010-09-09", "Transform": "AWS::LanguageExtensions", "Parameters": { "Stage": { "Type": "String", "AllowedValues": [ "Prod", "Staging", "Dev" ] } }, "Conditions": { "IsProd": { "Fn::Equals": [ { "Ref": "Stage" }, "Prod" ] } }, "Resources": { "Table": { "Type": "AWS::DynamoDB::Table", "Properties": { "KeySchema": [{ "AttributeName": "primaryKey", "KeyType": "HASH" }], "AttributeDefinitions": [{ "AttributeName": "primaryKey", "AttributeType": "S" }] }, "DeletionPolicy": { "Fn::If": [ "IsProd", "Retain", "Delete" ] }, "UpdateReplacePolicy": { "Fn::If": [ "IsProd", "Retain", "Delete" ] } } } }

YAML

AWSTemplateFormatVersion: 2010-09-09 Transform: 'AWS::LanguageExtensions' Parameters: Stage: Type: String AllowedValues: - Prod - Staging - Dev Conditions: IsProd: !Equals - !Ref Stage - Prod Resources: Table: Type: 'AWS::DynamoDB::Table' Properties: KeySchema: - AttributeName: primaryKey KeyType: HASH AttributeDefinitions: - AttributeName: primaryKey AttributeType: S DeletionPolicy: !If - IsProd - Retain - Delete UpdateReplacePolicy: !If - IsProd - Retain - Delete

Defina os atributos DeletionPolicy e UpdateReplacePolicy usando a função intrínseca Ref

O exemplo a seguir define os atributos Atributo DeletionPolicy e Atributo UpdateReplacePolicy com base no valor resolvido pela função intrínseca Ref. Se os parâmetros DeletionPolicyParam e UpdateReplacePolicyParam forem ambos definidos como Retain, os atributos DeletionPolicy e UpdateReplacePolicy também serão definidos como Retain.

JSON

{ "AWSTemplateFormatVersion": "2010-09-09", "Transform": "AWS::LanguageExtensions", "Parameters": { "DeletionPolicyParam": { "Type": "String", "AllowedValues": [ "Delete", "Retain", "Snapshot" ], "Default": "Delete" }, "UpdateReplacePolicyParam": { "Type": "String", "AllowedValues": [ "Delete", "Retain", "Snapshot" ], "Default": "Delete" } }, "Resources": { "Table": { "Type": "AWS::DynamoDB::Table", "Properties": { "KeySchema": [ { "AttributeName": "primaryKey", "KeyType": "HASH" }], "AttributeDefinitions": [{ "AttributeName": "primaryKey", "AttributeType": "S" }] }, "DeletionPolicy": { "Ref": "DeletionPolicyParam" }, "UpdateReplacePolicy": { "Ref": "UpdateReplacePolicyParam" } } } }

YAML

AWSTemplateFormatVersion: 2010-09-09 Transform: 'AWS::LanguageExtensions' Parameters: DeletionPolicyParam: Type: String AllowedValues: - Delete - Retain - Snapshot Default: Delete UpdateReplacePolicyParam: Type: String AllowedValues: - Delete - Retain - Snapshot Default: Delete Resources: Table: Type: 'AWS::DynamoDB::Table' Properties: KeySchema: - AttributeName: primaryKey KeyType: HASH AttributeDefinitions: - AttributeName: primaryKey AttributeType: S DeletionPolicy: !Ref DeletionPolicyParam UpdateReplacePolicy: !Ref UpdateReplacePolicyParam

Funções compatíveis

Nos atributos DeletionPolicy ou UpdateReplacePolicy, você pode usar as seguintes funções:

Você também pode usar os seguintes pseudoparâmetros:

  • AWS::AccountId

  • AWS::Partition

  • AWS::Region