TimesRecordCreatedJob.php 2.2 KB
<?php
/**
 * +--------------------------------------------------------------------------------------------------------------------
 * Job:TimesRecord 创建成功 处理业务逻辑
 * +--------------------------------------------------------------------------------------------------------------------
 *
 * PHP version 7
 *
 * @category  App\Jobs\User
 * @package   App\Jobs\User
 * @author    Richer <yangzi1028@163.com>
 * @date      2023年5月9日16:59:13
 * @copyright 2020-2022 Richer (http://www.Richer.com/)
 * @license   http://www.Richer.com/ License
 * @link      http://www.Richer.com/
 */
namespace App\Jobs\User;

use App\Jobs\BaseJob;
use App\Models\Traits\ChatTrait;
use App\Models\User\TimesRecord;
use App\Models\User\UserRemote;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;

/**
 * Class TimesRecordCreatedJob
 * @package App\Jobs\User
 */
class TimesRecordCreatedJob extends BaseJob
{
    use ChatTrait;
    /**
     * Create a new job instance.
     *
     * @param $model
     */
    public function __construct($model)
    {
        $this->desc  = '用户次数日志创建成功后同步数据';
        $this->channel =  'sync';
        // 执行
        parent::__construct($model);
    }

    /**
     * Execute the job.
     *
     * @return void
     * @throws \GuzzleHttp\Exception\GuzzleException
     */
    public function handle()
    {
        record_log($this->channel, '同步用户次数', 'begin');
        // 记录日志
        if ($this->attempts() > 1) {
//            $this->log('尝试次数过多');
            record_log($this->channel, '尝试次数过多');

        } else {

            $model = $this->model;
            // 同步增加记录
            $this->syncUserTimesRecord($model);

            if ($model->type == TimesRecord::DECREMENT) {
                UserRemote::where('id', $model->user_id)->decrement('times', $model->times);
            } else {
                UserRemote::where('id', $model->user_id)->increment('times', $model->times);
            }
        }
        record_log($this->channel, '同步用户次数', 'begin');

    }
}