Back | Home
الـ Path الحالي: /home/picotech/domains/instantly.picotech.app/public_html/public/./.././storage/./../app/Jobs/././.
الملفات الموجودة في هذا الـ Path:
.
..
AfterGenerate.php
CampaignCreateChunk.php
CampaignCreateJob.php
CampaignCreateSuccessJob.php
ChunkImport.php
ChunkImportFail.php
ListBuilderQueue.php

مشاهدة ملف: ChunkImport.php

<?php

namespace App\Jobs;

use App\Models\Contact;
use App\Models\ContactGroup;
use App\Models\Group;
use App\Models\Message;
use App\Models\MessageLog;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldBeUnique;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Carbon;
use Illuminate\Support\Collection;
use Illuminate\Support\Facades\Log;

class ChunkImport implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;


    private $request;
    private $user;
    private $group;
    private $offset;
    private $result_count;

    /**
     * Create a new job instance.
     *
     * @return void
     */

    public function __construct($rq,$group,$user,$resultCount)
    {
        $this->request=$rq;
        $this->user=$user;
        $this->group=$group;
        $this->result_count=$resultCount;
        $this->offset = ($rq->page - 1) * $this->result_count;
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        $customer = $this->user;
        $request=(object)$this->request;
        if (!$request->group_ids){
            return;
        }

        $contacts=ContactGroup::where('contact_groups.customer_id',$customer->id)
            ->select('contact_groups.contact_id','contact_groups.customer_id','contacts.first_name','contacts.last_name','contacts.city','contacts.address','contacts.state','contacts.zip_code','contacts.email')
            ->whereIn('contact_groups.group_id',$request->group_ids)
            ->skip($this->offset)
            ->take($this->result_count)
            ->groupBy('contacts.email')
            ->join('contacts', 'contacts.id', '=', 'contact_groups.contact_id');



        if (isset($request->first_name) && $request->first_name && $request->first_name_type == '=') {
            $contacts->where('first_name', $request->first_name);
        }elseif(isset($request->first_name) && $request->first_name && $request->first_name_type == '!='){
            $contacts->where('first_name','!=', $request->first_name);
        }

        if (isset($request->last_name) && $request->last_name && $request->last_name_type == '=') {
            $contacts->where('last_name', $request->last_name);
        }elseif(isset($request->last_name) && $request->last_name && $request->last_name_type == '!='){
            $contacts->where('last_name','!=', $request->last_name);
        }

        if (isset($request->address) && $request->address && $request->address_type == '=') {
            $contacts->where('address', $request->address);
        }elseif(isset($request->address) && $request->address && $request->address_type == '!='){
            $contacts->where('address','!=', $request->address);
        }
        if (isset($request->city) && $request->city && $request->city_type == '=') {
            $contacts->where('city', $request->city);
        }elseif(isset($request->city) && $request->city && $request->city_type == '!='){
            $contacts->where('city','!=', $request->city);
        }
        if (isset($request->state) && $request->state && $request->state_type == '=') {
            $contacts->where('state', $request->state);
        }elseif(isset($request->state) && $request->state && $request->state_type == '!='){
            $contacts->where('state','!=', $request->state);
        }
        if (isset($request->zip_code) && $request->zip_code && $request->zip_code_type == '=') {
            $contacts->where('zip_code', $request->state);
        }elseif(isset($request->zip_code) && $request->zip_code && $request->zip_code_type == '!='){
            $contacts->where('zip_code','!=', $request->state);
        }
        if (isset($request->email) && $request->email && $request->email_type == '=') {
            $contacts->where('email', $request->email);
        }elseif(isset($request->email) && $request->email && $request->email_type == '!='){
            $contacts->where('email','!=', $request->email);
        }

        $contactTo = $contacts->pluck('email');
        $sent_messages = MessageLog::where('type', 'sent')->where('status','!=','pending')->whereIn('to', $contactTo);
        if ($request->sent_type == 'older_than') {
            $sent_messages->whereDate('created_at', '<=', Carbon::now()->subDays($request->email_sent_days));
        }
        if ($request->sent_type == 'within') {
            $sent_messages->whereBetween('created_at', [Carbon::now()->subDays($request->email_sent_days)->toDateString(), Carbon::now()->addDay()->toDateString()]);
        }
        if ($request->sent_type == 'between') {
            $sent_messages->whereBetween('created_at', [Carbon::parse($request->between_from)->toDateString(), Carbon::parse($request->between_to)->toDateString()]);
        }
        if ($request->sent_type == 'empty'){
            $sent_messages=$sent_messages->get();
            $already_sent_to=$sent_messages->pluck('to');
            $toContactResult=$contactTo->filter(function ($value, $key) use ($already_sent_to) {
                return ! ($already_sent_to->contains($value));
            });
        }else{
            $sent_messages=$sent_messages->get();
            $toContactResult=$sent_messages->pluck('to');
        }
        $inbox_messages = MessageLog::where('type', 'inbox')->whereIn('from', $toContactResult);

        if ($request->email_received_type == 'older_than') {
            $inbox_messages->whereDate('created_at', '<=', Carbon::now()->subDays($request->email_received_days));
        }

        if ($request->email_received_type == 'within') {
            $inbox_messages->whereBetween('created_at', [Carbon::now()->subDays($request->email_received_days)->toDateString(), Carbon::now()->addDay()->toDateString()]);
        }

        if ($request->email_received_type == 'between') {
            $inbox_messages->whereBetween('created_at', [Carbon::parse($request->email_received_between_from)->toDateString(), Carbon::parse($request->email_received_between_to)->toDateString()]);
        }

        if ($request->email_received_type == 'empty') {
            $inbox_messages=$inbox_messages->get();
            $already_received_from=$inbox_messages->pluck('from');
            $toContactResult=$toContactResult->filter(function ($value, $key) use ($already_received_from) {
                return ! ($already_received_from->contains($value));
            });
        }else{
            $inbox_messages=$inbox_messages->get();
            $toContactResult=$inbox_messages->pluck('from');
        }
        $all_contacts = $contacts->whereIn('email',$toContactResult)->get();

        $contactsList = new Collection();
        foreach ($all_contacts as $contact) {
            $sentMessage=null;
            $inMessage=null;

            if ($request->sent_type != 'empty') {
                $sentMessage=$sent_messages->filter(function ($item) use ($contact) {
                    return strpos(" ".$item->to,$contact->email) !== false;
                })->first();
            }
            if($request->email_received_type != 'empty'){
                $inMessage=$inbox_messages->filter(function ($item) use ($contact) {
                    return strpos(" ".$item->from,$contact->email) !== false;
                })->first();
            }
            if($sentMessage && $inMessage){
                $contact['received_email_date'] = $inMessage->created_at;
                $contact['delivered_at'] = $sentMessage->created_at;
            }elseif ($sentMessage){
                $contact['delivered_at'] = $sentMessage->created_at;
            }elseif ($inMessage){
                $contact['received_email_date'] = $inMessage->created_at;
            }
            if(!$contactsList->contains($contact)){
                $contactsList->push($contact);
            }
        }
        $contact_ids = $contactsList->pluck('contact_id');
        $contactArray=[];
        foreach ($contact_ids as $contact_id) {
            $contactArray[] = [
                'contact_id' => $contact_id,
                'customer_id' => $this->group->customer_id,
                'group_id' => $this->group->id,
                'created_at' => now(),
                'updated_at' => now(),
            ];
        }
        if($contactArray){
            ContactGroup::insert($contactArray);
        }
    }

    public function failed(\Exception $exception)
    {
        Group::where('id',$this->group->id)->update(['import_status'=>'failed','import_fail_message'=>substr($exception->getMessage(), 0, 191)]);
    }
}