. // }}} namespace App\Entity; use App\Core\Entity; use DateTimeInterface; /** * Entity for Notices sources * * @category DB * @package GNUsocial * * @author Zach Copley * @copyright 2010 StatusNet Inc. * @author Mikael Nordfeldth * @copyright 2009-2014 Free Software Foundation, Inc http://www.fsf.org * @author Hugo Sales * @copyright 2020-2021 Free Software Foundation, Inc http://www.fsf.org * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ class NoteSource extends Entity { // {{{ Autocode // @codeCoverageIgnoreStart private string $code; private string $name; private string $url; private \DateTimeInterface $modified; public function setCode(string $code): self { $this->code = $code; return $this; } public function getCode(): string { return $this->code; } public function setName(string $name): self { $this->name = $name; return $this; } public function getName(): string { return $this->name; } public function setUrl(string $url): self { $this->url = $url; return $this; } public function getUrl(): string { return $this->url; } public function setModified(DateTimeInterface $modified): self { $this->modified = $modified; return $this; } public function getModified(): DateTimeInterface { return $this->modified; } // @codeCoverageIgnoreEnd // }}} Autocode public static function schemaDef(): array { return [ 'name' => 'note_source', 'fields' => [ 'code' => ['type' => 'varchar', 'length' => 32, 'not null' => true, 'description' => 'code identifier'], 'name' => ['type' => 'varchar', 'length' => 191, 'not null' => true, 'description' => 'name of the source'], 'url' => ['type' => 'varchar', 'length' => 191, 'not null' => true, 'description' => 'url to link to'], 'modified' => ['type' => 'timestamp', 'not null' => true, 'default' => 'CURRENT_TIMESTAMP', 'description' => 'date this record was modified'], ], 'primary key' => ['code'], ]; } }