HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //var/www/quadcode/app/Repository/PipedriveQueueRepository.php
<?php

namespace App\Repository;

use App\Models\PipedriveQueue;
use Illuminate\Database\Eloquent\Collection;

class PipedriveQueueRepository
{

    public function create(array $data): void
    {
        $pipedriveQueue = new PipedriveQueue(['data' => json_encode($data)]);
        $pipedriveQueue->save();
    }

    /** @return Collection|array|PipedriveQueue[] */
    public function getNeedToSend(): Collection|array
    {
        return PipedriveQueue::query()->where('status', PipedriveQueue::STATUS_NEW)->get();
    }

    public function getErrorsCount(): int
    {
        return PipedriveQueue::query()->where('status', PipedriveQueue::STATUS_ERROR)->count();
    }

    public function getFirstStepLeads(): Collection
    {
        return PipedriveQueue::query()
            ->where('status', PipedriveQueue::STATUS_DONE)
            ->where('whats_app_status', PipedriveQueue::STATUS_NEW)
            ->where('step', 1)
            ->whereRaw("lead_created_at <= now() - INTERVAL '2 MINUTES'")
            ->whereNotNull('lead_id')
            ->get();
    }

    public function getSecondStepLeads(): Collection
    {
        return PipedriveQueue::query()
            ->where('status', PipedriveQueue::STATUS_DONE)
            ->where('whats_app_status', PipedriveQueue::STATUS_NEW)
            ->where('step', 2)
            ->whereRaw("lead_created_at <= now() - INTERVAL '3 DAYS'")
            ->whereNotNull('lead_id')
            ->get();
    }

    public function getThirdStepLeads(): Collection
    {
        return PipedriveQueue::query()
            ->where('status', PipedriveQueue::STATUS_DONE)
            ->where('whats_app_status', PipedriveQueue::STATUS_NEW)
            ->where('step', 3)
            ->whereRaw("lead_created_at <= now() - INTERVAL '5 DAYS'")
            ->whereNotNull('lead_id')
            ->get();
    }

}