CloudFormationでEventBridge -> Lambra -> SNS のリソースを作成するべく
ymlでテンプレートファイルを書きました
yml
1AWSTemplateFormatVersion: 2010-09-09 2 3Parameters: 4 5 BucketName: 6 Type: String 7 SourceCodeFile: 8 Type: String 9 ResourceName: 10 Type: String 11 12Resources: 13 LambdaFunction: 14 Type: AWS::Lambda::Function 15 Properties: 16 Handler: lambda_function.lambda_handler 17 Code: 18 S3Bucket: !Ref BucketName 19 S3Key: !Ref SourceCodeFile 20 FunctionName: !Sub ${ResourceName}-function 21 Runtime: python3.9 22 Environment: 23 Variables: 24 TopicArn : !Sub arn:aws:sns:${AWS::Region}:${AWS::AccountId}:${ResourceName}-sns 25 Role: !GetAtt 26 - LambdaExecutionRole 27 - Arn 28 29 LambdaExecutionRole: 30 Type: AWS::IAM::Role 31 Properties: 32 RoleName: !Sub ${ResourceName}-function-execution-role 33 AssumeRolePolicyDocument: 34 Version: 2012-10-17 35 Statement: 36 - Effect: Allow 37 Principal: 38 Service: 39 - lambda.amazonaws.com 40 Action: sts:AssumeRole 41 Policies: 42 - PolicyName: !Sub ${ResourceName}-function-policy 43 PolicyDocument: 44 Version: 2012-10-17 45 Statement: 46 - Resource: !Sub arn:aws:logs:${AWS::Region}:${AWS::AccountId}:log-group:/aws/lambda/${ResourceName}-function:* 47 Effect: Allow 48 Action: 49 - logs:CreateLogGroup 50 - logs:CreateLogStream 51 - logs:PutLogEvents 52 - logs:CreateExportTask 53 - s3:GetBucketAcl 54 - s3:PutObject 55 - PolicyName: !Sub ${ResourceName}-function-nsn-policy 56 PolicyDocument: 57 Version: 2012-10-17 58 Statement: 59 - Resource: !Sub arn:aws:sns:${AWS::Region}:${AWS::AccountId}:${ResourceName}-sns 60 Effect: Allow 61 Action: 62 - sns:Publish 63 64 SnsTopic: 65 Type: AWS::SNS::Topic 66 Properties: 67 DisplayName: !Sub ${ResourceName}-sns 68 FifoTopic: false 69 TopicName: !Sub ${ResourceName}-sns 70 71 EventBridgeRule: 72 Type: AWS::Events::Rule 73 Properties: 74 EventBusName: default 75 # EventPattern: Json 76 Name: !Sub ${ResourceName}-eventbridge-rule 77 RoleArn: String 78 ScheduleExpression: rate(5 minutes) 79 State: ENABLED 80 Targets: 81 - Arn: !GetAtt 82 - LambdaFunction 83 - Arn 84 - Id: TargetFunction1
実行してみたところ、Lambda、SNSは作成できたのですが、EventBridgeでエラーが出てしまいました
Property Id cannot be empty.
「Idは空にしちゃダメだよー」というエラーだと思いますが、Idにはちゃんと値を入れています
Targets: - Arn: !GetAtt - LambdaFunction - Arn - Id: TargetFunction1
どなたか修正方法をご教示いただけないでしょうか?
よろしくお願い致します。
TargetFunction1が宣言されてませんが
すみません、ymlを書くのが初めてなので恐縮なのですが、
TargetFunction1は変数のつもりではなく、文字列としてそのままEventBridgeに登録するものと思っていました。
宣言文を書くべきなのでしょうか?
ENABLEという形式ではなく、function.xxx.idという形になるかと思います。
https://docs.aws.amazon.com/ja_jp/AWSCloudFormation/latest/UserGuide/aws-properties-events-rule-target.html
これなんですが、もう一歩わかりませんね。サポートに聞くレベルだと思います。
回答1件
あなたの回答
tips
プレビュー