owen-it /
laravel-auditing
| 1 | <?php |
||
| 2 | |||
| 3 | namespace OwenIt\Auditing; |
||
| 4 | |||
| 5 | use Illuminate\Support\Facades\Config; |
||
| 6 | use Illuminate\Support\Manager; |
||
| 7 | use InvalidArgumentException; |
||
| 8 | use OwenIt\Auditing\Contracts\Auditable; |
||
|
0 ignored issues
–
show
|
|||
| 9 | use OwenIt\Auditing\Contracts\AuditDriver; |
||
| 10 | use OwenIt\Auditing\Drivers\Database; |
||
| 11 | use OwenIt\Auditing\Events\Audited; |
||
| 12 | use OwenIt\Auditing\Events\Auditing; |
||
| 13 | use OwenIt\Auditing\Exceptions\AuditingException; |
||
| 14 | |||
| 15 | class Auditor extends Manager implements Contracts\Auditor |
||
| 16 | { |
||
| 17 | /** |
||
| 18 | * {@inheritdoc} |
||
| 19 | */ |
||
| 20 | public function getDefaultDriver() |
||
| 21 | { |
||
| 22 | return 'database'; |
||
| 23 | } |
||
| 24 | |||
| 25 | /** |
||
| 26 | * {@inheritdoc} |
||
| 27 | */ |
||
| 28 | 15 | protected function createDriver($driver) |
|
| 29 | { |
||
| 30 | try { |
||
| 31 | 15 | return parent::createDriver($driver); |
|
| 32 | } catch (InvalidArgumentException $exception) { |
||
| 33 | if (class_exists($driver)) { |
||
| 34 | return $this->container->make($driver); |
||
| 35 | } |
||
| 36 | |||
| 37 | throw $exception; |
||
| 38 | } |
||
| 39 | } |
||
| 40 | |||
| 41 | /** |
||
| 42 | * {@inheritdoc} |
||
| 43 | */ |
||
| 44 | 15 | public function auditDriver(Auditable $model): AuditDriver |
|
| 45 | { |
||
| 46 | 15 | $driver = $this->driver($model->getAuditDriver()); |
|
| 47 | |||
| 48 | 15 | if (!$driver instanceof AuditDriver) { |
|
| 49 | throw new AuditingException('The driver must implement the AuditDriver contract'); |
||
| 50 | } |
||
| 51 | |||
| 52 | 15 | return $driver; |
|
| 53 | } |
||
| 54 | |||
| 55 | /** |
||
| 56 | * {@inheritdoc} |
||
| 57 | */ |
||
| 58 | 15 | public function execute(Auditable $model): void |
|
| 59 | { |
||
| 60 | 15 | if (!$model->readyForAuditing()) { |
|
| 61 | return; |
||
| 62 | } |
||
| 63 | |||
| 64 | 15 | $driver = $this->auditDriver($model); |
|
| 65 | |||
| 66 | 15 | if (!$this->fireAuditingEvent($model, $driver)) { |
|
| 67 | return; |
||
| 68 | } |
||
| 69 | |||
| 70 | // Check if we want to avoid storing empty values |
||
| 71 | 15 | $allowEmpty = Config::get('audit.empty_values'); |
|
| 72 | 15 | $explicitAllowEmpty = in_array($model->getAuditEvent(), Config::get('audit.allowed_empty_values', [])); |
|
| 73 | |||
| 74 | 15 | if (!$allowEmpty && !$explicitAllowEmpty) { |
|
| 75 | if ( |
||
| 76 | empty($model->toAudit()['new_values']) && |
||
| 77 | empty($model->toAudit()['old_values']) |
||
| 78 | ) { |
||
| 79 | return; |
||
| 80 | } |
||
| 81 | } |
||
| 82 | |||
| 83 | 15 | $audit = $driver->audit($model); |
|
| 84 | 15 | if (!$audit) { |
|
| 85 | return; |
||
| 86 | } |
||
| 87 | |||
| 88 | 15 | $driver->prune($model); |
|
| 89 | |||
| 90 | 15 | $this->container->make('events')->dispatch( |
|
| 91 | 15 | new Audited($model, $driver, $audit) |
|
| 92 | 15 | ); |
|
| 93 | } |
||
| 94 | |||
| 95 | /** |
||
| 96 | * Create an instance of the Database audit driver. |
||
| 97 | */ |
||
| 98 | protected function createDatabaseDriver(): Database |
||
| 99 | { |
||
| 100 | 15 | return $this->container->make(Database::class); |
|
| 101 | } |
||
| 102 | 15 | ||
| 103 | /** |
||
| 104 | * Fire the Auditing event. |
||
| 105 | */ |
||
| 106 | protected function fireAuditingEvent(Auditable $model, AuditDriver $driver): bool |
||
| 107 | { |
||
| 108 | return $this |
||
| 109 | ->container |
||
| 110 | ->make('events') |
||
| 111 | ->until(new Auditing($model, $driver)) !== false; |
||
| 112 | } |
||
| 113 | } |
||
| 114 |
Let?s assume that you have a directory layout like this:
. |-- OtherDir | |-- Bar.php | `-- Foo.php `-- SomeDir `-- Foo.phpand let?s assume the following content of
Bar.php:If both files
OtherDir/Foo.phpandSomeDir/Foo.phpare loaded in the same runtime, you will see a PHP error such as the following:PHP Fatal error: Cannot use SomeDir\Foo as Foo because the name is already in use in OtherDir/Foo.phpHowever, as
OtherDir/Foo.phpdoes not necessarily have to be loaded and the error is only triggered if it is loaded beforeOtherDir/Bar.php, this problem might go unnoticed for a while. In order to prevent this error from surfacing, you must import the namespace with a different alias: