2FAuth/app/Api/v1/Controllers/UserController.php

87 lines
2.3 KiB
PHP

<?php
namespace App\Api\v1\Controllers;
use App\Api\v1\Requests\SettingUpdateRequest;
use App\Api\v1\Resources\UserResource;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Arr;
class UserController extends Controller
{
/**
* Get detailed information about the authenticated user
*
* @return \App\Api\v1\Resources\UserResource|\Illuminate\Http\JsonResponse
*/
public function show(Request $request)
{
return new UserResource($request->user());
}
/**
* List all preferences
*
* @return \Illuminate\Http\JsonResponse
*/
public function allPreferences(Request $request)
{
$preferences = $request->user()->preferences;
$jsonPrefs = collect([]);
$preferences->each(function (mixed $item, string $key) use ($jsonPrefs) {
$jsonPrefs->push([
'key' => $key,
'value' => $item,
]);
});
return response()->json($jsonPrefs->all(), 200);
}
/**
* Display a preference
*
* @param \Illuminate\Http\Request $request
* @param string $preferenceName
* @return \Illuminate\Http\JsonResponse
*/
public function showPreference(Request $request, string $preferenceName)
{
if (! Arr::exists($request->user()->preferences, $preferenceName)) {
abort(404);
}
return response()->json([
'key' => $preferenceName,
'value' => $request->user()->preferences[$preferenceName],
], 200);
}
/**
* Save a preference
*
* @param \App\Api\v1\Requests\SettingUpdateRequest $request
* @param string $preferenceName
* @return \Illuminate\Http\JsonResponse
*/
public function setPreference(SettingUpdateRequest $request, string $preferenceName)
{
if (! Arr::exists($request->user()->preferences, $preferenceName)) {
abort(404);
}
$validated = $request->validated();
$request->user()['preferences->' . $preferenceName] = $validated['value'];
$request->user()->save();
return response()->json([
'key' => $preferenceName,
'value' => $request->user()->preferences[$preferenceName],
], 201);
}
}