Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/johnbillion/wp_mail
Documentation for all the situations where WordPress core sends an email, how and when they happen, and how to filter or disable each one.
https://github.com/johnbillion/wp_mail
documentation email wordpress
Last synced: 7 days ago
JSON representation
Documentation for all the situations where WordPress core sends an email, how and when they happen, and how to filter or disable each one.
- Host: GitHub
- URL: https://github.com/johnbillion/wp_mail
- Owner: johnbillion
- License: gpl-2.0
- Created: 2019-03-31T22:01:47.000Z (almost 6 years ago)
- Default Branch: trunk
- Last Pushed: 2024-11-13T23:04:16.000Z (2 months ago)
- Last Synced: 2025-01-12T16:03:09.492Z (14 days ago)
- Topics: documentation, email, wordpress
- Homepage:
- Size: 145 KB
- Stars: 360
- Watchers: 23
- Forks: 24
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# WordPress Email Documentation
This document lists all the situations where WordPress core sends an email, how and when they happen, and how to filter or disable each one.
This list was last updated for WordPress 6.7.
## Table of Contents
- [Information Applicable to All Emails](#information-applicable-to-all-emails)
- [Comments](#comments)
- [Change of Admin Email](#change-of-admin-email)
- [Change of User Email or Password](#change-of-user-email-or-password)
- [Personal Data Requests](#personal-data-requests)
- [Automatic Updates](#automatic-updates)
- [New User](#new-user)
- [New Site](#new-site)
- [Other](#other)## Information Applicable to All Emails
All emails sent by WordPress go through the pluggable
wp_mail()
function. The following general-purpose filters and actions are used in this function:
Filters
wp_mail
pre_wp_mail
wp_mail_from
wp_mail_from_name
wp_mail_content_type
wp_mail_charset
Actions
phpmailer_init
wp_mail_succeeded
(WP 5.9+)
wp_mail_failed
## Comments
### Comment is awaiting moderation
Sent when a user or visitor submits a comment that gets held for moderation.
To
- Site Admin
- Post author, if they have the ability to edit the comment
From
WordPress <wordpress@host>
Subject
[%1$s] Please moderate: "%2$s"
Function
wp_notify_moderator()
Pluggable
Yes
Filters
comment_moderation_recipients
comment_moderation_subject
comment_moderation_text
comment_moderation_headers
Disable
- Return false fromnotify_moderator
filter
- Removewp_new_comment_notify_moderator
action fromcomment_post
hook
- "Email me whenever" settings on Settings -> Discussion screen
- Overwrite the pluggablewp_notify_moderator()
function
### Comment is published
Sent when:
* A user or visitor submits a comment that gets automatically approved
* A comment previously held for moderation gets approved.
To
Post author
From
WordPress <wordpress@host>
Subject
[%1$s] Comment: "%2$s"
[%1$s] Pingback: "%2$s"
[%1$s] Trackback: "%2$s"
Function
wp_notify_postauthor()
Pluggable
Yes
Filters
comment_notification_recipients
comment_notification_subject
comment_notification_text
comment_notification_headers
Disable
- Return false fromnotify_post_author
filter
- Removewp_new_comment_notify_postauthor
action fromcomment_post
hook
- "Email me whenever" settings on Settings -> Discussion screen
- Overwrite the pluggablewp_notify_postauthor()
function
- See also this hardcoded action added towp_set_comment_status
inwp_set_comment_status()
## Change of Admin Email
### Change of site admin email address is attempted
Sent when a user attempts to change the Administration Email Address option on the General Settings screen.
To
Proposed new email address
From
WordPress <wordpress@host>
Subject
[%s] New Admin Email Address
Function
update_option_new_admin_email()
Pluggable
No
Filters
new_admin_email_subject
(WP 6.5+)
new_admin_email_content
Disable
Removeupdate_option_new_admin_email
action fromadd_option_new_admin_email
andupdate_option_new_admin_email
hooks
### Site admin email address is changed
Sent when a user clicks the link in the email requesting confirmation of the change to the site admin email address (see above).
To
Old site admin email address
From
WordPress <wordpress@host>
Subject
[%s] Admin Email Changed
Function
wp_site_admin_email_change_notification()
Pluggable
No
Filters
site_admin_email_change_email
Disable
Return false fromsend_site_admin_email_change_email
filter
### Change of network admin email address is attempted
Multisite only. Sent when a user attempts to change the Network Admin Email option on the Network Settings screen.
To
Proposed new email address
From
WordPress <wordpress@host>
Subject
[%s] Network Admin Email Change Request
Function
update_network_option_new_admin_email()
Pluggable
No
Filters
new_network_admin_email_content
Disable
Removeupdate_network_option_new_admin_email
action fromadd_site_option_new_admin_email
andupdate_site_option_new_admin_email
hooks
### Network admin email address is changed
Multisite only. Sent when a user clicks the link in the email requesting confirmation of the change to the network admin email (see above).
To
Old network admin email address
From
WordPress <wordpress@host>
Subject
[%s] Notice of Network Admin Email Change
Function
wp_network_admin_email_change_notification()
Pluggable
No
Filters
network_admin_email_change_email
Disable
Return false fromsend_network_admin_email_change_email
filter
## Change of User Email or Password
### User or Administrator requests a password reset
Sent when:
* A user clicks the "Lost your password?" link on the login screen and submits their email address
* An Administrator clicks the "Send password reset" link next to a user on the Users screen (WP 5.7+)
* An Administrator clicks the "Send Reset Link" from the user editing screen of another user (WP 5.7+)
To
User
From
WordPress <wordpress@host>
Subject
[%s] Password Reset
Function
retrieve_password()
Pluggable
No
Filters
retrieve_password_title
retrieve_password_message
retrieve_password_notification_email
(WP 6.0+)
Disable
- Return false fromsend_retrieve_password_email
filter (WP 6.0+)
- Return an empty message fromretrieve_password_message
filter
### User resets their password
Sent when a user resets their password after clicking the confirmation link sent by the "Lost your password?" feature (see above).
To
Site admin
From
WordPress <wordpress@host>
Subject
[%s] Password Changed
Function
wp_password_change_notification()
Pluggable
Yes
Filters
wp_password_change_notification_email
Disable
- Removewp_password_change_notification
action from theafter_password_reset
hook
- Overwrite the pluggablewp_password_change_notification()
function
### User changes their password
Sent when a logged in user changes their password from the user profile screen.
To
User
From
WordPress <wordpress@host>
Subject
[%s] Password Changed
Function
wp_update_user()
Pluggable
No
Filters
password_change_email
Disable
Return false fromsend_password_change_email
filter
### User attempts to change their email address
Sent when a logged in user attempts to change their email address from the user profile screen.
To
Proposed new email address
From
WordPress <wordpress@host>
Subject
[%s] Email Change Request
Function
send_confirmation_on_profile_email()
Pluggable
No
Filters
new_user_email_content
Disable
Removesend_confirmation_on_profile_email()
action frompersonal_options_update
hook
### User changes their email address
Sent when a user clicks the link in the email requesting confirmation of the change to their email address (see above).
To
User
From
WordPress <wordpress@host>
Subject
[%s] Email Changed
Function
wp_update_user()
Pluggable
No
Filters
email_change_email
Disable
Return false fromsend_email_change_email
filter
## Personal Data Requests
### Personal data export or erasure request is created or resent
Sent when:
* A request is created or resent from the Tools -> Export Personal Data screen
* A request is created or resent from the Tools -> Erase Personal Data screen
To
Requester email address
From
WordPress <wordpress@host>
Subject
[%1$s] Confirm Action: %2$s
Function
wp_send_user_request()
Pluggable
No
Filters
user_request_action_email_subject
user_request_action_email_content
user_request_action_email_headers
Disable
Unknown, may have to remove the admin pages entirely by removing_wp_privacy_hook_requests_page
action fromadmin_menu
hook
### User confirms personal data export or erasure request
Sent when a user clicks the link in the personal data export or erasure request confirmation email (see above).
To
- Site admin on a single site installation
- Network admin on a Multisite installation
From
WordPress <wordpress@host>
Subject
[%1$s] Action Confirmed: %2$s
Function
_wp_privacy_send_request_confirmation_notification()
Pluggable
No
Filters
user_request_confirmed_email_to
user_request_confirmed_email_subject
user_request_confirmed_email_content
(WP 5.8+)
user_request_confirmed_email_headers
user_confirmed_action_email_content
(deprecated in 5.8)
Disable
Remove_wp_privacy_send_request_confirmation_notification()
action fromuser_request_action_confirmed
hook
### Site admin sends link to a personal data export
Sent when a site admin clicks the Send Export Link button next to a confirmed data export request.
To
Requester email address
From
WordPress <wordpress@host>
Subject
[%s] Personal Data Export
Function
wp_privacy_send_personal_data_export_email()
Pluggable
No
Filters
wp_privacy_personal_data_email_to
wp_privacy_personal_data_email_subject
wp_privacy_personal_data_email_content
wp_privacy_personal_data_email_headers
Disable
Removewp_privacy_send_personal_data_export_email()
action fromwp_privacy_personal_data_export_page
hook
### Site admin erases personal data to fulfill a data erasure request
Sent when:
* An administrator clicks the Erase Personal Data button next to a confirmed data erasure request
* An administrator clicks the Force Erase Personal Data button next to a data erasure request of any status
To
Requester email address
From
WordPress <wordpress@host>
Subject
[%s] Erasure Request Fulfilled
Function
_wp_privacy_send_erasure_fulfillment_notification()
Pluggable
No
Filters
user_erasure_fulfillment_email_to
user_erasure_fulfillment_email_subject
(WP 5.8+)
user_erasure_fulfillment_email_content
(WP 5.8+)
user_erasure_fulfillment_email_headers
(WP 5.8+)
user_erasure_complete_email_subject
(deprecated in 5.8)
user_confirmed_action_email_content
(deprecated in 5.8)
user_erasure_complete_email_headers
(deprecated in 5.8)
Disable
Remove_wp_privacy_send_erasure_fulfillment_notification()
action fromwp_privacy_personal_data_erased
hook
## Automatic Updates
### Automatic plugin or theme updates
Sent when a background automatic update to plugins and/or themes completes or fails.
To
Site admin on a single site installation
Network admin on a Multisite installation
From
WordPress <wordpress@host>
Subject
[%s] Some plugins and themes have automatically updated
[%s] Some plugins were automatically updated
[%s] Some themes were automatically updated
[%s] Some plugins and themes have failed to update
[%s] Some plugins have failed to update
[%s] Some themes have failed to update
Function
WP_Automatic_Updater::after_plugin_theme_update()
Pluggable
No
Filters
auto_plugin_theme_update_email
Disable
- Return false fromauto_plugin_update_send_email
filter
- Return false fromauto_theme_update_send_email
filter
### Automatic core update
Sent when a background automatic update to WordPress core completes or fails.
To
Site admin on a single site installation
Network admin on a Multisite installation
From
WordPress <wordpress@host>
Subject
[%1$s] Your site has updated to WordPress %2$s
[%1$s] WordPress %2$s is available. Please update!
[%1$s] URGENT: Your site may be down due to a failed update
Function
WP_Automatic_Updater::send_email()
Pluggable
No
Filters
auto_core_update_email
Disable
- Return false fromauto_core_update_send_email
filter
- Return false fromsend_core_update_notification_email
filter
### Full log of background update results
Only sent when you are using a development version of WordPress and it's not under version control.
To
Site admin on a single site installation
Network admin on a Multisite installation
From
WordPress <wordpress@host>
Subject
[%s] Background Update Failed
[%s] Background Update Finished
Function
WP_Automatic_Updater::send_debug_email()
Pluggable
No
Filters
auto_core_update_email
Disable
Return false fromautomatic_updates_send_debug_email
filter
## New User
### An existing user is invited to a site
Multisite only. Sent when an existing user is added to a site from Users -> Add New -> Add Existing User.
To
User being invited
From
WordPress <wordpress@host>
Subject
[%s] Joining Confirmation
Function
wp-admin/user-new.php
Pluggable
No
Filters
invited_user_email
Disable
Click the "Skip Confirmation Email" checkbox when adding the user
### A new user is invited to join a site
Multisite only. Sent when a new user is invited to join a site from Users -> Add New -> Add New User.
To
User being invited
From
[Network Name] <[network admin]>
Subject
[%1$s] Activate %2$s
Function
wpmu_signup_user_notification()
Pluggable
No
Filters
wpmu_signup_user_notification_subject
wpmu_signup_user_notification_email
Disable
- Click the "Skip Confirmation Email" checkbox when adding the user
- Return false fromwpmu_signup_user_notification
filter
Note
There is a default filter attached towpmu_signup_user_notification_email
:admin_created_user_email()
### A new user account is created
Multisite only. Sent when a new user account is created via `wpmu_create_user()`:
* From Network Admin -> Sites -> Add New and the email address doesn't already exist
* From Network Admin -> Sites -> [Edit] -> Users -> Add New User
* From Network Admin -> Users -> Add New
* From Users -> Add New -> Add New User and the "Skip Confirmation Email" checkbox is checked
* When a user activates their new account on `wp-activate.php`
* Via a REST API request to create a new user (`POST` to `/wp/v2/users`)Details:
To
Network Admin
From
WordPress <wordpress@host>
Subject
New User Registration: %s
Function
newuser_notify_siteadmin()
Pluggable
No
Filters
newuser_notify_siteadmin
Disable
- Filter theregistrationnotification
option value
- Remove action from thewpmu_new_user
hook
- Toggle "Registration notification" in Network Admin -> Settings
### A user is added, or their account activation is successful
Multisite only.
To
User being added
From
[Network Name] <[network admin]>
Subject
New %1$s User: %2$s
Function
wpmu_welcome_user_notification()
Pluggable
No
Filters
update_welcome_user_subject
update_welcome_user_email
See also the "Welcome User Email" setting in Network Admin -> Settings
Disable
- Click the "Skip Confirmation Email" checkbox when adding the user
- Return false from thewpmu_welcome_user_notification
filter
- Remove action from thewpmu_activate_user
hook
### A new user is created
When a new user is created, two emails are sent from the same function. One to the site admin:
To
Site Admin
From
WordPress <wordpress@host>
Subject
[%s] New User Registration
Filters
wp_new_user_notification_email_admin
wp_send_new_user_notification_to_admin
(WP 6.1+)
and one to the newly created user:
To
New user
From
WordPress <wordpress@host>
Subject
[%s] Login Details
Filters
wp_new_user_notification_email
wp_send_new_user_notification_to_user
(WP 6.1+)
Details:
Function
wp_new_user_notification()
Pluggable
Yes
Disable
- Return false from thewp_send_new_user_notification_to_admin
orwp_send_new_user_notification_to_user
filter (WP 6.1+)
- Removewp_send_new_user_notifications()
action from theregister_new_user
hook
- Removewp_send_new_user_notifications()
action from theedit_user_created_user
hook
- Removewp_send_new_user_notifications()
action from thenetwork_site_new_created_user
hook
- Removewp_send_new_user_notifications()
action from thenetwork_site_users_created_user
hook
- Removewp_send_new_user_notifications()
action from thenetwork_user_new_created_user
hook
- Overwrite the pluggablewp_new_user_notification()
function
## New Site
### A new site is created
Multisite only. Sent when a new site is created from Network Admin -> Sites -> Add New.
To
Network Admin
From
Site Admin <[network admin]>
Subject
[%s] New Site Created
Function
wpmu_new_site_admin_notification()
Pluggable
No
Filters
new_site_email
Disable
Return false from thesend_new_site_email
filter
### User registers for a new site
Multisite only, with site registration allowed. Sent when a visitor registers a new user account and site from wp-signup.php.
To
Site Admin
From
[Network Name] <[network admin]>
Subject
[%1$s] Activate %2$s
Function
wpmu_signup_blog_notification()
Pluggable
No
Filters
wpmu_signup_blog_notification_subject
wpmu_signup_blog_notification_email
Disable
- Return false from thewpmu_signup_blog_notification
filter
- Removewpmu_signup_blog_notification()
action from theafter_signup_site
hook
### User activates their new site, or site added from Network Admin -> Sites -> Add New
Multisite only.
To
Network Admin
From
WordPress <wordpress@host>
Subject
New Site Registration: %s
Function
newblog_notify_siteadmin()
Pluggable
No
Filters
newblog_notify_siteadmin
Disable
- Filter theregistrationnotification
option value
- Change the "Registration notification" setting in Network Admin -> Settings
- Removenewblog_notify_siteadmin()
action from thewpmu_new_blog
hook
- Removenewblog_notify_siteadmin()
action from thewp_initialize_site
hook
### User activates their new site, or site added from Network Admin -> Sites -> Add New
Multisite only.
To
New Site Admin
From
[Network Name] <[network admin]>
Subject
New %1$s Site: %2$s
Function
wpmu_welcome_notification()
Pluggable
No
Filters
update_welcome_subject
update_welcome_email
See also the "Welcome Email" setting in Network Admin -> Settings
Disable
- Return false from thewpmu_welcome_notification
filter
- Removewpmu_welcome_notification()
action from thewpmu_activate_blog
hook
## Other
### Installation
Sent when WordPress is initially installed.
To
Site Admin
From
WordPress <wordpress@host>
Subject
New WordPress Site
Function
wp_new_blog_notification()
Pluggable
yes
Filters
wp_installed_email
Disable
Overwrite the pluggablewp_new_blog_notification()
function
### A fatal error occurs
Sent when a fatal error occurs in a plugin or theme and Recovery Mode is not active.
**Important:** The `wp_fatal_error_handler_enabled` filter cannot be used by plugins as it runs too early. [Information about using this filter can be found here](https://core.trac.wordpress.org/browser/trunk/src/wp-includes/error-protection.php?rev=49489&marks=114-131#L97).
To
Site Admin / Value of RECOVERY_MODE_EMAIL constant
From
WordPress <wordpress@host>
Subject
[%s] Your Site is Experiencing a Technical Issue
Function
send_recovery_mode_email()
Pluggable
No
Filters
wp_fatal_error_handler_enabled
recovery_email_support_info
recovery_email_debug_info
recovery_mode_email
Disable
DefineWP_DISABLE_FATAL_ERROR_HANDLER
as true
Return false from thewp_fatal_error_handler_enabled
filter
Note
Does not currently apply to Multisite
### Site admin requests to delete site
Multisite only. Sent when an Administrator requests to delete their site from the Tools -> Delete Site screen.
To
Site Admin
From
WordPress <wordpress@host>
Subject
[%s] Delete My Site
File
wp-admin/ms-delete-site.php
Pluggable
No
Filters
delete_site_email_content
Disable
Not possible
## License: GPLv2
Copyright 2015 - 2024 John Blackbourn
This documentation is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.This documentation is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.