Chr*_*hvh 6 php laravel eloquent laravel-5.4
运用 Laravel 5.4
我有一个Job模型,其上有一个enum字段,具有不同的状态.这些状态在许多不同的地方发生变化.我制作了一个JobHistory模型和迁移来跟踪这些变化.
在我的工作模型中,我定义了新的laravel 5.4跟踪雄辩事件的方式:
/**
* The events that should be fired for eloquent actions
*
* @var array
*/
protected $events = [
'updating' => JobChangedStatus::class
];
Run Code Online (Sandbox Code Playgroud)
状态更改如下所示:
/**
* Change the job status
*
* @param $status
*/
public function changeStatus($status)
{
$this->update([
'status' => $status,
]);
}
Run Code Online (Sandbox Code Playgroud)
EventServiceProvider:
'App\Events\Jobs\JobChangedStatus' => [
'App\Listeners\Jobs\CreateJobHistory',
],
Run Code Online (Sandbox Code Playgroud)
CreateJobHistory Listener:
$job = $event->job;
$jobHistory = new JobHistory();
$jobHistory->old_status = $job->getOriginal('status');
$jobHistory->new_status = $job->status;
$jobHistory->job()->associate($job);
$jobHistory->executor()->associate(Auth::user());
$jobHistory->save();
Run Code Online (Sandbox Code Playgroud)
当我将工作状态从例如New改为In_progress
我的JobHistory表格如下所示:
所以new_status和old_status都给出了旧值.我尝试使用$job->getDirty()但是当我打印它时它只返回一个空数组.
我究竟做错了什么?
通常我会在Observer中实现这一点。看到这样的事件/监听器设置感觉有点尴尬。
在你的AppServiceProvider.php:
public function boot()
{
App\Job::observe(App\Observers\JobObserver::class);
}
Run Code Online (Sandbox Code Playgroud)
然后在App\Observers\JobObserver.php:
use App\Job;
use App\JobHistory;
class JobObserver{
public function updating(Job $job)
{
$jobHistory = new JobHistory();
$jobHistory->old_status = $job->getOriginal('status');
$jobHistory->new_status = $job->status;
$jobHistory->job()->associate($job);
$jobHistory->executor()->associate(Auth::user());
$jobHistory->save();
}
}
Run Code Online (Sandbox Code Playgroud)
对于雄辩的模型来说,使用观察者是最有意义的(只是我的观点)。我用来监听邮件事件、工作事件、可能的通知等的事件/监听器模型。
这可能对您的情况有所帮助的另一个原因是,如果事件正在排队而不是同步运行,您最终会遇到竞争条件,并且大多数情况下模型将被保存,这就是为什么getDirty()没有键的原因。对于观察者,操作始终同步运行,您不会遇到计时问题。