MediaWiki REL1_34
ForeignAPIFile.php
Go to the documentation of this file.
1<?php
25
32class ForeignAPIFile extends File {
34 private $mExists;
36 private $mInfo = [];
37
38 protected $repoClass = ForeignAPIRepo::class;
39
46 function __construct( $title, $repo, $info, $exists = false ) {
47 parent::__construct( $title, $repo );
48
49 $this->mInfo = $info;
50 $this->mExists = $exists;
51
52 $this->assertRepoDefined();
53 }
54
60 static function newFromTitle( Title $title, $repo ) {
61 $data = $repo->fetchImageQuery( [
62 'titles' => 'File:' . $title->getDBkey(),
63 'iiprop' => self::getProps(),
64 'prop' => 'imageinfo',
65 'iimetadataversion' => MediaHandler::getMetadataVersion(),
66 // extmetadata is language-dependant, accessing the current language here
67 // would be problematic, so we just get them all
68 'iiextmetadatamultilang' => 1,
69 ] );
70
71 $info = $repo->getImageInfo( $data );
72
73 if ( $info ) {
74 $lastRedirect = isset( $data['query']['redirects'] )
75 ? count( $data['query']['redirects'] ) - 1
76 : -1;
77 if ( $lastRedirect >= 0 ) {
78 $newtitle = Title::newFromText( $data['query']['redirects'][$lastRedirect]['to'] );
79 $img = new self( $newtitle, $repo, $info, true );
80 $img->redirectedFrom( $title->getDBkey() );
81 } else {
82 $img = new self( $title, $repo, $info, true );
83 }
84
85 return $img;
86 } else {
87 return null;
88 }
89 }
90
95 static function getProps() {
96 return 'timestamp|user|comment|url|size|sha1|metadata|mime|mediatype|extmetadata';
97 }
98
99 // Dummy functions...
100
104 public function exists() {
105 return $this->mExists;
106 }
107
111 public function getPath() {
112 return false;
113 }
114
120 function transform( $params, $flags = 0 ) {
121 if ( !$this->canRender() ) {
122 // show icon
123 return parent::transform( $params, $flags );
124 }
125
126 // Note, the this->canRender() check above implies
127 // that we have a handler, and it can do makeParamString.
128 $otherParams = $this->handler->makeParamString( $params );
129 $width = $params['width'] ?? -1;
130 $height = $params['height'] ?? -1;
131
132 $thumbUrl = $this->repo->getThumbUrlFromCache(
133 $this->getName(),
134 $width,
135 $height,
136 $otherParams
137 );
138 if ( $thumbUrl === false ) {
139 global $wgLang;
140
141 return $this->repo->getThumbError(
142 $this->getName(),
143 $width,
144 $height,
145 $otherParams,
146 $wgLang->getCode()
147 );
148 }
149
150 return $this->handler->getTransform( $this, 'bogus', $thumbUrl, $params );
151 }
152
153 // Info we can get from API...
154
159 public function getWidth( $page = 1 ) {
160 return isset( $this->mInfo['width'] ) ? intval( $this->mInfo['width'] ) : 0;
161 }
162
167 public function getHeight( $page = 1 ) {
168 return isset( $this->mInfo['height'] ) ? intval( $this->mInfo['height'] ) : 0;
169 }
170
174 public function getMetadata() {
175 if ( isset( $this->mInfo['metadata'] ) ) {
176 return serialize( self::parseMetadata( $this->mInfo['metadata'] ) );
177 }
178
179 return null;
180 }
181
186 public function getExtendedMetadata() {
187 return $this->mInfo['extmetadata'] ?? null;
188 }
189
194 public static function parseMetadata( $metadata ) {
195 if ( !is_array( $metadata ) ) {
196 return $metadata;
197 }
198 $ret = [];
199 foreach ( $metadata as $meta ) {
200 $ret[$meta['name']] = self::parseMetadata( $meta['value'] );
201 }
202
203 return $ret;
204 }
205
209 public function getSize() {
210 return isset( $this->mInfo['size'] ) ? intval( $this->mInfo['size'] ) : null;
211 }
212
216 public function getUrl() {
217 return isset( $this->mInfo['url'] ) ? strval( $this->mInfo['url'] ) : null;
218 }
219
227 public function getDescriptionShortUrl() {
228 if ( isset( $this->mInfo['descriptionshorturl'] ) ) {
229 return $this->mInfo['descriptionshorturl'];
230 } elseif ( isset( $this->mInfo['pageid'] ) ) {
231 $url = $this->repo->makeUrl( [ 'curid' => $this->mInfo['pageid'] ] );
232 if ( $url !== false ) {
233 return $url;
234 }
235 }
236 return null;
237 }
238
243 public function getUser( $type = 'text' ) {
244 if ( $type == 'text' ) {
245 return isset( $this->mInfo['user'] ) ? strval( $this->mInfo['user'] ) : null;
246 } else {
247 return 0; // What makes sense here, for a remote user?
248 }
249 }
250
256 public function getDescription( $audience = self::FOR_PUBLIC, User $user = null ) {
257 return isset( $this->mInfo['comment'] ) ? strval( $this->mInfo['comment'] ) : null;
258 }
259
263 function getSha1() {
264 return isset( $this->mInfo['sha1'] )
265 ? Wikimedia\base_convert( strval( $this->mInfo['sha1'] ), 16, 36, 31 )
266 : null;
267 }
268
272 function getTimestamp() {
273 return wfTimestamp( TS_MW,
274 isset( $this->mInfo['timestamp'] )
275 ? strval( $this->mInfo['timestamp'] )
276 : null
277 );
278 }
279
283 function getMimeType() {
284 if ( !isset( $this->mInfo['mime'] ) ) {
285 $magic = MediaWiki\MediaWikiServices::getInstance()->getMimeAnalyzer();
286 $this->mInfo['mime'] = $magic->guessTypesForExtension( $this->getExtension() );
287 }
288
289 return $this->mInfo['mime'];
290 }
291
295 function getMediaType() {
296 if ( isset( $this->mInfo['mediatype'] ) ) {
297 return $this->mInfo['mediatype'];
298 }
299 $magic = MediaWiki\MediaWikiServices::getInstance()->getMimeAnalyzer();
300
301 return $magic->getMediaType( null, $this->getMimeType() );
302 }
303
307 function getDescriptionUrl() {
308 return $this->mInfo['descriptionurl'] ?? false;
309 }
310
316 function getThumbPath( $suffix = '' ) {
317 if ( !$this->repo->canCacheThumbs() ) {
318 return null;
319 }
320
321 $path = $this->repo->getZonePath( 'thumb' ) . '/' . $this->getHashPath();
322 if ( $suffix ) {
323 $path .= $suffix . '/';
324 }
325 return $path;
326 }
327
331 function getThumbnails() {
332 $dir = $this->getThumbPath( $this->getName() );
333 $iter = $this->repo->getBackend()->getFileList( [ 'dir' => $dir ] );
334
335 $files = [];
336 if ( $iter ) {
337 foreach ( $iter as $file ) {
338 $files[] = $file;
339 }
340 }
341
342 return $files;
343 }
344
345 function purgeCache( $options = [] ) {
346 $this->purgeThumbnails( $options );
347 $this->purgeDescriptionPage();
348 }
349
351 $services = MediaWikiServices::getInstance();
352 $url = $this->repo->getDescriptionRenderUrl(
353 $this->getName(), $services->getContentLanguage()->getCode() );
354 $key = $this->repo->getLocalCacheKey( 'RemoteFileDescription', 'url', md5( $url ) );
355
356 $services->getMainWANObjectCache()->delete( $key );
357 }
358
362 function purgeThumbnails( $options = [] ) {
363 $key = $this->repo->getLocalCacheKey( 'ForeignAPIRepo', 'ThumbUrl', $this->getName() );
364 MediaWikiServices::getInstance()->getMainWANObjectCache()->delete( $key );
365
366 $files = $this->getThumbnails();
367 // Give media handler a chance to filter the purge list
368 $handler = $this->getHandler();
369 if ( $handler ) {
370 $handler->filterThumbnailPurgeList( $files, $options );
371 }
372
373 $dir = $this->getThumbPath( $this->getName() );
374 $purgeList = [];
375 foreach ( $files as $file ) {
376 $purgeList[] = "{$dir}{$file}";
377 }
378
379 # Delete the thumbnails
380 $this->repo->quickPurgeBatch( $purgeList );
381 # Clear out the thumbnail directory if empty
382 $this->repo->quickCleanDir( $dir );
383 }
384
390 public function isTransformedLocally() {
391 return false;
392 }
393}
serialize()
wfTimestamp( $outputtype=TS_UNIX, $ts=0)
Get a timestamp string in one of various formats.
$wgLang
Definition Setup.php:880
Implements some public methods and some protected utility functions which are required by multiple ch...
Definition File.php:61
string $url
The URL corresponding to one of the four basic zones.
Definition File.php:127
MediaHandler $handler
Definition File.php:124
assertRepoDefined()
Assert that $this->repo is set to a valid FileRepo instance.
Definition File.php:2284
getName()
Return the name of this file.
Definition File.php:307
canRender()
Checks if the output of transform() for this file is likely to be valid.
Definition File.php:758
getExtension()
Get the file extension, e.g.
Definition File.php:321
FileRepo LocalRepo ForeignAPIRepo bool $repo
Some member variables can be lazy-initialised using __get().
Definition File.php:106
string $path
The storage path corresponding to one of the zones.
Definition File.php:136
Title string bool $title
Definition File.php:109
getHandler()
Get a MediaHandler instance for this file.
Definition File.php:1390
getHashPath()
Get the filename hash component of the directory including trailing slash, e.g.
Definition File.php:1526
Foreign file accessible through api.php requests.
getThumbPath( $suffix='')
Only useful if we're locally caching thumbs anyway...
__construct( $title, $repo, $info, $exists=false)
purgeCache( $options=[])
Purge shared caches such as thumbnails and DB data caching STUB Overridden by LocalFile.
isTransformedLocally()
The thumbnail is created on the foreign server and fetched over internet.
static parseMetadata( $metadata)
static newFromTitle(Title $title, $repo)
getUser( $type='text')
purgeThumbnails( $options=[])
getDescription( $audience=self::FOR_PUBLIC, User $user=null)
transform( $params, $flags=0)
getDescriptionShortUrl()
Get short description URL for a file based on the foreign API response, or if unavailable,...
static getProps()
Get the property string for iiprop and aiprop.
filterThumbnailPurgeList(&$files, $options)
Remove files from the purge list.
static getMetadataVersion()
Get metadata version.
MediaWikiServices is the service locator for the application scope of MediaWiki.
Represents a title within MediaWiki.
Definition Title.php:42
getDBkey()
Get the main part with underscores.
Definition Title.php:1013
The User object encapsulates all of the user-specific settings (user_id, name, rights,...
Definition User.php:51
return true
Definition router.php:94
if(PHP_SAPI !='cli-server') if(!isset( $_SERVER['SCRIPT_FILENAME'])) $file
Item class for a filearchive table row.
Definition router.php:42