Caching requests

This commit is contained in:
Julian Prieber 2023-12-16 19:09:38 +01:00
parent 87dbdebb1f
commit 3a828a623f
1 changed files with 26 additions and 9 deletions

View File

@ -3,6 +3,7 @@
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Cache;
class UserData extends Model
{
@ -11,7 +12,7 @@ class UserData extends Model
public static function saveData($userId, $key, $value)
{
$userData = self::where('id', $userId)->first();
$userData = self::getCachedUserData($userId);
if (!$userData) {
return "null";
@ -22,35 +23,51 @@ class UserData extends Model
$userData->image = json_encode($data);
$userData->save();
self::cacheUserData($userId, $userData);
}
public static function getData($userId, $key)
{
$userData = self::where('id', $userId)->first();
$userData = self::getCachedUserData($userId);
if (!$userData || !$userData->image) {
return "null";
}
$data = json_decode($userData->image, true) ?? [];
return isset($data[$key]) ? $data[$key] : null;
}
public static function removeData($userId, $key)
{
$userData = self::where('id', $userId)->first();
$userData = self::getCachedUserData($userId);
if (!$userData || !$userData->image) {
return "null";
}
$data = json_decode($userData->image, true) ?? [];
if (isset($data[$key])) {
unset($data[$key]);
$userData->image = json_encode($data);
$userData->save();
self::cacheUserData($userId, $userData);
}
}
private static function getCachedUserData($userId)
{
return Cache::remember('user_data_' . $userId, now()->addMinutes(10), function () use ($userId) {
return self::where('id', $userId)->first();
});
}
private static function cacheUserData($userId, $userData)
{
Cache::put('user_data_' . $userId, $userData, now()->addMinutes(10));
}
}