123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367 |
- <?php
- /**
- * @ingroup Media
- */
- class ArchivedFile
- {
- /**#@+
- * @private
- */
- var $id, # filearchive row ID
- $title, # image title
- $name, # image name
- $group, # FileStore storage group
- $key, # FileStore sha1 key
- $size, # file dimensions
- $bits, # size in bytes
- $width, # width
- $height, # height
- $metadata, # metadata string
- $mime, # mime type
- $media_type, # media type
- $description, # upload description
- $user, # user ID of uploader
- $user_text, # user name of uploader
- $timestamp, # time of upload
- $dataLoaded, # Whether or not all this has been loaded from the database (loadFromXxx)
- $deleted; # Bitfield akin to rev_deleted
- /**#@-*/
- function ArchivedFile( $title, $id=0, $key='' ) {
- $this->id = -1;
- $this->title = false;
- $this->name = false;
- $this->group = '';
- $this->key = '';
- $this->size = 0;
- $this->bits = 0;
- $this->width = 0;
- $this->height = 0;
- $this->metadata = '';
- $this->mime = "unknown/unknown";
- $this->media_type = '';
- $this->description = '';
- $this->user = 0;
- $this->user_text = '';
- $this->timestamp = NULL;
- $this->deleted = 0;
- $this->dataLoaded = false;
-
- if( is_object($title) ) {
- $this->title = $title;
- $this->name = $title->getDBkey();
- }
-
- if ($id)
- $this->id = $id;
-
- if ($key)
- $this->key = $key;
-
- if (!$id && !$key && !is_object($title))
- throw new MWException( "No specifications provided to ArchivedFile constructor." );
- }
- /**
- * Loads a file object from the filearchive table
- * @return ResultWrapper
- */
- public function load() {
- if ( $this->dataLoaded ) {
- return true;
- }
- $conds = array();
-
- if( $this->id > 0 )
- $conds['fa_id'] = $this->id;
- if( $this->key ) {
- $conds['fa_storage_group'] = $this->group;
- $conds['fa_storage_key'] = $this->key;
- }
- if( $this->title )
- $conds['fa_name'] = $this->title->getDBkey();
-
- if( !count($conds))
- throw new MWException( "No specific information for retrieving archived file" );
-
- if( !$this->title || $this->title->getNamespace() == NS_FILE ) {
- $dbr = wfGetDB( DB_SLAVE );
- $res = $dbr->select( 'filearchive',
- array(
- 'fa_id',
- 'fa_name',
- 'fa_archive_name',
- 'fa_storage_key',
- 'fa_storage_group',
- 'fa_size',
- 'fa_bits',
- 'fa_width',
- 'fa_height',
- 'fa_metadata',
- 'fa_media_type',
- 'fa_major_mime',
- 'fa_minor_mime',
- 'fa_description',
- 'fa_user',
- 'fa_user_text',
- 'fa_timestamp',
- 'fa_deleted' ),
- $conds,
- __METHOD__,
- array( 'ORDER BY' => 'fa_timestamp DESC' ) );
- if ( $dbr->numRows( $res ) == 0 ) {
- // this revision does not exist?
- return;
- }
- $ret = $dbr->resultObject( $res );
- $row = $ret->fetchObject();
- // initialize fields for filestore image object
- $this->id = intval($row->fa_id);
- $this->name = $row->fa_name;
- $this->archive_name = $row->fa_archive_name;
- $this->group = $row->fa_storage_group;
- $this->key = $row->fa_storage_key;
- $this->size = $row->fa_size;
- $this->bits = $row->fa_bits;
- $this->width = $row->fa_width;
- $this->height = $row->fa_height;
- $this->metadata = $row->fa_metadata;
- $this->mime = "$row->fa_major_mime/$row->fa_minor_mime";
- $this->media_type = $row->fa_media_type;
- $this->description = $row->fa_description;
- $this->user = $row->fa_user;
- $this->user_text = $row->fa_user_text;
- $this->timestamp = $row->fa_timestamp;
- $this->deleted = $row->fa_deleted;
- } else {
- throw new MWException( 'This title does not correspond to an image page.' );
- return;
- }
- $this->dataLoaded = true;
- return true;
- }
- /**
- * Loads a file object from the filearchive table
- * @return ResultWrapper
- */
- public static function newFromRow( $row ) {
- $file = new ArchivedFile( Title::makeTitle( NS_FILE, $row->fa_name ) );
- $file->id = intval($row->fa_id);
- $file->name = $row->fa_name;
- $file->archive_name = $row->fa_archive_name;
- $file->group = $row->fa_storage_group;
- $file->key = $row->fa_storage_key;
- $file->size = $row->fa_size;
- $file->bits = $row->fa_bits;
- $file->width = $row->fa_width;
- $file->height = $row->fa_height;
- $file->metadata = $row->fa_metadata;
- $file->mime = "$row->fa_major_mime/$row->fa_minor_mime";
- $file->media_type = $row->fa_media_type;
- $file->description = $row->fa_description;
- $file->user = $row->fa_user;
- $file->user_text = $row->fa_user_text;
- $file->timestamp = $row->fa_timestamp;
- $file->deleted = $row->fa_deleted;
- return $file;
- }
- /**
- * Return the associated title object
- * @public
- */
- public function getTitle() {
- return $this->title;
- }
- /**
- * Return the file name
- */
- public function getName() {
- return $this->name;
- }
- public function getID() {
- $this->load();
- return $this->id;
- }
- /**
- * Return the FileStore key
- */
- public function getKey() {
- $this->load();
- return $this->key;
- }
- /**
- * Return the FileStore storage group
- */
- public function getGroup() {
- return $file->group;
- }
- /**
- * Return the width of the image
- */
- public function getWidth() {
- $this->load();
- return $this->width;
- }
- /**
- * Return the height of the image
- */
- public function getHeight() {
- $this->load();
- return $this->height;
- }
- /**
- * Get handler-specific metadata
- */
- public function getMetadata() {
- $this->load();
- return $this->metadata;
- }
- /**
- * Return the size of the image file, in bytes
- * @public
- */
- public function getSize() {
- $this->load();
- return $this->size;
- }
- /**
- * Return the bits of the image file, in bytes
- * @public
- */
- public function getBits() {
- $this->load();
- return $this->bits;
- }
- /**
- * Returns the mime type of the file.
- */
- public function getMimeType() {
- $this->load();
- return $this->mime;
- }
- /**
- * Return the type of the media in the file.
- * Use the value returned by this function with the MEDIATYPE_xxx constants.
- */
- public function getMediaType() {
- $this->load();
- return $this->media_type;
- }
- /**
- * Return upload timestamp.
- */
- public function getTimestamp() {
- $this->load();
- return wfTimestamp( TS_MW, $this->timestamp );
- }
- /**
- * Return the user ID of the uploader.
- */
- public function getUser() {
- $this->load();
- if( $this->isDeleted( File::DELETED_USER ) ) {
- return 0;
- } else {
- return $this->user;
- }
- }
- /**
- * Return the user name of the uploader.
- */
- public function getUserText() {
- $this->load();
- if( $this->isDeleted( File::DELETED_USER ) ) {
- return 0;
- } else {
- return $this->user_text;
- }
- }
- /**
- * Return upload description.
- */
- public function getDescription() {
- $this->load();
- if( $this->isDeleted( File::DELETED_COMMENT ) ) {
- return 0;
- } else {
- return $this->description;
- }
- }
- /**
- * Return the user ID of the uploader.
- */
- public function getRawUser() {
- $this->load();
- return $this->user;
- }
- /**
- * Return the user name of the uploader.
- */
- public function getRawUserText() {
- $this->load();
- return $this->user_text;
- }
- /**
- * Return upload description.
- */
- public function getRawDescription() {
- $this->load();
- return $this->description;
- }
- /**
- * int $field one of DELETED_* bitfield constants
- * for file or revision rows
- * @return bool
- */
- public function isDeleted( $field ) {
- return ($this->deleted & $field) == $field;
- }
- /**
- * Determine if the current user is allowed to view a particular
- * field of this FileStore image file, if it's marked as deleted.
- * @param int $field
- * @return bool
- */
- public function userCan( $field ) {
- if( ($this->deleted & $field) == $field ) {
- global $wgUser;
- $permission = ( $this->deleted & File::DELETED_RESTRICTED ) == File::DELETED_RESTRICTED
- ? 'suppressrevision'
- : 'deleterevision';
- wfDebug( "Checking for $permission due to $field match on $this->deleted\n" );
- return $wgUser->isAllowed( $permission );
- } else {
- return true;
- }
- }
- }
|