GoalAudienceTarget.php 3.84 KB
<?php

namespace App\Models\Pivots;

use App\Models\AudienceTarget;
use App\Models\YandexError;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Relations\Pivot;
use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Support\Facades\DB;

class GoalAudienceTarget extends Pivot
{
    use SoftDeletes;

    protected $table = 'goal_audience_targets';

    protected $fillable = [
        'external_id',
        'goal_ad_group_external_id',
        'dictionary_campaign_external_id',
        'goal_retargetinglist_external_id',
        'goal_ad_group_id',
        'dictionary_campaign_id',
        'goal_retargetinglist_id',
        'audience_target_id',

        'external_upload_at',
        'external_updated_at',
        'updated_need',
        'reserve_create_at',
        'reserve_update_at',
        'reserve_delete_at',
    ];

    protected $casts = [
        'external_upload_at' => 'datetime',
        'external_updated_at' => 'datetime',
        'updated_need' => 'datetime',
        'reserve_create_at' => 'datetime',
        'reserve_update_at' => 'datetime',
        'reserve_delete_at' => 'datetime',
    ];

    public $incrementing = true;

    static public function getWithPivot()
    {
        return [
            'id',
            'external_id',
            'goal_ad_group_external_id',
            'dictionary_campaign_external_id',
            'goal_ad_group_id',
            'dictionary_campaign_id',
            'audience_target_id',

            'external_upload_at',
            'external_updated_at',
            'updated_need',
            'reserve_create_at',
            'reserve_update_at',
            'reserve_delete_at',
        ];
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeForExternal($query)
    {
        return $query->whereNotNull('external_id');
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeForNotExternal($query)
    {
        return $query->whereNull('external_id');
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeForNotReserveCreate($query)
    {
        return $query->whereNull('reserve_create_at');
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeNeedDeleted($query)
    {
        return $query->forExternal()->whereExists(function (\Illuminate\Database\Query\Builder $query) {
            $query->select(DB::raw(1))
                ->from('goal_ad_groups')
                ->join('ad_groups', 'goal_ad_groups.ad_group_id', '=', 'ad_groups.id')
                ->whereNull('goal_ad_groups.deleted_at')
                ->whereNotNull('goal_ad_groups.external_id')
                ->whereNotNull('ad_groups.deleted_at')
                ->whereColumn('goal_audience_targets.goal_ad_group_id', 'goal_ad_groups.id');
        });
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeForNotReserveDelete($query)
    {
        return $query->whereNull('reserve_delete_at');
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeNeedUpdated($query)
    {
        return $query->whereNotNull('updated_need');
    }

    public function goalAdGroup()
    {
        return $this->belongsTo(GoalAdGroup::class, 'goal_ad_group_id');
    }

    public function goalRetargetinglist()
    {
        return $this->belongsTo(GoalRetargetinglist::class, 'goal_retargetinglist_id');
    }

    public function audienceTarget()
    {
        return $this->belongsTo(AudienceTarget::class, 'audience_target_id');
    }

    public function dictionaryCampaign()
    {
        return $this->belongsTo(DictionaryCampaign::class, 'dictionary_campaign_id');
    }

    public function errors()
    {
        return $this->morphMany(YandexError::class, 'cause');
    }

}