0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

テンプレートを使用してSES でメールを送信してみた

Last updated at Posted at 2025-02-24

背景・目的

以前、LambdaからSESでメールを送信しました。今回はメールテンプレートを使用して送信してみます。

まとめ

下記に特徴をまとめます。

特徴 説明
SESのテンプレート 下記の2つがある
・保存済みテンプレート
・インラインテンプレート
ストアドテンプレート SES v2 APIのCreateEmailTemplateオペレーションを使用してSESで作成されたTemplateリソース
テンプレートには、書き込まれたコンテンツとインラインで変数を含むメールの件名と本文が含まれる
インラインテンプレート Templateリソースは使用しない
変数を使用して、APIを呼び出すときにインラインで提供される
ストアドテンプレートの制限事項 リージョンあたり、最大20,000このテンプレートが作成可能
500KBサイズまで
インラインテンプレートの制限事項 JSON ファイルは、テキスト部分と HTML 部分の両方を含めて、最大 1 MBまで

概要

下記を基に整理します。

Amazon SES では、保存されたテンプレートを使用するか、インラインテンプレートを使用して、テンプレート化された E メールを送信できます。

  • 保存済みテンプレート – Amazon SES v2 API の CreateEmailTemplateオペレーションを使用して SES で作成および保存されるTemplateリソースを指します。 Amazon SES テンプレートには、書き込まれたコンテンツとインラインで変数 (プレースホルダー) を含む E メールの件名と本文が含まれています。ストアドテンプレートの名前とテンプレート内のプレースホルダー変数への動的データは、 SendEmailまたは v2 API SendBulkEmail オペレーションを呼び出すときに提供されます。
    保存されたテンプレートは簡単に再利用でき、同様の種類の E メールを送信する際の時間と労力を節約できます。各 E メールをゼロから作成する代わりに、基本構造と設計を一度作成するだけで、テンプレート内の動的コンテンツを更新できます。
  • インラインテンプレート – Templateリソースは使用されませんが、変数 (プレースホルダー) を含む E メールの件名と本文は、これらのプレースホルダー変数の値とともに、 SendEmailまたは v2 API SendBulkEmail オペレーションを呼び出すときにインラインで提供されます。
    インラインテンプレートは、SES アカウントでテンプレートリソースを管理する必要がなくなり、アプリケーションロジック内にテンプレートコンテンツを直接含めることができるため、統合プロセスを簡素化することで、一括 E メールを送信するプロセスを合理化します。あたりの 20,000 テンプレートの制限にはカウントされません AWS リージョン。
  • SESでは、下記のテンプレートを使用してテンプレート化されたメールを送信できる

    • 保存済みテンプレート
    • インラインテンプレート
  • 保存済みテンプレート

    • SES v2 APIのCreateEmailTemplateオペレーションを使用してSESで作成されたTemplateリソース
    • テンプレートには、書き込まれたコンテンツとインラインで変数を含むメールの件名と本文が含まれる
  • インラインテンプレート

    • Templateリソースは使用しない
    • 変数を使用して、APIを呼び出すときにインラインで提供される

ストアドテンプレートを使用する場合、次の制限が適用されます。

  • それぞれに最大 20,000 個の E メールテンプレートを作成できます AWS リージョン。
  • 各テンプレートは、テキストと HTML パートの両方を含めて、最大 500 KB のサイズまで可能です。
  • ストアドテンプレートの制限事項
    • リージョンあたり、最大20,000このテンプレートが作成可能
    • 500KBサイズまで

インラインテンプレートを使用する場合、次の制限が適用されます。

  • 各入力 JSON ファイルは、テキスト部分と HTML 部分の両方を含めて、最大 1 MB のサイズにすることができます。
  • インラインテンプレートの制限事項
    • JSON ファイルは、テキスト部分と HTML 部分の両方を含めて、最大 1 MB

以下は、保存済みテンプレートとインラインテンプレートの両方に適用されます。

  • 使用できる置換変数の数に制限はありません。
  • SendBulkEmail オペレーションの呼び出しごとに、最大 50 個の送信先オブジェクトに E メールを送信できます。Destination オブジェクトには、ToAddresses、CcAddresses、および BccAddresses で定義された複数の受信者を含めることができます。v2 API への 1 回の呼び出しで問い合わせることができる送信先の数は、アカウントの最大送信レートによって制限される場合があります。詳細については、「Amazon SES 送信制限の管理」を参照してください。
  • 置換変数の数に制限はない
  • SendBulkEmail オペレーション
    • 呼び出しごとに最大 50 個の送信先オブジェクトに E メールを送信できる
  • Destination オブジェクトには、下記で定義した複数の受信者を含めることができる
    • ToAddresses
    • CcAddresses
    • BccAddresses
  • v2 API への 1 回の呼び出しで問い合わせることができる送信先の数は、アカウントの最大送信レートによって制限される場合がある

実践

ストアドメールテンプレート

下記を基に試します。

IAMロールの修正

  1. こちらで作成したロールを開きます
  2. ポリシーの編集をクリックしses:SendTemplatedEmailを追加します。修正後のポリシーは下記のとおりです
    {
    	"Version": "2012-10-17",
    	"Statement": [
    		{
    			"Effect": "Allow",
    			"Action": [
    				"ses:SendEmail",
    				"ses:SendRawEmail",
    				"ses:SendTemplatedEmail"
    			],
    			"Resource": "*"
    		}
    	]
    }
    

メールテンプレートの作成

  1. スケルトンを作成します

    templates % aws sesv2 create-email-template --generate-cli-skeleton > mytemplate.json
    templates % cat mytemplate.json 
    {
        "TemplateName": "",
        "TemplateContent": {
            "Subject": "",
            "Text": "",
            "Html": ""
        }
    }
    templates % 
    
  2. 動的に埋める値をセットします

    templates % cat mytemplate.json 
    {
        "TemplateName": "MyTemplate",
        "TemplateContent": {
            "Subject": "Greetings, {{name}}!",
            "Text": "Dear {{name}},\r\nYour favorite animal is {{favoriteanimal}}.",
            "Html": "<h1>Hello {{name}},</h1><p>Your favorite animal is {{favoriteanimal}}.</p>"
        }
    }
    templates % 
    
    • Subject:メールの件名
    • Html:HTML本文
    • Text:テキスト本文(HTMLメールが表示できない受信者にはこちらが利用される)
  3. CLIで登録します

    templates % aws sesv2 create-email-template --cli-input-json file://mytemplate.json 
    templates % 
    

登録後の確認

CLI

  1. 登録後のテンプレート一覧を確認します
    templates % aws sesv2 list-email-templates   
    {
        "TemplatesMetadata": [
            {
                "TemplateName": "MyTemplate",
                "CreatedTimestamp": "2025-02-24T18:03:25.049000+09:00"
            }
        ]
    }
    templates % 
    
  2. 登録したテンプレートを確認します
    templates % aws sesv2 get-email-template --template-name MyTemplate
    {
        "TemplateName": "MyTemplate",
        "TemplateContent": {
            "Subject": "Greetings, {{name}}!",
            "Text": "Dear {{name}},\r\nYour favorite animal is {{favoriteanimal}}.",
            "Html": "<h1>Hello {{name}},</h1><p>Your favorite animal is {{favoriteanimal}}.</p>"
        }
    }
    templates % 
    

確認

  1. AWSにサインインします
  2. SESに移動し、ナビゲーションペインでEメールテンプレートをクリックします
  3. 登録されました。しかし中身は確認できないようです。
    image.png

Lambda関数の作成

  1. Lambdaに移動します

  2. 「関数の作成」をクリックします

  3. 下記を入力します

    • 関数名:任意
    • ランタイム:Python3.13
    • アーキテクチャ:arm64
    • 実行ロール:上記で作成したIAMロール
  4. 下記のコードをデプロイします

    import boto3
    from botocore.exceptions import ClientError
    
    def lambda_handler(event, context):
        ses_client = boto3.client('ses', region_name='ap-northeast-1')
        template_name = 'MyTemplate'
        sender = 'sender@example.com'
        recipient = 'recipient@example.com'
        template_data = '{ "name":"Taro Yamata" ,"favoriteanimal":"alligator"}'
    
        try:
            response = ses_client.send_templated_email(
                Source=sender,
                Destination={
                    'ToAddresses': [recipient],
                },
                Template=template_name,
                TemplateData=template_data,
            )
        except ClientError as e:
            print(e.response['Error']['Message'])
        else:
            print("Email sent! Message ID:"),
            print(response['MessageId'])
    

テスト

  1. 「Test」をクリックします
  2. 受信ボックスに届きました
    image.png

インラインテンプレート

テンプレートコンテンツを送信 API リクエストに直接含めることで、統合プロセスが簡素化され、個別のテンプレートリソースを作成して維持する必要はありません。

Lambdaレイヤーの追加

boto3 ライブラリのバージョンが古いため、Amazon SESのインラインテンプレート機能に対応していない可能性があったため、設定しました。

ローカルでパッケージ化

  1. ローカルでディレクトリを作成します
    % mkdir -p my_layer/python
    % 
    
  2. pipを使用して、pythonディレクトリに最新のboto3とbotocoreをインストールします
    % pip install boto3 -t my_layer/python
    % pip install botocore -t my_layer/python
    % 
    
  3. レイヤーのパッケージ化
    cd my_layer
    zip -r ../my_layer.zip .
    

AWSでレイヤーの追加

  1. AWSにサインインします
  2. Lambdaに移動します
  3. ナビゲーションペインで「レイヤー」をクリックします
  4. 「レイヤーの作成」をクリックします
  5. アップロードします
    image.png

Lambda関数の作成

  1. Lambdaに移動します

  2. 「関数の作成」をクリックします

  3. 下記を入力します

    • 関数名:任意
    • ランタイム:Python3.13
    • アーキテクチャ:arm64
    • 実行ロール:上記で作成したIAMロール
  4. 下記のコードをデプロイします

    import boto3
    import json
    from botocore.exceptions import ClientError
    
    def lambda_handler(event, context):
    
        # SESクライアントの作成
        ses_client = boto3.client('sesv2', region_name='ap-northeast-1')
        
        # 送信者と受信者のメールアドレス
        sender = 'sender@example.com'
        recipient = 'recipient@example.com'
        
        # テンプレートの内容
        template_content = {
            'Subject': 'こんにちは、{{name}}さん',
            'Text': 'こんにちは、{{name}}さん。ご利用ありがとうございます。',
            'Html': '<h1>こんにちは、{{name}}さん</h1><p>ご利用ありがとうございます。</p>'
        }
        
        # テンプレートデータ
        template_data = {
            'name': 'Taro Yamata'
        }
        
        try:
            # メールの送信
            response = ses_client.send_email(
                FromEmailAddress=sender,
                Destination={
                    'ToAddresses': [recipient],
                },
                Content={
                    'Template': {
                        'TemplateContent': template_content,
                        'TemplateData': json.dumps(template_data)
                    }
                }
            )
            print("Email sent! Message ID:", response['MessageId'])
        except ClientError as e:
            print("Error sending email:", e.response['Error']['Message'])
    
  5. レイヤーの追加をクリックします

  6. 作成したレイヤーを指定して、「追加」をクリックします

テスト

  1. 「Test」をクリックします
  2. 受信ボックスに届きました
    image.png

考察

今回、SESのストアドメールテンプレートとインラインテンプレートを試しました。
インラインテンプレートにより、事前のテンプレート登録が不要となり、効率的とのことですが個人的にはストアドのほうがアプリと静的なコンテンツが分離できるので便利かと思いました。

引き続き、他の機能も試してみます。

参考

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?