如何使用 Laravel 5.1 使用更新记录的用户 ID 填充 modified_by?

Jun*_*ior 4 php traits laravel laravel-5

使用 Laravel 5.1 时,我正在尝试创建一个观察者,它将自动更新以下 3 列

  1. created_by:当创建的记录“不再更新”时填充
  2. modified_by:每次修改记录时填充一个新值
  3. purged_by:当记录被软删除时填充一个值。

我知道 Eloquent 会自动更新日期时间戳(created_by、updated_at、removed_at),但我需要更新进行更改的 user_id。

我被建议使用 Observer 和 trait 来处理这个问题。这是我所做的

1)创建了一个名为“ModelSignature”的观察者类app\Observers\ModelSignature.php,这是它的内容

<?php 

namespace App\Observers;

class ModelSignature {

    protected $userID;

    public function __construct(){
        $this->userID =  Auth::id();
    }


    public function updating($model)
    {
        $model->modified_by = $this->userID;
    }


    public function creating($model)
    {
        $model->created_by = $this->userID;
    }


    public function removing($model)
    {
        $model->purged_by = $this->userID;
    }

}
Run Code Online (Sandbox Code Playgroud)

然后我创建了一个名为“RecordSignature”的新特征,位于app\Traits\RecordSignature.php并包含以下代码

<?php

namespace App\Traits;

use app\Observers\ModelSignature;

trait RecordSignature
{

    public static function bootObservantTrait()
    {
        static::observe(new ModelSignature() );
    }
}
Run Code Online (Sandbox Code Playgroud)

最后,在我位于“app\Models\Account.php”的“Account”模型中,我像这样使用它

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use App\Models\industry;
use App\Traits\RecordSignature;
use App\Traits\TrimScalarValues;


class Account extends Model
{
    use RecordSignature, TrimScalarValues;
    /**
     * The database table used by the model.
     *
     * @var string
    */
    protected $table = 'accounts';

    protected $primaryKey = 'account_id';

    const CREATED_AT = 'created_on';

    const UPDATED_AT = 'modified_on';

    const REMOVED_AT = 'purged_on';


    /**
     * The attributes that are mass assignable.
     *
     * @var array
    */
    protected $fillable = ['client_id','account_name', 'company_code', 'legal_name', 'created_by','modified_by','instrucations'];

    /**
     * The attributes excluded from the model's JSON form.
     *
     * @var array
    */
    //protected $hidden = ['account_id', 'remember_token'];


    protected $guarded = ['account_id'];

    /**
     * Get the industry record associated with the account.
    */
    public function industry()
    {
        return $this->hasOne(industry, industry::primaryKey);
    }

    public function pk(){

        return $this->primaryKey;
    }

}
Run Code Online (Sandbox Code Playgroud)

问题是,这些方法updating()removing()creating()不是填充的userid预期。似乎字段被忽略或方法没有被触发!

我在这里做错了什么?

Rwd*_*Rwd 5

您应该能够摆脱 ModelSignatures 类并将您的特征更改为:

trait RecordSignature
{
    protected static function boot()
    {
        parent::boot();

        static::updating(function ($model) {

            $model->modified_by = \Auth::User()->id;
        });

        static::creating(function ($model) {

            $model->created_by = \Auth::User()->id;
        });
        //etc

    }

}
Run Code Online (Sandbox Code Playgroud)

更新

现在有很多软件包可以为您处理此类事情。我目前经常使用的是Laravel Auditing,它不仅会跟踪谁执行了任务,还会跟踪行的任何更改。