2020-03-29 19:33:16 +01:00
< ? php
2020-03-29 20:56:35 +01:00
// {{{ License
2021-04-15 23:28:28 +01:00
2020-05-20 17:53:53 +01:00
// This file is part of GNU social - https://www.gnu.org/software/social
2020-03-29 20:56:35 +01:00
//
// GNU social is free software: you can redistribute it and/or modify
2020-05-10 21:43:15 +01:00
// it under the terms of the GNU Affero General Public License as published by
2020-03-29 20:56:35 +01:00
// 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.
//
2020-05-10 21:43:15 +01:00
// You should have received a copy of the GNU Affero General Public License
2020-03-29 20:56:35 +01:00
// along with GNU social. If not, see <http://www.gnu.org/licenses/>.
2021-04-15 23:28:28 +01:00
2020-03-29 20:56:35 +01:00
// }}}
2020-03-29 19:33:16 +01:00
namespace App\Entity ;
2021-04-16 17:11:34 +01:00
use App\Core\Cache ;
2021-04-16 11:46:53 +01:00
use App\Core\DB\DB ;
2020-08-15 07:18:23 +01:00
use App\Core\Entity ;
2021-04-16 11:46:53 +01:00
use App\Core\Event ;
2021-04-18 02:17:57 +01:00
use App\Core\GSFile ;
2021-04-16 11:46:53 +01:00
use App\Core\Log ;
2021-04-25 22:26:53 +01:00
use App\Core\Router ;
2021-04-16 16:57:25 +01:00
use App\Util\Common ;
2021-04-16 11:46:53 +01:00
use App\Util\Exception\NotFoundException ;
use App\Util\Exception\ServerException ;
2020-05-10 21:43:15 +01:00
use DateTimeInterface ;
2020-03-29 19:33:16 +01:00
/**
2021-04-15 23:28:28 +01:00
* Entity for Attachment thumbnails
2020-03-29 19:33:16 +01:00
*
* @ category DB
* @ package GNUsocial
*
* @ author Zach Copley < zach @ status . net >
* @ copyright 2010 StatusNet Inc .
* @ author Mikael Nordfeldth < mmn @ hethane . se >
* @ copyright 2009 - 2014 Free Software Foundation , Inc http :// www . fsf . org
2021-02-19 23:29:43 +00:00
* @ author Hugo Sales < hugo @ hsal . es >
* @ copyright 2020 - 2021 Free Software Foundation , Inc http :// www . fsf . org
2020-03-29 19:33:16 +01:00
* @ license https :// www . gnu . org / licenses / agpl . html GNU AGPL v3 or later
*/
2021-04-16 20:27:33 +01:00
class AttachmentThumbnail extends Entity
2020-03-29 19:33:16 +01:00
{
2020-03-30 15:00:13 +01:00
// {{{ Autocode
2021-04-15 23:28:28 +01:00
private int $attachment_id ;
2020-03-30 16:13:51 +01:00
private int $width ;
private int $height ;
2021-04-27 22:24:48 +01:00
private \DateTimeInterface $modified ;
2020-03-30 16:13:51 +01:00
2021-04-15 23:28:28 +01:00
public function setAttachmentId ( int $attachment_id ) : self
2020-03-30 16:13:51 +01:00
{
2021-04-15 23:28:28 +01:00
$this -> attachment_id = $attachment_id ;
2020-03-30 16:13:51 +01:00
return $this ;
}
2020-08-08 17:11:18 +01:00
2021-04-15 23:28:28 +01:00
public function getAttachmentId () : int
2020-03-30 16:13:51 +01:00
{
2021-04-15 23:28:28 +01:00
return $this -> attachment_id ;
2020-03-30 16:13:51 +01:00
}
public function setWidth ( int $width ) : self
{
$this -> width = $width ;
return $this ;
}
2020-08-08 17:11:18 +01:00
2020-03-30 16:13:51 +01:00
public function getWidth () : int
{
return $this -> width ;
}
public function setHeight ( int $height ) : self
{
$this -> height = $height ;
return $this ;
}
2020-08-08 17:11:18 +01:00
2020-03-30 16:13:51 +01:00
public function getHeight () : int
{
return $this -> height ;
}
2020-05-10 21:43:15 +01:00
public function setModified ( DateTimeInterface $modified ) : self
2020-03-30 16:13:51 +01:00
{
$this -> modified = $modified ;
return $this ;
}
2020-08-08 17:11:18 +01:00
2020-05-10 21:43:15 +01:00
public function getModified () : DateTimeInterface
2020-03-30 16:13:51 +01:00
{
return $this -> modified ;
}
2020-03-30 15:00:13 +01:00
// }}} Autocode
2020-03-29 19:33:16 +01:00
2021-04-16 16:57:25 +01:00
private Attachment $attachment ;
public function setAttachment ( Attachment $attachment )
{
$this -> attachment = $attachment ;
}
public function getAttachment ()
{
if ( isset ( $this -> attachment )) {
return $this -> attachment ;
} else {
return $this -> attachment = DB :: findOneBy ( 'attachment' , [ 'id' => $this -> attachment_id ]);
}
}
2021-04-16 11:46:53 +01:00
public static function getOrCreate ( Attachment $attachment , ? int $width = null , ? int $height = null , ? bool $crop = null )
{
try {
2021-04-16 17:11:34 +01:00
return Cache :: get ( 'thumb-' . $attachment -> getId () . " - { $width } x { $height } " ,
function () use ( $attachment , $width , $height ) {
return DB :: findOneBy ( 'attachment_thumbnail' , [ 'attachment_id' => $attachment -> getId (), 'width' => $width , 'height' => $height ]);
});
2021-04-16 11:46:53 +01:00
} catch ( NotFoundException $e ) {
2021-04-16 17:12:49 +01:00
$thumbnail = self :: create ([ 'attachment_id' => $attachment -> getId (), 'width' => $width , 'height' => $height , 'attachment' => $attachment ]);
2021-04-16 11:46:53 +01:00
$event_map = [ 'image' => 'ResizeImage' , 'video' => 'ResizeVideo' ];
2021-04-18 02:17:57 +01:00
$major_mime = GSFile :: mimetypeMajor ( $attachment -> getMimetype ());
2021-04-16 11:46:53 +01:00
if ( in_array ( $major_mime , array_keys ( $event_map ))) {
2021-04-16 16:57:25 +01:00
Event :: handle ( $event_map [ $major_mime ], [ $attachment , $thumbnail , $width , $height , $crop ]);
2021-04-16 23:55:00 +01:00
DB :: persist ( $thumbnail );
DB :: flush ();
2021-04-16 16:57:25 +01:00
return $thumbnail ;
2021-04-16 11:46:53 +01:00
} else {
Log :: debug ( $m = ( 'Cannot resize attachment with mimetype ' . $attachment -> getMimetype ()));
throw new ServerException ( $m );
}
}
}
2021-04-16 16:57:25 +01:00
public function getFilename ()
{
return $this -> getAttachment () -> getFileHash () . " - { $this -> width } x { $this -> height } .webp " ;
}
public function getPath ()
{
return Common :: config ( 'thumbnail' , 'dir' ) . $this -> getFilename ();
}
2021-04-25 22:26:53 +01:00
public function getUrl ()
{
return Router :: url ( 'attachment_thumbnail' , [ 'id' => $this -> getAttachmentId (), 'w' => $this -> getWidth (), 'h' => $this -> getHeight ()]);
}
/**
* Get the HTML attributes for this thumbnail
*/
public function getHTMLAttributes ( array $orig = [], bool $overwrite = true )
{
$attrs = [
'height' => $this -> getHeight (),
'width' => $this -> getWidth (),
'src' => $this -> getUrl (),
];
return $overwrite ? array_merge ( $orig , $attrs ) : array_merge ( $attrs , $orig );
}
2020-08-07 03:03:55 +01:00
/**
2021-04-15 23:28:28 +01:00
* Delete a attachment thumbnail . This table doesn ' t own all the attachments , only itself
2020-08-07 03:03:55 +01:00
*/
2021-04-15 23:28:28 +01:00
public function delete ( bool $flush = false , bool $delete_attachments_now = false , bool $cascading = false ) : string
2020-08-07 03:03:55 +01:00
{
2021-04-15 23:28:28 +01:00
// TODO Implement deleting attachment thumbnails
2020-08-07 03:03:55 +01:00
return '' ;
}
2020-03-29 19:33:16 +01:00
public static function schemaDef () : array
{
return [
2021-04-15 23:28:28 +01:00
'name' => 'attachment_thumbnail' ,
2020-03-29 19:33:16 +01:00
'fields' => [
2021-04-15 23:28:28 +01:00
'attachment_id' => [ 'type' => 'int' , 'foreign key' => true , 'target' => 'Attachment.id' , 'multiplicity' => 'one to one' , 'not null' => true , 'description' => 'thumbnail for what attachment' ],
'width' => [ 'type' => 'int' , 'not null' => true , 'description' => 'width of thumbnail' ],
'height' => [ 'type' => 'int' , 'not null' => true , 'description' => 'height of thumbnail' ],
'modified' => [ 'type' => 'timestamp' , 'not null' => true , 'default' => 'CURRENT_TIMESTAMP' , 'description' => 'date this record was modified' ],
2020-03-29 19:33:16 +01:00
],
2021-04-15 23:28:28 +01:00
'primary key' => [ 'attachment_id' , 'width' , 'height' ],
2021-02-22 21:34:59 +00:00
'indexes' => [
2021-04-15 23:28:28 +01:00
'attachment_thumbnail_attachment_id_idx' => [ 'attachment_id' ],
2020-06-30 17:26:40 +01:00
],
2020-03-29 19:33:16 +01:00
];
}
2020-06-30 17:26:40 +01:00
}