| Server IP : 54.94.228.101 / Your IP : 172.28.20.13 Web Server : Apache System : Linux ip-172-28-29-189 6.5.0-1014-aws #14~22.04.1-Ubuntu SMP Thu Feb 15 15:27:06 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.2.34-43+ubuntu22.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /var/www/html/vinumday2_0/vendor/spatie/laravel-activitylog/src/Traits/ |
Upload File : |
<?php
namespace Spatie\Activitylog\Traits;
use Illuminate\Database\Eloquent\Model;
use Spatie\Activitylog\Exceptions\CouldNotLogChanges;
trait DetectsChanges
{
protected $oldAttributes = [];
protected static function bootDetectsChanges()
{
if (static::eventsToBeRecorded()->contains('updated')) {
static::updating(function (Model $model) {
//temporary hold the original attributes on the model
//as we'll need these in the updating event
$oldValues = $model->replicate()->setRawAttributes($model->getOriginal());
$model->oldAttributes = static::logChanges($oldValues);
});
}
}
public function attributesToBeLogged(): array
{
if (! isset(static::$logAttributes)) {
return [];
}
return static::$logAttributes;
}
public function shouldlogOnlyDirty(): bool
{
if (! isset(static::$logOnlyDirty)) {
return false;
}
return static::$logOnlyDirty;
}
public function attributeValuesToBeLogged(string $processingEvent): array
{
if (! count($this->attributesToBeLogged())) {
return [];
}
$properties['attributes'] = static::logChanges($this->exists ? $this->fresh() : $this);
if (static::eventsToBeRecorded()->contains('updated') && $processingEvent == 'updated') {
$nullProperties = array_fill_keys(array_keys($properties['attributes']), null);
$properties['old'] = array_merge($nullProperties, $this->oldAttributes);
}
if ($this->shouldlogOnlyDirty() && isset($properties['old'])) {
$properties['attributes'] = array_udiff_assoc(
$properties['attributes'],
$properties['old'],
function ($new, $old) {
return $new <=> $old;
}
);
$properties['old'] = collect($properties['old'])->only(array_keys($properties['attributes']))->all();
}
return $properties;
}
public static function logChanges(Model $model): array
{
$changes = [];
foreach ($model->attributesToBeLogged() as $attribute) {
if (str_contains($attribute, '.')) {
$changes += self::getRelatedModelAttributeValue($model, $attribute);
} else {
$changes += collect($model)->only($attribute)->toArray();
}
}
return $changes;
}
protected static function getRelatedModelAttributeValue(Model $model, string $attribute): array
{
if (substr_count($attribute, '.') > 1) {
throw CouldNotLogChanges::invalidAttribute($attribute);
}
list($relatedModelName, $relatedAttribute) = explode('.', $attribute);
$relatedModel = $model->$relatedModelName ?? $model->$relatedModelName();
return ["{$relatedModelName}.{$relatedAttribute}" => $relatedModel->$relatedAttribute];
}
}