承接 oliverkroener/ok-exchange365-mailer 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

oliverkroener/ok-exchange365-mailer

最新稳定版本:4.2.0

Composer 安装命令:

composer require oliverkroener/ok-exchange365-mailer

包简介

A TYPO3 extension for sending emails using Exchange 365 and Microsoft Graph API

README 文档

README

TYPO3 12 TYPO3 13 TYPO3 14 PHP 8.1+ License: GPL v2+ Version

A TYPO3 extension for sending emails via Microsoft Exchange 365 using the MS Graph API instead of SMTP. Uses OAuth 2.0 client credentials flow for secure, token-based authentication.

Features

  • Send emails through Microsoft Graph API — no SMTP required
  • OAuth 2.0 client credentials flow for server-to-server authentication
  • Supports both backend (environment variables / TYPO3 settings) and frontend (TypoScript) configuration
  • Compatible with Powermail, TYPO3 Form Framework, and other form extensions
  • Optional saving of sent emails to the sender's "Sent Items" folder
  • Automatic credential blinding in TYPO3's configuration module
  • Works with shared mailboxes and Application Access Policies
  • Send As / Send On Behalf — optional graphSenderUserId decouples the Graph mailbox used for /users/{id}/sendMail from the visible From header, so a configured mailbox can send on behalf of another

Requirements

  • TYPO3: 12.4 LTS, 13.4 LTS, or 14.x
  • PHP: 8.1 – 8.5
  • Dependencies:
    • microsoft/microsoft-graph ^2
    • oliverkroener/ok-typo3-helper ^3

Installation

Install via Composer (recommended):

composer require oliverkroener/ok-exchange365-mailer

Local path repository

If using a local path (e.g., in a monorepo), add the repository to your root composer.json:

{
    "repositories": [
        {
            "type": "path",
            "url": "packages/ok_exchange365_mailer"
        }
    ]
}

Then install:

composer require oliverkroener/ok-exchange365-mailer:@dev

Configuration

1. Register an Azure App

Register an application in Microsoft Entra ID (formerly Azure AD) with Mail.Send and User.ReadBasic.All application permissions. Grant admin consent. See the full Azure setup guide.

2. Configure TYPO3

Set the mail transport to Exchange365Transport and provide your Azure credentials.

Via environment variables (.env):

Variable Description
TYPO3_CONF_VARS__MAIL__transport OliverKroener\OkExchange365\Mail\Transport\Exchange365Transport
TYPO3_CONF_VARS__MAIL__transport_exchange365_tenantId Microsoft Entra ID Tenant ID
TYPO3_CONF_VARS__MAIL__transport_exchange365_clientId Azure Application (Client) ID
TYPO3_CONF_VARS__MAIL__transport_exchange365_clientSecret Azure Application Secret Value
TYPO3_CONF_VARS__MAIL__transport_exchange365_fromEmail Sender email address (must exist in Exchange 365)
TYPO3_CONF_VARS__MAIL__transport_exchange365_graphSenderUserId (optional) Graph mailbox/user ID used for /users/{id}/sendMail. When set, this mailbox sends the message; the visible From header still comes from the message or fromEmail. Use for Send As / Send On Behalf.
TYPO3_CONF_VARS__MAIL__transport_exchange365_saveToSentItems 1 to save to Sent Items, 0 to skip (default: 0)

Via TypoScript (for frontend forms):

plugin.tx_okexchange365mailer.settings.exchange365 {
    tenantId = your-tenant-id
    clientId = your-client-id
    clientSecret = your-client-secret
    fromEmail = service@your-domain.com
    # Optional: route via a different mailbox using Send As / Send On Behalf
    # graphSenderUserId = service@your-domain.com
    saveToSentItems = 1
}

Send As / Send On Behalf

The optional graphSenderUserId (or transport_exchange365_graphSenderUserId) decouples the Graph mailbox used for the API call from the visible From address of the message:

  • The Graph endpoint /users/{id}/sendMail is called against graphSenderUserId.
  • The message From header still resolves through $graphMessage['from']fromEmaildefaultMailFromAddress, so recipients see the configured sender, not the Graph mailbox.

The configured Graph mailbox must hold Send As or Send On Behalf permission on the visible sender mailbox in Exchange. See the Microsoft Graph documentation on sending mail from another user.

When graphSenderUserId is unset (or empty), the same value resolution chain is used to pick the Graph mailbox — i.e. the visible sender also sends the message, which is the standard single-mailbox setup.

Sender Display Name

The Graph API uses the Display name configured on the mailbox in Exchange Online. TYPO3's defaultMailFromName has no effect. Configure the display name in the Microsoft 365 Admin Center or Exchange Admin Center.

Architecture

Component Description
Exchange365Transport Custom Symfony mailer transport; handles OAuth2 auth and sends via Graph API
ModifyBlindedConfigurationOptionsEventListener PSR-14 event listener; blinds credentials in TYPO3 configuration module
MSGraphMailApiService (from ok-typo3-helper) Converts Symfony email messages to Microsoft Graph format
Classes/
├── Mail/Transport/
│   └── Exchange365Transport.php
└── Lowlevel/EventListener/
    └── ModifyBlindedConfigurationOptionsEventListener.php
Configuration/
├── Services.yaml
├── TCA/Overrides/sys_template.php
└── TypoScript/
    ├── constants.typoscript
    └── setup.typoscript

License

GPL-2.0-or-later

Author — Oliver Kroener

Automated. Scaled. Done.

Web3 · Cloud · Automation

Technology is only valuable when it solves a real problem. For over 30 years I've been translating between business and tech — so your investment in digitalisation doesn't stall at proof-of-concept but delivers measurable results.

统计信息

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

GitHub 信息

  • Stars: 8
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: GPL-2.0-or-later
  • 更新时间: 2024-09-12

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固