status = $status; $this->comment = $comment; } /** * Execute the job. * * @return void */ public function handle() { $status = $this->status; $comment = $this->comment; // Verify status and comment exists if (! $status) { Log::info('CommentPipeline: Status no longer exists, skipping job'); return; } if (! $comment) { Log::info('CommentPipeline: Comment no longer exists, skipping job'); return; } $target = $status->profile; $actor = $comment->profile; // Verify target and actor profiles exist if (! $target) { Log::info("CommentPipeline: Target profile no longer exists for status {$status->id}, skipping job"); return; } if (! $actor) { Log::info("CommentPipeline: Actor profile no longer exists for comment {$comment->id}, skipping job"); return; } if (config('database.default') === 'mysql') { // todo: refactor // $exp = DB::raw("select id, in_reply_to_id from statuses, (select @pv := :kid) initialisation where id > @pv and find_in_set(in_reply_to_id, @pv) > 0 and @pv := concat(@pv, ',', id)"); // $expQuery = $exp->getValue(DB::connection()->getQueryGrammar()); // $count = DB::select($expQuery, [ 'kid' => $status->id ]); // $status->reply_count = count($count); $status->reply_count = $status->reply_count + 1; $status->save(); } else { $status->reply_count = $status->reply_count + 1; $status->save(); } StatusService::del($comment->id); StatusService::del($status->id); Cache::forget('status:replies:all:'.$comment->id); Cache::forget('status:replies:all:'.$status->id); if ($actor->id === $target->id || $status->comments_disabled == true) { return true; } $filtered = UserFilter::whereUserId($target->id) ->whereFilterableType('App\Profile') ->whereIn('filter_type', ['mute', 'block']) ->whereFilterableId($actor->id) ->exists(); if ($filtered == true) { return; } if ($target->user_id && $target->domain === null) { DB::transaction(function () use ($target, $actor, $comment) { $notification = new Notification; $notification->profile_id = $target->id; $notification->actor_id = $actor->id; $notification->action = 'comment'; $notification->item_id = $comment->id; $notification->item_type = "App\Status"; $notification->save(); NotificationService::setNotification($notification); NotificationService::set($notification->profile_id, $notification->id); StatusService::del($comment->id); }); } if ($exists = Cache::get('status:replies:all:'.$status->id)) { if ($exists && $exists->count() == 3) { } else { Cache::forget('status:replies:all:'.$status->id); } } else { Cache::forget('status:replies:all:'.$status->id); } } }