Cache preferences.

This commit is contained in:
James Cole
2015-06-03 22:11:50 +02:00
parent 14dce8a10b
commit a50949e554

View File

@@ -3,6 +3,7 @@
namespace FireflyIII\Support; namespace FireflyIII\Support;
use Auth; use Auth;
use Cache;
use FireflyIII\Models\Preference; use FireflyIII\Models\Preference;
/** /**
@@ -30,9 +31,17 @@ class Preferences
*/ */
public function get($name, $default = null) public function get($name, $default = null)
{ {
$preference = Preference::where('user_id', Auth::user()->id)->where('name', $name)->first(['id','name','data_encrypted']); $fullName = 'preference' . Auth::user()->id . $name;
if (Cache::has($fullName)) {
return Cache::get($fullName);
}
$preference = Preference::where('user_id', Auth::user()->id)->where('name', $name)->first(['id', 'name', 'data_encrypted']);
if ($preference) { if ($preference) {
Cache::forever($fullName, $preference);
return $preference; return $preference;
} }
// no preference found and default is null: // no preference found and default is null:
@@ -53,7 +62,9 @@ class Preferences
*/ */
public function set($name, $value) public function set($name, $value)
{ {
$pref = Preference::where('user_id', Auth::user()->id)->where('name', $name)->first(['id','name','data_encrypted']); $fullName = 'preference' . Auth::user()->id . $name;
Cache::forget($fullName);
$pref = Preference::where('user_id', Auth::user()->id)->where('name', $name)->first(['id', 'name', 'data_encrypted']);
if ($pref) { if ($pref) {
$pref->data = $value; $pref->data = $value;
} else { } else {
@@ -65,6 +76,8 @@ class Preferences
} }
$pref->save(); $pref->save();
Cache::forever($fullName, $pref);
return $pref; return $pref;
} }