diff options
Diffstat (limited to 'www/wiki/includes/watcheditem/WatchedItem.php')
-rw-r--r-- | www/wiki/includes/watcheditem/WatchedItem.php | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/www/wiki/includes/watcheditem/WatchedItem.php b/www/wiki/includes/watcheditem/WatchedItem.php new file mode 100644 index 00000000..43a9c4e5 --- /dev/null +++ b/www/wiki/includes/watcheditem/WatchedItem.php @@ -0,0 +1,85 @@ +<?php +/** + * This program 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 program 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. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * http://www.gnu.org/copyleft/gpl.html + * + * @file + * @ingroup Watchlist + */ + +use MediaWiki\Linker\LinkTarget; + +/** + * Representation of a pair of user and title for watchlist entries. + * + * @author Tim Starling + * @author Addshore + * + * @ingroup Watchlist + */ +class WatchedItem { + /** + * @var LinkTarget + */ + private $linkTarget; + + /** + * @var User + */ + private $user; + + /** + * @var null|string the value of the wl_notificationtimestamp field + */ + private $notificationTimestamp; + + /** + * @param User $user + * @param LinkTarget $linkTarget + * @param null|string $notificationTimestamp the value of the wl_notificationtimestamp field + */ + public function __construct( + User $user, + LinkTarget $linkTarget, + $notificationTimestamp + ) { + $this->user = $user; + $this->linkTarget = $linkTarget; + $this->notificationTimestamp = $notificationTimestamp; + } + + /** + * @return User + */ + public function getUser() { + return $this->user; + } + + /** + * @return LinkTarget + */ + public function getLinkTarget() { + return $this->linkTarget; + } + + /** + * Get the notification timestamp of this entry. + * + * @return bool|null|string + */ + public function getNotificationTimestamp() { + return $this->notificationTimestamp; + } +} |