maatify/email-delivery 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

maatify/email-delivery

最新稳定版本:v1.0.0

Composer 安装命令:

composer require maatify/email-delivery

包简介

Standalone email delivery module for rendering, queueing and sending emails.

README 文档

README

Latest Version PHP Version License

PHPStan

Changelog Security

Monthly Downloads Total Downloads

Security Audit

Async Email SMTP Twig Templates Maatify Ecosystem

Install

CI

Overview

Maatify Email Delivery is a standalone module for rendering, queueing, and sending transactional emails.

It provides:

  • Async transactional email delivery
  • Twig email rendering
  • Queue-based delivery
  • SMTP transport via PHPMailer
  • Background worker processing
  • Encrypted payload storage via maatify/crypto
  • Framework-agnostic architecture

Why This Library

This library solves several common problems in web applications:

  • Synchronous email sending blocking requests and slowing down user responses.
  • Unreliable delivery in high-volume systems when SMTP servers drop connections.
  • Lack of templating systems for clean, maintainable transactional email layouts.
  • Difficulty scaling email infrastructure.

By decoupling the process, the library introduces an robust async email pipeline.

Features

  • Async email queue
  • Twig template rendering
  • SMTP transport (PHPMailer)
  • Background worker processing
  • Encrypted queue payloads
  • Retry mechanism for failed emails
  • Framework-agnostic design
  • Designed for transactional email systems

Quick Example

use Maatify\EmailDelivery\Queue\DTO\EmailQueuePayloadDTO;
use Maatify\EmailDelivery\Queue\PdoEmailQueueWriter;

// 1. Initialize Queue Writer
$queueWriter = new PdoEmailQueueWriter($pdo, $cryptoProvider, $cryptoContext);

// 2. Create Payload
$payload = new EmailQueuePayloadDTO(
    templateKey: 'welcome',
    language: 'en',
    context: ['name' => 'John Doe']
);

$email = 'john.doe@example.com';

// 3. Enqueue the email
$queueWriter->enqueue(
    entityType: 'user',
    entityId: '123',
    recipientEmail: $email,
    payload: $payload,
    senderType: 1,
    priority: 10
);

Architecture Overview

The email delivery pipeline relies on four main components:

  • Renderer: Compiles data and Twig templates into HTML/Text content.
  • Queue Writer: Securely encrypts and stores the payload in the database queue.
  • Worker: A background process that decrypts, renders, and attempts delivery.
  • Transport: The SMTP layer that physically sends the email.
Application
      ↓
Queue Writer
      ↓
Database Queue
      ↓
Email Worker
      ↓
SMTP Transport

Email Delivery Pipeline

Request → Queue → Worker → SMTP → Recipient

This system intentionally decouples email sending from application requests. Your application immediately responds to the user while the background worker handles the potentially slow and error-prone process of rendering and SMTP transmission.

System Diagrams

Architecture

Architecture

Email Flow

Email Flow

Worker Lifecycle

Worker Lifecycle

Installation

composer require maatify/email-delivery

Documentation

Book:

Guides:

Examples:

Ecosystem

This package is part of the Maatify Ecosystem.

It relies on the maatify/crypto dependency to provide robust encryption. Encryption is used specifically for queue payload security, ensuring that sensitive transactional data (like password reset tokens or PII) remains unreadable if the queue database is ever compromised.

License

MIT License

统计信息

  • 总下载量: 20
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 5
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-11

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固