Skip to content
Snippets Groups Projects
FavouriteModel.php 4.76 KiB
Newer Older
  • Learn to ignore specific revisions
  • /**
     * @copyright  2021 Podlibre
     * @license    https://www.gnu.org/licenses/agpl-3.0.en.html AGPL3
     * @link       https://castopod.org/
     */
    
    
    use Modules\Fediverse\Activities\LikeActivity;
    use Modules\Fediverse\Activities\UndoActivity;
    use Modules\Fediverse\Entities\Actor;
    use Modules\Fediverse\Entities\Favourite;
    use Modules\Fediverse\Entities\Post;
    
        protected $allowedFields = ['actor_id', 'post_id'];
    
        /**
         * @var string
         */
        protected $returnType = Favourite::class;
    
        public function addFavourite(Actor $actor, Post $post, bool $registerActivity = true): void
    
            $this->db->transStart();
    
            $this->insert([
                'actor_id' => $actor->id,
    
            model('PostModel')
                ->where('id', service('uuid') ->fromString($post->id) ->getBytes())
    
                ->increment('favourites_count');
    
            if ($registerActivity) {
                $likeActivity = new LikeActivity();
    
                $likeActivity->set('actor', $actor->uri)
    
    
                $activityId = model('ActivityModel')
                    ->newActivity(
                        'Like',
                        $actor->id,
    
                $likeActivity->set('id', url_to('activity', $actor->username, $activityId));
    
    
                model('ActivityModel')
                    ->update($activityId, [
                        'payload' => $likeActivity->toJSON(),
                    ]);
    
            Events::trigger('on_post_favourite', $actor, $post);
    
        public function removeFavourite(Actor $actor, Post $post, bool $registerActivity = true): void
    
            model('PostModel')
                ->where('id', service('uuid') ->fromString($post->id) ->getBytes())
    
            $this->where([
                'actor_id' => $actor->id,
                'post_id' => service('uuid')
                    ->fromString($post->id)
                    ->getBytes(),
            ])
    
                ->delete();
    
            if ($registerActivity) {
                $undoActivity = new UndoActivity();
                // get like activity
                $activity = model('ActivityModel')
                    ->where([
                        'type' => 'Like',
                        'actor_id' => $actor->id,
    
                        'post_id' => service('uuid')
                            ->fromString($post->id)
    
                            ->getBytes(),
                    ])
                    ->first();
    
                $likeActivity = new LikeActivity();
                $likeActivity
    
                    ->set('id', url_to('activity', $actor->username, $activity->id))
    
    
                $undoActivity
                    ->set('actor', $actor->uri)
                    ->set('object', $likeActivity);
    
    
                $activityId = model('ActivityModel')
                    ->newActivity(
                        'Undo',
                        $actor->id,
    
                $undoActivity->set('id', url_to('activity', $actor->username, $activityId));
    
    
                model('ActivityModel')
                    ->update($activityId, [
                        'payload' => $undoActivity->toJSON(),
                    ]);
    
            Events::trigger('on_post_undo_favourite', $actor, $post);
    
         * Adds or removes favourite from database
    
        public function toggleFavourite(Actor $actor, Post $post): void
    
                    'post_id' => service('uuid')
                        ->fromString($post->id)
    
                $this->removeFavourite($actor, $post);