每当使用无服务器将文件上传到s3存储桶时,都将获取电子邮件

ner*_*ner 0 amazon-s3 amazon-web-services python-2.7 amazon-ses serverless

我想按上面的标题中所述将文件上传到s3存储桶时,我想接收电子邮件,我使用的是无服务器,问题是我在s3上创建的事件仅在s3-aws控制台上通知我,并且不不知道如何在S3上配置cloudwatch事件以触发lambda。因此,如果有人知道如何使用cloudwatch触发S3上的事件,我将不知所措。这是我的代码:

import json
import boto3
import botocore
import logging
import sys
import os
import traceback


from botocore.exceptions import ClientError
from pprint import pprint
from time import strftime, gmtime

email_from = '*****@******.com'
email_to = '******@******.com'
#email_cc = '********@gmail.com'
email_subject = 'new event on s3 '
email_body = 'a new file is uploaded'


#setup simple logging for INFO
logger = logging.getLogger()
logger.setLevel(logging.INFO)

from botocore.exceptions import ClientError

def sthree(event, context):
 """Send email whenever a file is uploaded to S3"""
body = {}
status_code = 200


try:
    s3 = boto3.client('s3')
    ses = boto3.client('ses')
    response = ses.send_email(Source = email_from,
                    Destination = {'ToAddresses': [email_to,],}, 
                        Message = {'Subject': {'Data': email_subject}, 'Body':{'Text' : {'Data': email_body}}}
         )

response = {
    "statusCode": 200,
    "body": json.dumps(body)
}

return response
Run Code Online (Sandbox Code Playgroud)

这是我的serverless.yml文件

service: aws-python # NOTE: update this with your service name

plugins:
  - serverless-external-s3-event

provider:   name: aws   
runtime: python2.7 
stage: dev  
region: us-east-1   
iamRoleStatements:
        - Effect: "Allow"
          Action:
              - s3:*
              - "ses:SendEmail"
              - "ses:SendRawEmail"
              - "s3:PutBucketNotification"
          Resource: "*"

 functions:   sthree:
    handler: handler.sthree
    description: send mail whenever a file is uploaded on S3 
    events:
       - s3:
          bucket: cartegie-nirmine
          event: s3:ObjectCreated:*
          rules:
            - prefix: uploads/
            - suffix: .jpg
      - cloudwatchEvent:
              description: 'CloudWatch Event triggered '
              event:
                  source:
                      - "aws.S3"
                  detail-type:
                      - "S3 event Notification"
              enabled : true
Run Code Online (Sandbox Code Playgroud)

Mad*_*aju 5

如果您的座右铭只是接收有关S3存储桶上操作的电子邮件通知,那么您不需要lambda函数。对于问题中提到的用例,可以使用SNS主题和S3事件来实现。我将提到从控制台执行的步骤(通过sdk或cli可以实现相同的步骤)。

1)Topic使用SNS控制台创建一个。

2)订阅主题。使用email的通信协议,并提供您的电子邮件ID

3)您会收到一封电子邮件,要求您确认您对该主题的订阅。确认订阅。

4)重要:用以下策略替换主题的访问策略:

{
  "Version": "2008-10-17",
  "Id": "__default_policy_ID",
  "Statement": [
    {
      "Sid": "__default_statement_ID",
      "Effect": "Allow",
      "Principal": {
        "AWS": "*"
      },
      "Action": "SNS:Publish",
      "Resource": "sns-topic-arn",
      "Condition": {
        "ArnLike": {
          "aws:SourceArn": "arn:aws:s3:*:*:s3-bucket-name"
        }
      }
    }
  ]
}
Run Code Online (Sandbox Code Playgroud)

基本上,您是允许s3-bucket发布到SNS主题。

用上面创建的主题的ARN 替换sns-topic-arn。将s3-bucket-name替换为要接收通知的存储桶名称。

5)转到S3控制台。单击您的S3存储桶,然后打开“ 属性”标签。

6)在高级设置下,单击事件卡。

7)单击添加通知,然后输入值。示例如下所示。

在此处输入图片说明

选择要监视的必需的s3事件和创建的SNS主题。

8)点击保存。现在,您应该开始接收电子邮件通知。