74 lines
2.0 KiB
PHP
74 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Storage;
|
|
|
|
class UploadController extends Controller
|
|
{
|
|
public function storeAvatar(Request $request): JsonResponse
|
|
{
|
|
$user = $request->user();
|
|
if (!$user) {
|
|
return response()->json(['message' => 'Unauthorized'], 401);
|
|
}
|
|
|
|
$data = $request->validate([
|
|
'file' => ['required', 'image', 'mimes:jpg,jpeg,png,gif,webp', 'max:2048'],
|
|
]);
|
|
|
|
if ($user->avatar_path) {
|
|
Storage::disk('public')->delete($user->avatar_path);
|
|
}
|
|
|
|
$path = $data['file']->store('avatars', 'public');
|
|
$user->avatar_path = $path;
|
|
$user->save();
|
|
|
|
return response()->json([
|
|
'path' => $path,
|
|
'url' => Storage::url($path),
|
|
]);
|
|
}
|
|
|
|
public function storeLogo(Request $request): JsonResponse
|
|
{
|
|
$user = $request->user();
|
|
if (!$user || !$user->roles()->where('name', 'ROLE_ADMIN')->exists()) {
|
|
return response()->json(['message' => 'Forbidden'], 403);
|
|
}
|
|
|
|
$data = $request->validate([
|
|
'file' => ['required', 'file', 'mimes:jpg,jpeg,png,gif,webp,svg,ico', 'max:5120'],
|
|
]);
|
|
|
|
$path = $data['file']->store('logos', 'public');
|
|
|
|
return response()->json([
|
|
'path' => $path,
|
|
'url' => Storage::url($path),
|
|
]);
|
|
}
|
|
|
|
public function storeFavicon(Request $request): JsonResponse
|
|
{
|
|
$user = $request->user();
|
|
if (!$user || !$user->roles()->where('name', 'ROLE_ADMIN')->exists()) {
|
|
return response()->json(['message' => 'Forbidden'], 403);
|
|
}
|
|
|
|
$data = $request->validate([
|
|
'file' => ['required', 'file', 'mimes:png,ico', 'max:2048'],
|
|
]);
|
|
|
|
$path = $data['file']->store('favicons', 'public');
|
|
|
|
return response()->json([
|
|
'path' => $path,
|
|
'url' => Storage::url($path),
|
|
]);
|
|
}
|
|
}
|