. // }}} namespace Plugin\Favourite\Entity; use App\Core\DB\DB; use App\Core\Entity; use App\Entity\Note; use DateTimeInterface; class NoteFavourite extends Entity { // {{{ Autocode // @codeCoverageIgnoreStart private int $note_id; private int $actor_id; private DateTimeInterface $created; private DateTimeInterface $modified; public function setNoteId(int $note_id): self { $this->note_id = $note_id; return $this; } public function getNoteId(): int { return $this->note_id; } public function setActorId(int $actor_id): self { $this->actor_id = $actor_id; return $this; } public function getActorId(): int { return $this->actor_id; } public function setCreated(DateTimeInterface $created): self { $this->created = $created; return $this; } public function getCreated(): DateTimeInterface { return $this->created; } public function setModified(DateTimeInterface $modified): self { $this->modified = $modified; return $this; } public function getModified(): DateTimeInterface { return $this->modified; } // @codeCoverageIgnoreEnd // }}} Autocode public static function getNoteFavourites(Note $note): array { return DB::findBy('note_favourite', ['note_id' => $note->getId()]); } public static function getNoteFavouriteActors(Note $note): array { return DB::dql( <<<'EOF' select a from actor as a inner join note_favourite as nf with nf.note_id = :note_id where a.id = nf.actor_id order by nf.created DESC EOF, ['note_id' => $note->getId()], ); } public function getNotificationTargetIds(array $ids_already_known = [], ?int $sender_id = null, bool $include_additional = true): array { if (!\array_key_exists('object', $ids_already_known)) { $target_ids = Note::getById($this->getNoteId())->getNotificationTargetIds(); } else { $target_ids = $ids_already_known['object']; } // Additional actors that should know about this if ($include_additional && \array_key_exists('additional', $ids_already_known)) { array_push($target_ids, ...$ids_already_known['additional']); } else { return $target_ids; } return array_unique($target_ids); } public static function schemaDef() { return [ 'name' => 'note_favourite', 'fields' => [ 'note_id' => ['type' => 'int', 'foreign key' => true, 'target' => 'App\Entity\Note.id', 'multiplicity' => 'one to one', 'not null' => true, 'description' => 'note that is the favorite of'], 'actor_id' => ['type' => 'int', 'foreign key' => true, 'target' => 'App\Entity\Actor.id', 'multiplicity' => 'one to one', 'not null' => true, 'description' => 'actor who favourited this note'], // note: formerly referenced notice.id, but we can now record remote users' favorites 'created' => ['type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'], 'modified' => ['type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'], ], 'primary key' => ['note_id', 'actor_id'], 'indexes' => [ 'fave_note_id_idx' => ['note_id'], 'fave_actor_id_idx' => ['actor_id', 'modified'], 'fave_modified_idx' => ['modified'], ], ]; } }