Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F120824403
SettingsTrait.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Authored By
Unknown
Size
3 KB
Referenced Files
None
Subscribers
None
SettingsTrait.php
View Options
<?php
namespace
App\Traits
;
use
Illuminate\Database\Eloquent\Relations\HasMany
;
trait
SettingsTrait
{
/**
* Obtain the value for a setting.
*
* Example Usage:
*
* ```php
* $user = User::firstOrCreate(['email' => 'some@other.erg']);
* $locale = $user->getSetting('locale');
* ```
*
* @param string $key Setting name
* @param mixed $default Default value, to be used if not found
*
* @return string|null Setting value
*/
public
function
getSetting
(
string
$key
,
$default
=
null
)
{
$setting
=
$this
->
settings
()->
where
(
'key'
,
$key
)->
first
();
return
$setting
?
$setting
->
value
:
$default
;
}
/**
* Obtain the values for many settings in one go (for better performance).
*
* @param array $keys Setting names
*
* @return array Setting key=value hash, includes also requested but non-existing settings
*/
public
function
getSettings
(
array
$keys
):
array
{
$settings
=
[];
foreach
(
$keys
as
$key
)
{
$settings
[
$key
]
=
null
;
}
$this
->
settings
()->
whereIn
(
'key'
,
$keys
)->
get
()
->
each
(
static
function
(
$setting
)
use
(&
$settings
)
{
$settings
[
$setting
->
key
]
=
$setting
->
value
;
});
return
$settings
;
}
/**
* Remove a setting.
*
* Example Usage:
*
* ```php
* $user = User::firstOrCreate(['email' => 'some@other.erg']);
* $user->removeSetting('locale');
* ```
*
* @param string $key Setting name
*/
public
function
removeSetting
(
string
$key
):
void
{
$this
->
setSetting
(
$key
,
null
);
}
/**
* Remove settings without invoking events.
*
* @param array $keys Setting names
*/
public
function
removeSettingsQuietly
(
array
$keys
):
void
{
$this
->
settings
()->
whereIn
(
'key'
,
$keys
)->
delete
();
}
/**
* Create or update a setting.
*
* Example Usage:
*
* ```php
* $user = User::firstOrCreate(['email' => 'some@other.erg']);
* $user->setSetting('locale', 'en');
* ```
*
* @param string $key Setting name
* @param string|null $value the new value for the setting
*/
public
function
setSetting
(
string
$key
,
$value
):
void
{
$this
->
setSettings
([
$key
=>
$value
]);
}
/**
* Create or update multiple settings in one fell swoop.
*
* Example Usage:
*
* ```php
* $user = User::firstOrCreate(['email' => 'some@other.erg']);
* $user->setSettings(['locale' => 'en', 'country' => 'GB']);
* ```
*
* @param array $data an associative array of key value pairs
*/
public
function
setSettings
(
array
$data
=
[]):
void
{
// Note: We're selecting the records first, so observers can act
$settings
=
$this
->
settings
()->
whereIn
(
'key'
,
array_keys
(
$data
))->
get
()->
keyBy
(
'key'
)->
all
();
foreach
(
$data
as
$key
=>
$value
)
{
if
(
$value
===
null
||
$value
===
''
)
{
if
(
isset
(
$settings
[
$key
]))
{
$settings
[
$key
]->
delete
();
}
}
elseif
(
isset
(
$settings
[
$key
]))
{
$settings
[
$key
]->
value
=
$value
;
$settings
[
$key
]->
save
();
}
else
{
// Note: upsert() might have been better, but it does not trigger events
$this
->
settings
()->
create
([
'key'
=>
$key
,
'value'
=>
$value
]);
}
}
}
/**
* Any (additional) properties of this domain.
*
* @return HasMany
*/
public
function
settings
()
{
return
$this
->
hasMany
(
self
::
class
.
'Setting'
);
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Fri, Apr 24, 10:21 AM (5 h, 1 m ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
18740805
Default Alt Text
SettingsTrait.php (3 KB)
Attached To
Mode
rK kolab
Attached
Detach File
Event Timeline