etailors/mautic-amazon-ses

Amazon SES Mailer Plugin for Mautic

Installs: 2

Dependents: 0

Suggesters: 0

Security: 0

Stars: 43

Watchers: 5

Forks: 38

Open Issues: 4

Type:mautic-plugin

pkg:composer/etailors/mautic-amazon-ses

1.0.26 2025-11-09 00:45 UTC

README

This plugin provides integration between Mautic 5 and Amazon SES for sending emails through AWS. It also integrates with Amazon SNS for handling email feedback such as bounces and complaints via callbacks.

This is a custom plugin inspired by the structure of:

Feel free to suggest improvements or provide feedback — this is my first Mautic plugin and community contributions are welcome.

Features

  • Send emails through Amazon SES using the API.
  • Support for setting AWS regions and optional custom rate limits in the DSN.
  • Integration with Amazon SNS to process bounces and complaints via callback.
  • Built-in rate limiting to honor SES sending quotas.
  • Dynamic batch size matching the current SES max send rate.
  • Auto-fetch and cache your SES sending quota.
  • Manual override of rate limit with ratelimit DSN option.
  • Optional retry handling for partial email failures.

Installation

1. Download and Install the Plugin

  1. Download or clone the repository to your Mautic plugins directory:

    cd /path/to/your/mautic/plugins
    git clone https://github.com/yourusername/mautic-aws-ses-plugin.git AmazonSesBundle
  2. Clear Mautic's cache:

    php /path/to/mautic/bin/console cache:clear
  3. Go to Mautic Settings > Plugins and click the "Install/Update Plugins" button.

Install via Composer (alternatief)

Als je Composer gebruikt in je Mautic-installatie, kun je de plugin via Composer installeren. Dit zorgt er automatisch voor dat de plugin in plugins/AmazonSesBundle wordt geplaatst.

  1. In de Mautic-root:

    composer require etailors/mautic-amazon-ses:^1.0.25 -W
    • Tip: gebruik -W (alias --update-with-all-dependencies) zodat Composer gelockte afhankelijkheden kan bijwerken.
    • Draai je Mautic 6? Zorg dat de PHP-extensie imap is geïnstalleerd/ingeschakeld voordat je Composer draait, anders kan mautic/core-lib 6.x niet worden opgelost.
    • Heb je (nog) geen Packagist publicatie, gebruik dan een VCS-repository in de Mautic composer.json:
      {
        "repositories": [
          { "type": "vcs", "url": "https://github.com/pm-pmaas/etailors_amazon_ses" }
        ]
      }
      
      En installeer vervolgens:
      composer require etailors/mautic-amazon-ses:dev-main
  2. Zorg dat Composer 2 plugins zijn toegestaan in de Mautic-root (meestal al zo):

    {
      "config": {
        "allow-plugins": {
          "composer/installers": true
        }
      }
    }
  3. Leeg de cache hard en herlaad plugins:

    rm -rf var/cache/*
    php bin/console mautic:plugins:reload

Let op: dankzij type: "mautic-plugin" en extra.install-directory-name: "AmazonSesBundle" in deze plugin wordt de mapnaam automatisch juist gezet.

2. Configure Amazon SES Settings

  1. In Mautic, navigate to Settings > Email Settings.

  2. Select the newly installed AWS SES option.

  3. In the DSN field, enter your connection string in the following format:

    mautic+ses+api://<AWS_ACCESS_KEY>:<AWS_SECRET_KEY>@default?region=<AWS_REGION>&ratelimit=14
    
    • Replace <AWS_ACCESS_KEY> and <AWS_SECRET_KEY> with your AWS credentials.
    • Replace <AWS_REGION> with your AWS region (e.g., us-east-1).
    • Optionally set ratelimit to override the SES max send rate manually.
  4. Set the region in the options parameter, for example:

    Label: region   Value: eu-west-1
    

Amazon SES Integration

3. AWS SES Configuration

  1. Ensure that you have verified your domain and email addresses in AWS SES.

  2. Set up the appropriate IAM user with permissions to send emails via SES. Please make sure you create a new IAM user directly via IAM instead of upgrading an SMTP user with the permission: sending via SES API.

    There are known issues when upgrading SMTP-only users — see: issue #28.

Your IAM user must have permission to send and get account limits. Here's an example policy that grants those permissions:

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "AllowSending",
            "Effect": "Allow",
            "Action": [
                "ses:SendEmail",
                "ses:SendBulkEmail"
            ],
            "Resource": "arn:aws:ses:*:<account id>:identity/*"
        },
        {
            "Sid": "AllowGetAccount",
            "Effect": "Allow",
            "Action": [
                "ses:GetAccount"
            ],
            "Resource": "*"
        }
    ]
}

4. Available Regions

Below are the supported AWS SES regions:

us-east-1
us-east-2
ap-south-1
ap-northeast-2
ap-southeast-1
ap-southeast-2
ap-northeast-1
ca-central-1
eu-central-1
eu-west-1
eu-west-2
eu-north-1
sa-east-1
us-gov-west-1

SNS Callback Configuration

To receive feedback from Amazon SES regarding bounces and complaints, you need to set up Amazon SNS.

  1. Go to your Amazon SNS Dashboard.

  2. Create a new Topic (or use an existing one) for SES feedback.

  3. Subscribe to this topic with an HTTPS endpoint using the following URL:

    https://<your-mautic-instance-url>/mailer/callback
    
  4. Ensure your topic sends notifications for bounces, complaints, and delivery status.

  5. Test your callback configuration by sending test emails and reviewing the logs in Mautic to ensure feedback is being processed correctly.

Batch Limit & Throttling

To avoid exceeding SES rate limits, this plugin automatically:

  • Caches the current maxSendRate returned by AWS SES.
  • Dynamically adjusts the batch size to match that rate.
  • Throttles outgoing email API calls using usleep().
  • Allows overriding the send rate via ratelimit DSN option.

This prevents common errors like TooManyRequests while making the most of your quota.

Debugging

  • To debug or troubleshoot any issues with email sending or SNS feedback processing, check Mautic's logs at:

    /path/to/mautic/var/logs
    
  • You can also review the status of your emails and SNS callbacks within the Amazon CloudWatch service to monitor the performance of SES and SNS.

Contributions & Feedback

This is my first Mautic plugin, so I’m open to any feedback or improvements. Feel free to open an issue or submit a pull request if you find a bug or have a feature request!

License

This project is licensed under the MIT License - see the LICENSE file for details.