MediaWiki REL1_35
EmailNotification Class Reference

This module processes the email notifications when the current page is changed. More...

Collaboration diagram for EmailNotification:

Public Member Functions

 actuallyNotifyOnPageChange ( $editor, $title, $timestamp, $summary, $minorEdit, $oldid, $watchers, $pageStatus='changed')
 Immediate version of notifyOnPageChange().
 
 getPageStatus ()
 Extensions that have hooks for UpdateUserMailerFormattedPageStatus (to provide additional pageStatus indicators) need a way to make sure that, when their hook is called in SendWatchlistemailNotification, they only handle notifications using their pageStatus indicator.
 
 notifyOnPageChange ( $editor, $title, $timestamp, $summary, $minorEdit, $oldid=false, $pageStatus='changed')
 Send emails corresponding to the user $editor editing the page $title.
 

Protected Attributes

 $body
 
 $composed_common
 
User $editor
 
 $from
 
 $mailTargets = []
 
 $minorEdit
 
 $oldid
 
 $pageStatus
 
 $replyto
 
 $subject
 
 $summary
 
 $timestamp
 
Title $title
 

Private Member Functions

 canSendUserTalkEmail ( $editor, $title, $minorEdit)
 
 compose ( $user, $source, MessageCache $messageCache)
 Compose a mail to a given user and either queue it for sending, or send it now, depending on settings.
 
 composeCommonMailtext (MessageCache $messageCache)
 Generate the generic "this page has been changed" e-mail text.
 
 sendImpersonal ( $addresses)
 Same as sendPersonalised but does impersonal mail suitable for bulk mailing.
 
 sendMails ()
 Send any queued mails.
 
 sendPersonalised ( $watchingUser, $source)
 Does the per-user customizations to a notification e-mail (name, timestamp in proper timezone, etc) and sends it out.
 

Private Attributes

const ALL_CHANGES = 'all_changes'
 Notification because user is notified for all changes.
 
const USER_TALK = 'user_talk'
 Notification is due to user's user talk being edited.
 
const WATCHLIST = 'watchlist'
 Notification is due to a watchlisted page being edited.
 

Detailed Description

This module processes the email notifications when the current page is changed.

It looks up the table watchlist to find out which users are watching that page.

The current implementation sends independent emails to each watching user for the following reason:

  • Each watching user will be notified about the page edit time expressed in his/her local time (UTC is shown additionally). To achieve this, we need to find the individual timeoffset of each watching user from the preferences..

Suggested improvement to slack down the number of sent emails: We could think of sending out bulk mails (bcc:user1,user2...) for all these users having the same timeoffset in their preferences.

Visit the documentation pages under https://www.mediawiki.org/wiki/Help:Watching_pages

Definition at line 48 of file EmailNotification.php.

Member Function Documentation

◆ actuallyNotifyOnPageChange()

EmailNotification::actuallyNotifyOnPageChange (   $editor,
  $title,
  $timestamp,
  $summary,
  $minorEdit,
  $oldid,
  $watchers,
  $pageStatus = 'changed' 
)

Immediate version of notifyOnPageChange().

Send emails corresponding to the user $editor editing the page $title.

Note
Do not call directly. Use notifyOnPageChange so that wl_notificationtimestamp is updated.
Parameters
User$editor
Title$title
string$timestampEdit timestamp
string$summaryEdit summary
bool$minorEdit
int$oldidRevision ID
array$watchersArray of user IDs
string$pageStatus
Exceptions
MWException

Definition at line 183 of file EmailNotification.php.

References $title, $wgBlockDisablesLogin, $wgEnotifMinorEdits, $wgEnotifUserTalk, $wgEnotifWatchlist, $wgUsersNotifiedOnAllChanges, User\getName(), getPermissionManager(), UserArray\newFromIDs(), User\newFromName(), and NS_USER_TALK.

◆ canSendUserTalkEmail()

EmailNotification::canSendUserTalkEmail (   $editor,
  $title,
  $minorEdit 
)
private
Parameters
User$editor
Title$title
bool$minorEdit
Returns
bool

Definition at line 276 of file EmailNotification.php.

References $title, $wgBlockDisablesLogin, $wgEnotifUserTalk, User\getId(), User\newFromName(), NS_USER_TALK, and wfDebug().

◆ compose()

EmailNotification::compose (   $user,
  $source,
MessageCache  $messageCache 
)
private

Compose a mail to a given user and either queue it for sending, or send it now, depending on settings.

Call sendMails() to send any mails that were queued.

Parameters
User$user
string$source
MessageCache$messageCache

Definition at line 432 of file EmailNotification.php.

References $source, and $wgEnotifImpersonal.

◆ composeCommonMailtext()

EmailNotification::composeCommonMailtext ( MessageCache  $messageCache)
private

◆ getPageStatus()

EmailNotification::getPageStatus ( )

Extensions that have hooks for UpdateUserMailerFormattedPageStatus (to provide additional pageStatus indicators) need a way to make sure that, when their hook is called in SendWatchlistemailNotification, they only handle notifications using their pageStatus indicator.

Since
1.33
Returns
string

Definition at line 87 of file EmailNotification.php.

◆ notifyOnPageChange()

EmailNotification::notifyOnPageChange (   $editor,
  $title,
  $timestamp,
  $summary,
  $minorEdit,
  $oldid = false,
  $pageStatus = 'changed' 
)

Send emails corresponding to the user $editor editing the page $title.

May be deferred via the job queue.

Parameters
User$editor
Title$title
string$timestamp
string$summary
bool$minorEdit
bool$oldid(default: false)
string$pageStatus(default: 'changed')
Returns
bool Whether an email job was created or not.
Since
1.35 returns a boolean indicating whether an email job was created.

Definition at line 106 of file EmailNotification.php.

◆ sendImpersonal()

EmailNotification::sendImpersonal (   $addresses)
private

Same as sendPersonalised but does impersonal mail suitable for bulk mailing.

Takes an array of MailAddress objects.

Parameters
MailAddress[]$addresses
Returns
Status|null

Definition at line 505 of file EmailNotification.php.

References wfMessage().

◆ sendMails()

EmailNotification::sendMails ( )
private

Send any queued mails.

Definition at line 449 of file EmailNotification.php.

References $wgEnotifImpersonal.

◆ sendPersonalised()

EmailNotification::sendPersonalised (   $watchingUser,
  $source 
)
private

Does the per-user customizations to a notification e-mail (name, timestamp in proper timezone, etc) and sends it out.

Returns Status if email was sent successfully or not (Status::newGood() or Status::newFatal() respectively).

Parameters
User$watchingUser
string$source
Returns
Status

Definition at line 466 of file EmailNotification.php.

References $source, and $wgEnotifUseRealName.

Member Data Documentation

◆ $body

EmailNotification::$body
protected

Definition at line 63 of file EmailNotification.php.

◆ $composed_common

EmailNotification::$composed_common
protected

Definition at line 64 of file EmailNotification.php.

◆ $editor

User EmailNotification::$editor
protected

Definition at line 75 of file EmailNotification.php.

◆ $from

EmailNotification::$from
protected

Definition at line 63 of file EmailNotification.php.

◆ $mailTargets

EmailNotification::$mailTargets = []
protected

Definition at line 65 of file EmailNotification.php.

◆ $minorEdit

EmailNotification::$minorEdit
protected

Definition at line 64 of file EmailNotification.php.

◆ $oldid

EmailNotification::$oldid
protected

Definition at line 64 of file EmailNotification.php.

◆ $pageStatus

EmailNotification::$pageStatus
protected

Definition at line 64 of file EmailNotification.php.

◆ $replyto

EmailNotification::$replyto
protected

Definition at line 63 of file EmailNotification.php.

◆ $subject

EmailNotification::$subject
protected

Definition at line 63 of file EmailNotification.php.

◆ $summary

EmailNotification::$summary
protected

Definition at line 64 of file EmailNotification.php.

◆ $timestamp

EmailNotification::$timestamp
protected

Definition at line 64 of file EmailNotification.php.

◆ $title

Title EmailNotification::$title
protected

Definition at line 70 of file EmailNotification.php.

◆ ALL_CHANGES

const EmailNotification::ALL_CHANGES = 'all_changes'
private

Notification because user is notified for all changes.

Definition at line 61 of file EmailNotification.php.

◆ USER_TALK

const EmailNotification::USER_TALK = 'user_talk'
private

Notification is due to user's user talk being edited.

Definition at line 53 of file EmailNotification.php.

◆ WATCHLIST

const EmailNotification::WATCHLIST = 'watchlist'
private

Notification is due to a watchlisted page being edited.

Definition at line 57 of file EmailNotification.php.


The documentation for this class was generated from the following file: