36 $this->file = static::initFile(
$list,
$row );
47 return MediaWikiServices::getInstance()->getRepoGroup()->getLocalRepo()
48 ->newFileFromRow(
$row );
52 return 'oi_archive_name';
56 return 'oi_timestamp';
64 return 'oi_user_text';
72 $parts = explode(
'!', $this->row->oi_archive_name );
78 return $this->file->userCan( File::DELETED_RESTRICTED, $this->list->getUser() );
82 return $this->file->userCan( File::DELETED_FILE, $this->list->getUser() );
86 return $this->file->getVisibility();
91 # @todo FIXME: Move to LocalFile.php
93 if ( $bits & File::DELETED_FILE ) {
97 $key = $this->file->getStorageKey();
98 $srcRel = $this->file->repo->getDeletedHashPath( $key ) . $key;
99 $this->list->storeBatch[] = [
100 $this->file->repo->getVirtualUrl(
'deleted' ) .
'/' . $srcRel,
102 $this->file->getRel()
104 $this->list->cleanupBatch[] = $key;
106 } elseif ( $bits & File::DELETED_FILE ) {
108 $key = $this->file->getStorageKey();
109 $dstRel = $this->file->repo->getDeletedHashPath( $key ) . $key;
110 $this->list->deleteBatch[] = [ $this->file->getRel(), $dstRel ];
113 # Do the database operations
115 $dbw->update(
'oldimage',
116 [
'oi_deleted' => $bits ],
118 'oi_name' => $this->row->oi_name,
119 'oi_timestamp' => $this->row->oi_timestamp,
120 'oi_deleted' => $this->getBits()
125 return (
bool)$dbw->affectedRows();
129 return $this->file->isDeleted( File::DELETED_FILE );
138 $date = $this->list->getLanguage()->userTimeAndDate(
139 $this->file->getTimestamp(), $this->list->getUser() );
143 return Html::element(
'a', [
'href' => $this->file->getUrl() ], $date );
148 $link = htmlspecialchars( $date );
155 'target' => $this->list->getPageName(),
156 'file' => $this->file->getArchiveName(),
157 'token' => $this->list->getUser()->getEditToken(
158 $this->file->getArchiveName() )
163 return '<span class="history-deleted">' . $link .
'</span>';
171 $uploader = $this->file->getUploader( File::FOR_THIS_USER, $this->list->getAuthority() );
177 $link = $this->list->msg(
'rev-deleted-user' )->escaped();
179 if ( $this->file->isDeleted( File::DELETED_USER ) ) {
180 return '<span class="history-deleted">' . $link .
'</span>';
192 if ( $this->file->userCan( File::DELETED_COMMENT, $this->list->getUser() ) ) {
195 $block =
' ' . $this->list->msg(
'rev-deleted-comment' )->escaped();
197 if ( $this->file->isDeleted( File::DELETED_COMMENT ) ) {
198 return "<span class=\"history-deleted\">$block</span>";
206 $this->list->msg(
'widthheight' )->numParams(
207 $this->file->getWidth(),
208 $this->file->getHeight() )->escaped() .
209 ' (' . $this->list->msg(
'nbytes' )->numParams(
210 $this->file->getSize() )->escaped() .
')';
218 $user = $this->list->getUser();
220 'title' => $this->list->getPageName(),
226 'userhidden' => (bool)
$file->
isDeleted( RevisionRecord::DELETED_USER ),
227 'commenthidden' => (bool)
$file->
isDeleted( RevisionRecord::DELETED_COMMENT ),
228 'contenthidden' => (bool)$this->
isDeleted(),
238 'target' => $this->list->getPageName(),
248 'userid' => $uploader->getId(),
249 'user' => $uploader->getName(),
253 if ( ( $comment ??
'' ) !==
'' ) {
255 'comment' => $comment,
263 return $this->file->acquireFileLock();
267 return $this->file->releaseFileLock();
wfGetDB( $db, $groups=[], $wiki=false)
Get a Database object.
wfTimestamp( $outputtype=TS_UNIX, $ts=0)
Get a timestamp string in one of various formats.
This class represents the result of the API operations.
getUrl()
Return the URL of the file.
static userLink( $userId, $userName, $altUserName=false)
Make user link (or user contributions for unregistered users)
static commentBlock( $comment, $title=null, $local=false, $wikiId=null, $useParentheses=true)
Wrap a comment in standard punctuation and formatting if it's non-empty, otherwise return empty strin...
static userToolLinks( $userId, $userText, $redContribsWhenNoEdits=false, $flags=0, $edits=null, $useParentheses=true)
Generate standard user tool links (talk, contributions, block link, etc.)
getWidth( $page=1)
Return the width of the image.
getUploader(int $audience=self::FOR_PUBLIC, Authority $performer=null)
getSize()
Returns the size of the image file, in bytes.
getDescription( $audience=self::FOR_PUBLIC, Authority $performer=null)
getHeight( $page=1)
Return the height of the image.
Class to represent a file in the oldimage table.
Item class for an oldimage table row.
getTimestampField()
Get the DB field name storing timestamps.
getComment()
Wrap and format the file's comment block, if the current user is allowed to view it.
getLink()
Get the link to the file.
canViewContent()
Returns true if the current user can view the item text/file.
getId()
Get the ID, as it would appear in the ids URL parameter.
getIdField()
Get the DB field name associated with the ID list.
getBits()
Get the current deletion bitfield value.
getAuthorIdField()
Get the DB field name storing user ids.
static initFile( $list, $row)
Create file object from $row sourced from $list.
getHTML()
Get the HTML of the list item.
getUserTools()
Generate a user tool link cluster if the current user is allowed to view it.
__construct(RevisionListBase $list, $row)
unlock()
Unlock the item against changes outside of the DB.
getAuthorNameField()
Get the DB field name storing user names.
lock()
Lock the item against changes outside of the DB.
canView()
Returns true if the current user can view the item.
getAuthorActorField()
Get the DB field name storing actor ids.
setBits( $bits)
Set the visibility of the item.
getApiData(ApiResult $result)
Get the return information about the revision for the API.
List for oldimage table items.
Abstract base class for deletable items.
stdClass $row
The database result row.
getLinkRenderer()
Returns an instance of LinkRenderer.
List for revision table items for a single page.
static getTitleFor( $name, $subpage=false, $fragment='')
Get a localised Title object for a specified special page name If you don't need a full Title object,...