17

Questo è il codice Cloudformation modello legato al mio problema:Impossibile creare una fonte SNS evento su una funzione lambda utilizza CloudFormation

"SNSTopic": { 
    "Type": "AWS::SNS::Topic", 
    "Properties": { 
    "TopicName": "JumpboxPresenceTopic", 
    "DisplayName": "Jumpbox Presence Topic", 
    "Subscription": [ 
     { 
     "Endpoint": { 
      "Fn::GetAtt": [ 
      "Lambda", 
      "Arn" 
      ] 
     }, 
     "Protocol": "lambda" 
     } 
    ] 
    } 
}, 
"Lambda": { 
    "Type": "AWS::Lambda::Function", 
    "Properties": [...] 

posso vedere l'argomento nella SNS cruscotto: enter image description here

Ma non viene visualizzato nella funzione lambda Origini evento pannello: enter image description here

La cosa strana è che se creo un nuovo abbonamento dal dashboard SNS per la stessa funzione lambda, non viene creato alcun nuovo abbonamento poiché sarebbe un duplicato esatto. Tuttavia, ora se controllo il origini evento pannello nel cruscotto Lambda, posso vedere una nuova voce per il SNS: JumpboxPresenceTopic: enter image description here

Mi sento come se fosse una questione da parte di Amazon, ma potrei sbagliarmi. C'è qualcosa di sbagliato nel mio approccio o è una limitazione di AWS?

risposta

13

È necessario concedere l'autorizzazione SNS per richiamare Lambda per prima. Ecco un esempio di AWS. Si prega di cambiarlo da S3 a SNS e non dimenticare di impostare SourceArn come ARN dell'argomento SNS.

http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html

+1

sto sperimentando un problema simile, e mentre questa risposta si fa aiutare a ottenere la configurazione delle autorizzazioni di origine in lambda, la notifica di sns non la sta invocando, altre idee perché? – Onema

+5

@Onema Ho avuto un problema simile, il supporto AWS mi ha detto di rimuovere il "SourceAccount" e di aggiungere "SourceArn" puntato all'argomento SNS nella risorsa Permission, speriamo che aiuti! – deviavir

+0

@deviavir, sì! questo ha risolto anche il mio problema. Ho finito per utilizzare solo "SourceArn". – Onema

0

Aggiungendo il nome della funzione corretta e sourcearn in permessi aiutarono risolvere il problema

"MySNSTopic": { 
      "Type": "AWS::SNS::Topic", 
      "Properties": { 
       "TopicName": "MyTopic", 
       "DisplayName": "My Test Topic", 
       "Subscription": [ 
       { 
        "Endpoint": { "Fn::GetAtt" : ["Lambda", "Arn"] }, 
        "Protocol": "lambda" 
       } 
       ] 
      } 
    }, 
    "PermissionForEventsToInvokeLambda": { 
      "Type": "AWS::Lambda::Permission", 
      "Properties": { 
      "FunctionName": { "Fn::GetAtt" : ["Lambda", "Arn"] }, 
      "Action": "lambda:InvokeFunction", 
      "Principal": "sns.amazonaws.com", 
      "SourceArn": { "Ref": "MySNSTopic" } 
      } 
     } 
    },