Cloudformation: connect lambda to an exisitng SNS topic ?

0

Hello,

With cloudformation, is it possible to connecting a lambda to an existing SNS topic ?

I've tried with "AWS::Events::Rule" with this code (yaml)

      LambdaInvokeEventRule:
        Type: AWS::Events::Rule
        Properties:
          Name: "MyLambda"
          RoleArn: !GetAtt MyLambdaRole.Arn
          EventPattern: 
            source: 
              - "aws.sns"
            resources:
              - "arn:aws:sns:eu-west-1:643462973525:mytopic"
          Targets:
              - Arn: !GetAtt MyLambda.Arn
                Id: "MyLambda"

But the validation fails with this message "Invalid template resource property" for this block

Thanks !!

已提問 5 年前檢視次數 2215 次
2 個答案
0

Hi,
Just to clarify. When the sns Topic gets a message, you want it to invoke a Lambda function to process the message that was sent to the SNS topic. If yes, then you want to create your Cloudformation template to look something like the following:

 
Parameters:
  MyLambdaArn:
    Type: String
    Default: arn:aws:lambda:us-east-1:XXXXXXXXXX:function:MyLambda
    Description: Enter the Lambda ARN
    
Resources:
  lambdaTopic:
    Type: AWS::SNS::Topic
    Properties:
      DisplayName: Topic that invokes the Lambda function
      Subscription:
        - Endpoint: !Ref MyLambdaArn
          Protocol: lambda

  lambdaPermission:
    Type: AWS::Lambda::Permission
    Properties:
      Action: lambda:InvokeFunction
      FunctionName: !Ref MyLambdaArn
      Principal: sns.amazonaws.com
      SourceArn: arn:aws:sns:eu-west-1:643462973525:mytopic

Hope that helps.
-randy

Edited by: rtakeshi on Aug 7, 2019 10:05 AM

已回答 5 年前
0

OK, I had use this solution first.

The SNS topic has created by an other teams but it make sens that the Lambda creation section must be present in their cloudformation file.

Very thanks !

已回答 5 年前

您尚未登入。 登入 去張貼答案。

一個好的回答可以清楚地回答問題並提供建設性的意見回饋,同時有助於提問者的專業成長。

回答問題指南