- Delete unused Livewire Search test and fuel type select Blade component - Move subscription webhook listener from EventServiceProvider to AppServiceProvider - Add FUEL_TYPES global config to app layout for client-side use - Add Billable trait to User model and include email_verified_at in fillable - Implement monthly/annual cadence toggle with pricing display and smart CTA routing on homepage - Update VerifyApiKeyMiddlewareTest to use e10 instead of petrol - Refactor PollFuelPrices to auto-refresh stale stations based on last_seen_at - Add incremental polling with cached timestamp and effective-start-timestamp param to FuelPriceService - Normalize amenities/fuel_types from API objects to flat arrays, skip stations missing required fields - Log response body on API failures in ApiLogger - Default homepage sort to 'reliable' instead of 'price'
122 lines
3.7 KiB
PHP
122 lines
3.7 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
use App\Enums\FuelType;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\User;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\Response;
|
|
use Illuminate\Support\Facades\Hash;
|
|
use Illuminate\Validation\Rule;
|
|
use Illuminate\Validation\Rules\Password;
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
final class UserController extends Controller
|
|
{
|
|
public function preferences(Request $request): JsonResponse
|
|
{
|
|
return response()->json([
|
|
'preferred_fuel_type' => $request->user()->preferred_fuel_type,
|
|
'postcode' => $request->user()->postcode,
|
|
]);
|
|
}
|
|
|
|
public function updatePreferences(Request $request): JsonResponse
|
|
{
|
|
$validated = $request->validate([
|
|
'preferred_fuel_type' => ['sometimes', Rule::in(array_column(FuelType::cases(), 'value'))],
|
|
'postcode' => ['sometimes', 'string', 'max:8'],
|
|
]);
|
|
|
|
$request->user()->update($validated);
|
|
|
|
return response()->json([
|
|
'preferred_fuel_type' => $request->user()->fresh()->preferred_fuel_type,
|
|
'postcode' => $request->user()->fresh()->postcode,
|
|
]);
|
|
}
|
|
|
|
public function savedStations(Request $request): JsonResponse
|
|
{
|
|
$stations = $request->user()->savedStations()->get();
|
|
|
|
return response()->json(['data' => $stations]);
|
|
}
|
|
|
|
public function saveStation(Request $request): JsonResponse
|
|
{
|
|
$validated = $request->validate([
|
|
'station_id' => ['required', 'string', 'max:64'],
|
|
]);
|
|
|
|
$request->user()->savedStations()->firstOrCreate([
|
|
'station_id' => $validated['station_id'],
|
|
]);
|
|
|
|
return response()->json(null, 201);
|
|
}
|
|
|
|
public function removeStation(Request $request, string $stationId): Response
|
|
{
|
|
$request->user()->savedStations()->where('station_id', $stationId)->delete();
|
|
|
|
return response()->noContent();
|
|
}
|
|
|
|
public function updateProfile(Request $request): JsonResponse
|
|
{
|
|
$validated = $request->validate([
|
|
'name' => ['required', 'string', 'max:255'],
|
|
'email' => ['required', 'string', 'email', 'max:255', Rule::unique(User::class)->ignore($request->user()->id)],
|
|
]);
|
|
|
|
$user = $request->user();
|
|
$user->fill($validated);
|
|
|
|
if ($user->isDirty('email')) {
|
|
$user->email_verified_at = null;
|
|
}
|
|
|
|
$user->save();
|
|
|
|
return response()->json($user->fresh());
|
|
}
|
|
|
|
public function updatePassword(Request $request): JsonResponse
|
|
{
|
|
$request->validate([
|
|
'current_password' => ['required', 'string'],
|
|
'password' => ['required', 'string', Password::defaults(), 'confirmed'],
|
|
]);
|
|
|
|
if (! Hash::check($request->string('current_password'), $request->user()->password)) {
|
|
throw ValidationException::withMessages([
|
|
'current_password' => [__('The provided password does not match your current password.')],
|
|
]);
|
|
}
|
|
|
|
$request->user()->update(['password' => $request->string('password')]);
|
|
|
|
return response()->json(['message' => 'Password updated.']);
|
|
}
|
|
|
|
public function deleteAccount(Request $request): Response
|
|
{
|
|
$request->validate(['password' => ['required', 'string']]);
|
|
|
|
if (! Hash::check($request->string('password'), $request->user()->password)) {
|
|
throw ValidationException::withMessages([
|
|
'password' => [__('The provided password does not match your current password.')],
|
|
]);
|
|
}
|
|
|
|
$user = $request->user();
|
|
$user->tokens()->delete();
|
|
$user->delete();
|
|
|
|
return response()->noContent();
|
|
}
|
|
}
|