2021-07-16 16:55:26 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add eloquent queries single(), singleOrFail(), singleOrNew()
|
|
|
|
*/
|
|
|
|
namespace App\Traits;
|
|
|
|
|
|
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
|
|
use Illuminate\Database\Eloquent\ModelNotFoundException;
|
|
|
|
|
|
|
|
trait SingleOrFail
|
|
|
|
{
|
2021-09-28 22:27:21 +10:00
|
|
|
private static function bootSingleOrFail(): void
|
2021-07-16 16:55:26 +10:00
|
|
|
{
|
|
|
|
// When a query should return 1 object, or FAIL if it doesnt
|
2024-11-04 18:25:49 +11:00
|
|
|
// @deprecated use sole()
|
2021-07-16 16:55:26 +10:00
|
|
|
Builder::macro('singleOrFail',function () {
|
|
|
|
$result = $this->get();
|
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
if (($x=$result->count()) === 1)
|
2021-07-16 16:55:26 +10:00
|
|
|
return $result->first();
|
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
if ($x === 0)
|
2021-07-16 16:55:26 +10:00
|
|
|
throw new ModelNotFoundException('Query brings back 0 record(s) called for singleOrFail()');
|
|
|
|
else
|
|
|
|
throw new \Exception(sprintf('Query brings back %d record(s) called for singleOrFail()',$x));
|
|
|
|
});
|
|
|
|
|
|
|
|
// When a query should return 1 object, or NULL if it doesnt
|
|
|
|
Builder::macro('single',function () {
|
|
|
|
$result = $this->get();
|
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
if ($result->count() === 1)
|
2021-07-16 16:55:26 +10:00
|
|
|
return $result->first();
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
});
|
|
|
|
|
|
|
|
// When a query should return 1 object, or NULL if it doesnt
|
|
|
|
Builder::macro('singleOrNew',function ($args) {
|
|
|
|
$result = $this->where($args)->get();
|
|
|
|
|
2023-06-27 19:39:11 +12:00
|
|
|
if ($result->count() === 1)
|
2021-07-16 16:55:26 +10:00
|
|
|
return $result->first();
|
|
|
|
|
|
|
|
return $this->newModelInstance($args);
|
|
|
|
});
|
|
|
|
}
|
2023-06-27 19:39:11 +12:00
|
|
|
}
|