每当使用无服务器在s3存储桶上传文件时,都会收到电子邮件

时间:2017-10-10 15:03:31

标签: python-2.7 amazon-web-services amazon-s3 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

这是我的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

1 个答案:

答案 0 :(得分:2)

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

1)使用SNS控制台创建Topic

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"
        }
      }
    }
  ]
}

基本上,您授权 s3-bucket 发布到SNS主题。

sns-topic-arn 替换为您在上面创建的主题的ARN。 使用您要为其接收通知的存储桶名称重新显示 s3-bucket-name

5)转到S3控制台。单击您的S3存储桶并打开属性选项卡。

6)在 高级设置 下,点击 活动 卡。

7)点击添加通知并输入值。示例如下所示。

enter image description here

选择要监控的所需s3事件和您创建的SNS主题。

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