| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | // {{{ License
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // 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/>.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // }}}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * OembedPlugin implementation for GNU social | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package   GNUsocial | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @author    Stephen Paul Weber | 
					
						
							|  |  |  |  * @author    Mikael Nordfeldth | 
					
						
							|  |  |  |  * @author    Diogo Cordeiro <diogo@fc.up.pt> | 
					
						
							|  |  |  |  * @copyright 2019 Free Software Foundation, Inc http://www.fsf.org | 
					
						
							|  |  |  |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Plugin\Embed\Entity; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use App\Core\Entity; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:24:48 +00:00
										 |  |  | use DateTimeInterface; | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2021-04-27 20:56:50 +00:00
										 |  |  |  * Table Definition for attachment_embed | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2021-04-27 20:56:50 +00:00
										 |  |  |  * @author Hugo Sales <hugo@hsal.es> | 
					
						
							|  |  |  |  * @copyright 2019, 2021 Free Software Foundation, Inc http://www.fsf.org | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class AttachmentEmbed extends Entity | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-04-27 20:56:50 +00:00
										 |  |  |     // {{{ Autocode
 | 
					
						
							| 
									
										
										
										
											2021-05-05 16:03:03 +00:00
										 |  |  |     // @codeCoverageIgnoreStart
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     private int $remoteurl_id; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     private int $attachment_id; | 
					
						
							|  |  |  |     private ?string $title; | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     private ?string $description; | 
					
						
							|  |  |  |     private ?string $provider_name; | 
					
						
							|  |  |  |     private ?string $provider_url; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     private ?string $author_name; | 
					
						
							|  |  |  |     private ?string $author_url; | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     private ?string $thumbnail_url; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:24:48 +00:00
										 |  |  |     private \DateTimeInterface $modified; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function setRemoteUrlId(int $remoteurl_id): self | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         $this->remoteurl_id = $remoteurl_id; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function getRemoteUrlId(): int | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         return $this->remoteurl_id; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAttachmentId(): int | 
					
						
							| 
									
										
										
										
											2021-04-28 15:03:17 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         return $this->attachment_id; | 
					
						
							| 
									
										
										
										
											2021-04-28 15:03:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param int $attachment_id | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setAttachmentId(int $attachment_id): void | 
					
						
							| 
									
										
										
										
											2021-04-28 15:03:17 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         $this->attachment_id = $attachment_id; | 
					
						
							| 
									
										
										
										
											2021-04-28 15:03:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function setProviderName(?string $provider_name): self | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         $this->provider_name = $provider_name; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function getProviderName(): ?string | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         return $this->provider_name; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setProviderUrl(?string $provider_url): self | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->provider_url = $provider_url; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getProviderUrl(): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->provider_url; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function setDescription(?string $description): self | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         $this->description = $description; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function getDescription(): ?string | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         return $this->description; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setTitle(?string $title): self | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->title = $title; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getTitle(): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->title; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setAuthorName(?string $author_name): self | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->author_name = $author_name; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getAuthorName(): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->author_name; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setAuthorUrl(?string $author_url): self | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->author_url = $author_url; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getAuthorUrl(): ?string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->author_url; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function setThumbnailUrl(?string $thumbnail_url): self | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         $this->thumbnail_url = $thumbnail_url; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |     public function getThumbnailUrl(): ?string | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |         return $this->thumbnail_url; | 
					
						
							| 
									
										
										
										
											2021-04-27 21:18:44 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setModified(DateTimeInterface $modified): self | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->modified = $modified; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getModified(): DateTimeInterface | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->modified; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 16:03:03 +00:00
										 |  |  |     // @codeCoverageIgnoreEnd
 | 
					
						
							| 
									
										
										
										
											2021-04-27 20:56:50 +00:00
										 |  |  |     // }}} Autocode
 | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public static function schemaDef() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return [ | 
					
						
							|  |  |  |             'name'   => 'attachment_embed', | 
					
						
							|  |  |  |             'fields' => [ | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |                 'remoteurl_id'  => ['type' => 'int', 'not null' => true, 'description' => 'Embed for that URL/file'], | 
					
						
							|  |  |  |                 'attachment_id' => ['type' => 'int', 'not null' => true, 'description' => 'Attachment relation, used to show previews'], | 
					
						
							|  |  |  |                 'provider_name' => ['type' => 'text', 'description' => 'name of this Embed provider'], | 
					
						
							|  |  |  |                 'provider_url'  => ['type' => 'text', 'description' => 'URL of this Embed provider'], | 
					
						
							| 
									
										
										
										
											2021-05-01 22:45:47 +01:00
										 |  |  |                 'title'         => ['type' => 'text', 'description' => 'title of Embed resource when available'], | 
					
						
							|  |  |  |                 'author_name'   => ['type' => 'text', 'description' => 'author name for this Embed resource'], | 
					
						
							|  |  |  |                 'author_url'    => ['type' => 'text', 'description' => 'author URL for this Embed resource'], | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |                 'thumbnail_url' => ['type' => 'text', 'description' => 'URL for this Embed resource when applicable (photo, link)'], | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  |                 'modified'      => ['type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'], | 
					
						
							|  |  |  |             ], | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |             'primary key'  => ['remoteurl_id'], | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  |             'foreign keys' => [ | 
					
						
							| 
									
										
										
										
											2021-08-12 00:41:57 +01:00
										 |  |  |                 'attachment_embed_remoteurl_id_fkey'  => ['remoteurl', ['remoteurl_id' => 'id']], | 
					
						
							| 
									
										
										
										
											2021-04-27 20:56:50 +00:00
										 |  |  |                 'attachment_embed_attachment_id_fkey' => ['attachment', ['attachment_id' => 'id']], | 
					
						
							| 
									
										
										
										
											2021-04-25 21:23:46 +00:00
										 |  |  |             ], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |