DeletionPolicy と UpdateReplacePolicy 属性の組み込み関数リファレンス - AWS CloudFormation

DeletionPolicyUpdateReplacePolicy 属性の組み込み関数リファレンス

AWS::LanguageExtensions 変換を AWS CloudFormation テンプレートに追加する場合、組み込み関数を使用して DeletionPolicy 属性UpdateReplacePolicy 属性 リソース属性を定義できます。

注記

組み込み関数は、有効な DeletionPolicy オプション または UpdateReplacePolicy オプション と解釈されなければなりません。

宣言

JSON

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

YAML

DeletionPolicy: IntrinsicFunction
UpdateReplacePolicy: IntrinsicFunction

パラメータ

IntrinsicFunction

有効なDeletionPolicy 属性またはUpdateReplacePolicy 属性オプションに解決される組み込み関数。

Fn:If 組み込み関数を使用して DeletionPolicyUpdateReplacePolicy を定義します。

次の例では、Fn::If 組み込み関数で定義された条件に基づいて、DeletionPolicy 属性 属性と UpdateReplacePolicy 属性 属性を設定します。Stage パラメータが Prod の場合、DeletionPolicyUpdateReplacePolicy の属性は 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

Ref 組み込み関数を使用して DeletionPolicyUpdateReplacePolicy 属性を定義します。

次の例では、Ref 組み込み関数よって解決された値に基づいて、DeletionPolicy 属性 属性と UpdateReplacePolicy 属性 属性を設定します。DeletionPolicyParamUpdateReplacePolicyParam のパラメータが両方とも Retain に設定されている場合、DeletionPolicyUpdateReplacePolicy の属性も 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

サポートされている関数

DeletionPolicy または UpdateReplacePolicy 属性の中では、次の関数を使用できます。

また、次の Pseudo パラメータを使用することもできます。

  • AWS::AccountId

  • AWS::Partition

  • AWS::Region