| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  | // This file is part of GNU social - https://www.gnu.org/software/social
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // GNU social is free software: you can redistribute it and/or modify
 | 
					
						
							|  |  |  | // it under the terms of the GNU Affero General Public License as published by
 | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or
 | 
					
						
							|  |  |  | // (at your option) any later version.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // GNU social 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 Affero General Public License for more details.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU Affero General Public License
 | 
					
						
							|  |  |  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  | /* | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |  * @copyright 2008-2009 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | 
					
						
							| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  | defined('GNUSOCIAL') || die(); | 
					
						
							| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Table Definition for file_thumbnail | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  | class File_thumbnail extends Managed_DataObject | 
					
						
							| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  | { | 
					
						
							|  |  |  |     public $__table = 'file_thumbnail';                  // table name
 | 
					
						
							| 
									
										
										
										
											2009-06-22 14:19:41 -07:00
										 |  |  |     public $file_id;                         // int(4)  primary_key not_null
 | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  |     public $urlhash;                         // varchar(64) indexed
 | 
					
						
							| 
									
										
										
										
											2015-02-19 18:59:13 +01:00
										 |  |  |     public $url;                             // text
 | 
					
						
							| 
									
										
										
										
											2015-04-10 22:16:44 +02:00
										 |  |  |     public $filename;                        // text
 | 
					
						
							| 
									
										
										
										
											2014-04-21 20:39:28 +02:00
										 |  |  |     public $width;                           // int(4)  primary_key
 | 
					
						
							|  |  |  |     public $height;                          // int(4)  primary_key
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public $modified;                        // timestamp() not_null default_CURRENT_TIMESTAMP
 | 
					
						
							| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  |     const URLHASH_ALG = 'sha256'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |     public static function schemaDef() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return array( | 
					
						
							|  |  |  |             'fields' => array( | 
					
						
							|  |  |  |                 'file_id' => array('type' => 'int', 'not null' => true, 'description' => 'thumbnail for what URL/file'), | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  |                 'urlhash' => array('type' => 'varchar', 'length' => 64, 'description' => 'sha256 of url field if non-empty'), | 
					
						
							| 
									
										
										
										
											2016-01-06 19:06:29 +01:00
										 |  |  |                 'url' => array('type' => 'text', 'description' => 'URL of thumbnail'), | 
					
						
							| 
									
										
										
										
											2015-04-10 22:16:44 +02:00
										 |  |  |                 'filename' => array('type' => 'text', 'description' => 'if stored locally, filename is put here'), | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |                 'width' => array('type' => 'int', 'not null' => true, 'description' => 'width of thumbnail'), | 
					
						
							|  |  |  |                 'height' => array('type' => 'int', 'not null' => true, 'description' => 'height of thumbnail'), | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |                 'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'), | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |             ), | 
					
						
							| 
									
										
										
										
											2014-04-21 20:39:28 +02:00
										 |  |  |             'primary key' => array('file_id', 'width', 'height'), | 
					
						
							|  |  |  |             'indexes' => array( | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  |                 'file_thumbnail_urlhash_idx' => array('urlhash'), | 
					
						
							| 
									
										
										
										
											2014-04-21 20:39:28 +02:00
										 |  |  |             ), | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |             'foreign keys' => array( | 
					
						
							|  |  |  |                 'file_thumbnail_file_id_fkey' => array('file', array('file_id' => 'id')), | 
					
						
							| 
									
										
										
										
											2011-09-28 15:48:20 -04:00
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-21 21:54:23 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the attachment's thumbnail record, if any or generate one. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param File $file | 
					
						
							|  |  |  |      * @param int|null $width    Max width of thumbnail in pixels. (if null, use common_config values) | 
					
						
							|  |  |  |      * @param int|null $height   Max height of thumbnail in pixels. (if null, square-crop to $width) | 
					
						
							|  |  |  |      * @param bool $crop         Crop to the max-values' aspect ratio | 
					
						
							|  |  |  |      * @param bool $force_still  Don't allow fallback to showing original (such as animated GIF) | 
					
						
							|  |  |  |      * @param bool|null $upscale Whether or not to scale smaller images up to larger thumbnail sizes. (null = site default) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return File_thumbnail | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @throws ClientException | 
					
						
							|  |  |  |      * @throws FileNotFoundException | 
					
						
							|  |  |  |      * @throws FileNotStoredLocallyException | 
					
						
							|  |  |  |      * @throws InvalidFilenameException | 
					
						
							|  |  |  |      * @throws NoResultException | 
					
						
							|  |  |  |      * @throws ServerException on various other errors | 
					
						
							|  |  |  |      * @throws UnsupportedMediaException if, despite trying, we can't understand how to make a thumbnail for this format | 
					
						
							|  |  |  |      * @throws UseFileAsThumbnailException if the file is considered an image itself and should be itself as thumbnail | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-09-21 21:37:21 +01:00
										 |  |  |     public static function fromFileObject( | 
					
						
							|  |  |  |         File $file, | 
					
						
							|  |  |  |         ?int $width = null, | 
					
						
							|  |  |  |         ?int $height = null, | 
					
						
							|  |  |  |         bool $crop = false, | 
					
						
							|  |  |  |         bool $force_still = true, | 
					
						
							|  |  |  |         ?bool $upscale = null | 
					
						
							|  |  |  |     ): File_thumbnail { | 
					
						
							| 
									
										
										
										
											2021-02-16 18:30:21 +00:00
										 |  |  |         if ($file->isStoredRemotely()) {  // Remote file
 | 
					
						
							|  |  |  |             // If StoreRemoteMedia or Embed are enabled...
 | 
					
						
							| 
									
										
										
										
											2020-09-21 21:37:21 +01:00
										 |  |  |             if (Event::handle('CreateFileImageThumbnailSource', [$file, &$imgPath, 'image'])) { | 
					
						
							|  |  |  |                 if (!file_exists($imgPath)) { | 
					
						
							|  |  |  |                     throw new FileNotFoundException($imgPath); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // First some mimetype specific exceptions
 | 
					
						
							|  |  |  |                 switch ($file->mimetype) { | 
					
						
							|  |  |  |                     case 'image/svg+xml': | 
					
						
							|  |  |  |                         throw new UseFileAsThumbnailException($file); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-02-17 09:48:24 +00:00
										 |  |  |             } else { | 
					
						
							|  |  |  |                 throw new ServerException("This remote file has no local thumbnail."); | 
					
						
							| 
									
										
										
										
											2020-09-21 21:37:21 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-09-21 21:54:23 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |         $image = ImageFile::fromFileObject($file); | 
					
						
							|  |  |  |         $imgPath = $image->getPath(); | 
					
						
							|  |  |  |         $media = common_get_mime_media($file->mimetype); | 
					
						
							|  |  |  |         if (Event::handle('CreateFileImageThumbnailSource', [$file, &$imgPath, $media])) { | 
					
						
							|  |  |  |             if (!file_exists($imgPath)) { | 
					
						
							|  |  |  |                 throw new FileNotFoundException($imgPath); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // First some mimetype specific exceptions
 | 
					
						
							|  |  |  |             switch ($file->mimetype) { | 
					
						
							|  |  |  |                 case 'image/svg+xml': | 
					
						
							|  |  |  |                     throw new UseFileAsThumbnailException($file); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($image->animated && !common_config('thumbnail', 'animated')) { | 
					
						
							|  |  |  |             // null  means "always use file as thumbnail"
 | 
					
						
							|  |  |  |             // false means you get choice between frozen frame or original when calling getThumbnail
 | 
					
						
							|  |  |  |             if (is_null(common_config('thumbnail', 'animated')) || !$force_still) { | 
					
						
							|  |  |  |                 try { | 
					
						
							|  |  |  |                     // remote files with animated GIFs as thumbnails will match this
 | 
					
						
							|  |  |  |                     return File_thumbnail::byFile($file); | 
					
						
							|  |  |  |                 } catch (NoResultException $e) { | 
					
						
							|  |  |  |                     // and if it's not a remote file, it'll be safe to use the locally stored File
 | 
					
						
							|  |  |  |                     throw new UseFileAsThumbnailException($file); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $image->getFileThumbnail( | 
					
						
							|  |  |  |             $width, | 
					
						
							|  |  |  |             $height, | 
					
						
							|  |  |  |             $crop, | 
					
						
							|  |  |  |             !is_null($upscale) ? $upscale : common_config('thumbnail', 'upscale') | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 17:20:04 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Save oEmbed-provided thumbnail data | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param object $data | 
					
						
							|  |  |  |      * @param int $file_id | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |     public static function saveNew($data, $file_id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-11-12 14:03:08 -08:00
										 |  |  |         if (!empty($data->thumbnail_url)) { | 
					
						
							|  |  |  |             // Non-photo types such as video will usually
 | 
					
						
							|  |  |  |             // show us a thumbnail, though it's not required.
 | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |             self::saveThumbnail( | 
					
						
							|  |  |  |                 $file_id, | 
					
						
							|  |  |  |                 $data->thumbnail_url, | 
					
						
							|  |  |  |                 $data->thumbnail_width, | 
					
						
							|  |  |  |                 $data->thumbnail_height | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } elseif ($data->type == 'photo') { | 
					
						
							| 
									
										
										
										
											2010-11-12 14:03:08 -08:00
										 |  |  |             // The inline photo URL given should also fit within
 | 
					
						
							|  |  |  |             // our requested thumbnail size, per oEmbed spec.
 | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |             self::saveThumbnail( | 
					
						
							|  |  |  |                 $file_id, | 
					
						
							|  |  |  |                 $data->url, | 
					
						
							|  |  |  |                 $data->width, | 
					
						
							|  |  |  |                 $data->height | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2010-11-12 14:03:08 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-11-08 17:20:04 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 02:32:57 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Fetch an entry by using a File's id | 
					
						
							| 
									
										
										
										
											2016-02-10 04:37:43 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @param   File    $file       The File object we're getting a thumbnail for. | 
					
						
							|  |  |  |      * @param   boolean $notNullUrl Originally remote thumbnails have a URL stored, we use this to find the "original" | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return  File_thumbnail | 
					
						
							|  |  |  |      * @throws  NoResultException if no File_thumbnail matched the criteria | 
					
						
							| 
									
										
										
										
											2015-01-25 02:32:57 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |     public static function byFile(File $file, $notNullUrl = true) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-10 04:37:43 +01:00
										 |  |  |         $thumb = new File_thumbnail(); | 
					
						
							|  |  |  |         $thumb->file_id = $file->getID(); | 
					
						
							|  |  |  |         if ($notNullUrl) { | 
					
						
							|  |  |  |             $thumb->whereAdd('url IS NOT NULL'); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-07-21 00:37:43 +02:00
										 |  |  |         $thumb->orderBy('modified ASC');    // the first created, a somewhat ugly hack
 | 
					
						
							| 
									
										
										
										
											2016-02-10 04:37:43 +01:00
										 |  |  |         $thumb->limit(1); | 
					
						
							|  |  |  |         if (!$thumb->find(true)) { | 
					
						
							|  |  |  |             throw new NoResultException($thumb); | 
					
						
							| 
									
										
										
										
											2015-01-25 02:32:57 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-10 04:37:43 +01:00
										 |  |  |         return $thumb; | 
					
						
							| 
									
										
										
										
											2015-01-25 02:32:57 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 17:20:04 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Save a thumbnail record for the referenced file record. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2014-04-16 19:14:26 +02:00
										 |  |  |      * FIXME: Add error handling | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-11-08 17:20:04 -08:00
										 |  |  |      * @param int $file_id | 
					
						
							|  |  |  |      * @param string $url | 
					
						
							|  |  |  |      * @param int $width | 
					
						
							|  |  |  |      * @param int $height | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |     public static function saveThumbnail($file_id, $url, $width, $height, $filename = null) | 
					
						
							| 
									
										
										
										
											2010-11-08 17:20:04 -08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-05-15 15:04:58 -04:00
										 |  |  |         $tn = new File_thumbnail; | 
					
						
							|  |  |  |         $tn->file_id = $file_id; | 
					
						
							| 
									
										
										
										
											2010-11-08 17:20:04 -08:00
										 |  |  |         $tn->url = $url; | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |         $tn->filename = $filename; | 
					
						
							| 
									
										
										
										
											2020-09-21 21:54:23 +01:00
										 |  |  |         $tn->width = (int)$width; | 
					
						
							|  |  |  |         $tn->height = (int)$height; | 
					
						
							| 
									
										
										
										
											2009-05-15 15:04:58 -04:00
										 |  |  |         $tn->insert(); | 
					
						
							| 
									
										
										
										
											2014-04-21 20:39:28 +02:00
										 |  |  |         return $tn; | 
					
						
							| 
									
										
										
										
											2009-05-15 15:04:58 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-04-18 23:06:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-16 18:30:21 +00:00
										 |  |  |     public static function path($filename): string | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |         File::tryFilename($filename); | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |         // NOTE: If this is left empty in default config, it will be set to File::path('thumb')
 | 
					
						
							| 
									
										
										
										
											2016-03-07 22:55:52 +01:00
										 |  |  |         $dir = common_config('thumbnail', 'dir'); | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (!in_array($dir[mb_strlen($dir)-1], ['/', '\\'])) { | 
					
						
							|  |  |  |             $dir .= DIRECTORY_SEPARATOR; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $dir . $filename; | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  |     public function getFilename() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |         return File::tryFilename($this->filename); | 
					
						
							| 
									
										
										
										
											2015-03-04 13:13:04 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return  string  full filesystem path to the locally stored thumbnail file | 
					
						
							| 
									
										
										
										
											2019-06-30 15:24:11 +01:00
										 |  |  |      * @throws FileNotFoundException | 
					
						
							|  |  |  |      * @throws ServerException | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-02-16 18:30:21 +00:00
										 |  |  |     public function getPath(): string | 
					
						
							| 
									
										
										
										
											2015-01-25 02:32:57 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  |         $oldpath = File::path($this->getFilename()); | 
					
						
							|  |  |  |         $thumbpath = self::path($this->getFilename()); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |         // If we have a file in our old thumbnail storage path, move (or copy) it to the new one
 | 
					
						
							|  |  |  |         // (if the if/elseif don't match, we have a $thumbpath just as we should and can return it)
 | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  |         if (file_exists($oldpath) && !file_exists($thumbpath)) { | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |             try { | 
					
						
							|  |  |  |                 // let's get the filename of the File, to check below if it happens to be identical
 | 
					
						
							|  |  |  |                 $file_filename = $this->getFile()->getFilename(); | 
					
						
							|  |  |  |             } catch (NoResultException $e) { | 
					
						
							|  |  |  |                 // reasonably the function calling us will handle the following as "File_thumbnail entry should be deleted"
 | 
					
						
							| 
									
										
										
										
											2016-03-10 13:46:19 +01:00
										 |  |  |                 throw new FileNotFoundException($thumbpath); | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |             } catch (InvalidFilenameException $e) { | 
					
						
							|  |  |  |                 // invalid filename in getFile()->getFilename(), just
 | 
					
						
							|  |  |  |                 // means the File object isn't stored locally and that
 | 
					
						
							|  |  |  |                 // means it's safe to move it below.
 | 
					
						
							|  |  |  |                 $file_filename = null; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($this->getFilename() === $file_filename) { | 
					
						
							| 
									
										
										
										
											2016-03-08 01:59:58 +01:00
										 |  |  |                 // special case where thumbnail file exactly matches stored File filename
 | 
					
						
							|  |  |  |                 common_debug('File filename and File_thumbnail filename match on '.$this->file_id.', copying instead'); | 
					
						
							|  |  |  |                 copy($oldpath, $thumbpath); | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  |             } elseif (!rename($oldpath, $thumbpath)) { | 
					
						
							|  |  |  |                 common_log(LOG_ERR, 'Could not move thumbnail from '._ve($oldpath).' to '._ve($thumbpath)); | 
					
						
							|  |  |  |                 throw new ServerException('Could not move thumbnail from old path to new path.'); | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 common_log(LOG_DEBUG, 'Moved thumbnail '.$this->file_id.' from '._ve($oldpath).' to '._ve($thumbpath)); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } elseif (!file_exists($thumbpath)) { | 
					
						
							|  |  |  |             throw new FileNotFoundException($thumbpath); | 
					
						
							| 
									
										
										
										
											2015-02-24 21:11:25 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-07 22:33:34 +01:00
										 |  |  |         return $thumbpath; | 
					
						
							| 
									
										
										
										
											2015-01-25 02:32:57 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-18 23:06:28 +02:00
										 |  |  |     public function getUrl() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-09-21 21:54:23 +01:00
										 |  |  |         $url = common_local_url('attachment_thumbnail', ['filehash' => $this->getFile()->filehash]); | 
					
						
							|  |  |  |         if (strpos($url, '?') === false) { | 
					
						
							|  |  |  |             $url .= '?'; | 
					
						
							| 
									
										
										
										
											2015-01-12 19:22:10 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-09-21 21:54:23 +01:00
										 |  |  |         return $url . http_build_query(['w'=>$this->width, 'h'=>$this->height]); | 
					
						
							| 
									
										
										
										
											2014-04-18 23:06:28 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-01 14:13:16 +01:00
										 |  |  |     public function getHeight() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->height; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getWidth() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->width; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-06 19:06:29 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @throws UseFileAsThumbnailException from File_thumbnail->getUrl() for stuff like animated GIFs | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-01-01 14:13:16 +01:00
										 |  |  |     public function getHtmlAttrs(array $orig=array(), $overwrite=true) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-07-11 23:49:16 +01:00
										 |  |  |         $attrs = [ 'height' => $this->getHeight(), | 
					
						
							|  |  |  |                    'width'  => $this->getWidth(), | 
					
						
							|  |  |  |                    'src'    => $this->getUrl() ]; | 
					
						
							| 
									
										
										
										
											2016-01-01 14:13:16 +01:00
										 |  |  |         return $overwrite ? array_merge($orig, $attrs) : array_merge($attrs, $orig); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |     public function delete($useWhere=false) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |         try { | 
					
						
							|  |  |  |             $thumbpath = self::path($this->getFilename()); | 
					
						
							|  |  |  |             // if file does not exist, try to delete it
 | 
					
						
							|  |  |  |             $deleted = !file_exists($thumbpath) || @unlink($thumbpath); | 
					
						
							|  |  |  |             if (!$deleted) { | 
					
						
							|  |  |  |                 common_log(LOG_ERR, 'Could not unlink existing thumbnail file: '._ve($thumbpath)); | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-03-09 23:49:01 +01:00
										 |  |  |         } catch (InvalidFilenameException $e) { | 
					
						
							|  |  |  |             common_log(LOG_ERR, 'Deleting object but not attempting deleting file: '._ve($e->getMessage())); | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return parent::delete($useWhere); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-21 21:54:23 +01:00
										 |  |  |     public function getFile(): File | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-04 22:29:40 +02:00
										 |  |  |         return File::getByID($this->file_id); | 
					
						
							| 
									
										
										
										
											2014-05-12 14:33:41 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-21 03:19:05 +02:00
										 |  |  |     public function getFileId() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->file_id; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-11 12:27:40 +03:00
										 |  |  |     public static function hashurl($url) | 
					
						
							| 
									
										
										
										
											2016-02-10 04:15:41 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (!mb_strlen($url)) { | 
					
						
							|  |  |  |             throw new Exception('No URL provided to hash algorithm.'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return hash(self::URLHASH_ALG, $url); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function onInsert() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setUrlhash(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function onUpdate($dataObject=false) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // if we have nothing to compare with OR it has changed from previous entry
 | 
					
						
							|  |  |  |         if (!$dataObject instanceof Managed_DataObject || $this->url !== $dataObject->url) { | 
					
						
							|  |  |  |             $this->setUrlhash(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setUrlhash() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->urlhash = mb_strlen($this->url)>0 ? self::hashurl($this->url) : null; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-05-11 13:45:00 -04:00
										 |  |  | } |