Initial commit
This commit is contained in:
71
api/app/Http/Controllers/Admin/EventsController.php
Normal file
71
api/app/Http/Controllers/Admin/EventsController.php
Normal file
@@ -0,0 +1,71 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Actions\Events\CreateEventAction;
|
||||
use App\Actions\Events\UpdateEventAction;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Requests\Admin\StoreEventRequest;
|
||||
use App\Http\Requests\Admin\UpdateEventRequest;
|
||||
use App\Models\Event;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class EventsController extends Controller
|
||||
{
|
||||
public function index(Request $request): JsonResponse
|
||||
{
|
||||
$events = Event::query()
|
||||
->where('user_id', $request->user()->id)
|
||||
->withCount('uploads')
|
||||
->orderByDesc('created_at')
|
||||
->paginate($request->input('per_page', 15));
|
||||
|
||||
return response()->json($events);
|
||||
}
|
||||
|
||||
public function store(StoreEventRequest $request, CreateEventAction $action): JsonResponse
|
||||
{
|
||||
$event = $action->execute($request->validated(), $request->user());
|
||||
|
||||
return response()->json($event->loadCount('uploads'), 201);
|
||||
}
|
||||
|
||||
public function show(Event $event, Request $request): JsonResponse
|
||||
{
|
||||
$this->authorizeEvent($event, $request);
|
||||
|
||||
return response()->json($event->loadCount('uploads'));
|
||||
}
|
||||
|
||||
public function update(UpdateEventRequest $request, Event $event, UpdateEventAction $action): JsonResponse
|
||||
{
|
||||
$this->authorizeEvent($event, $request);
|
||||
$event = $action->execute($event, $request->validated());
|
||||
|
||||
return response()->json($event->loadCount('uploads'));
|
||||
}
|
||||
|
||||
public function destroy(Event $event, Request $request): JsonResponse
|
||||
{
|
||||
$this->authorizeEvent($event, $request);
|
||||
$event->delete();
|
||||
|
||||
return response()->json(null, 204);
|
||||
}
|
||||
|
||||
public function uploads(Event $event, Request $request): JsonResponse
|
||||
{
|
||||
$this->authorizeEvent($event, $request);
|
||||
$uploads = $event->uploads()->orderByDesc('created_at')->paginate($request->input('per_page', 20));
|
||||
|
||||
return response()->json($uploads);
|
||||
}
|
||||
|
||||
protected function authorizeEvent(Event $event, Request $request): void
|
||||
{
|
||||
if ($event->user_id !== $request->user()->id) {
|
||||
abort(404);
|
||||
}
|
||||
}
|
||||
}
|
||||
103
api/app/Http/Controllers/Admin/GoogleDriveController.php
Normal file
103
api/app/Http/Controllers/Admin/GoogleDriveController.php
Normal file
@@ -0,0 +1,103 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\GoogleDrive\GoogleDriveService;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
class GoogleDriveController extends Controller
|
||||
{
|
||||
public function __construct(
|
||||
protected GoogleDriveService $googleDrive
|
||||
) {}
|
||||
|
||||
public function authUrl(): JsonResponse
|
||||
{
|
||||
$url = $this->googleDrive->getAuthUrl();
|
||||
|
||||
return response()->json(['url' => $url]);
|
||||
}
|
||||
|
||||
public function callback(Request $request): RedirectResponse
|
||||
{
|
||||
$frontendUrl = config('app.frontend_admin_url', 'http://localhost:5173');
|
||||
|
||||
$code = $request->query('code');
|
||||
if (! $code) {
|
||||
return redirect($frontendUrl.'?google_drive_error=missing_code');
|
||||
}
|
||||
|
||||
$user = Auth::user();
|
||||
if (! $user) {
|
||||
return redirect($frontendUrl.'?google_drive_error=not_authenticated');
|
||||
}
|
||||
|
||||
try {
|
||||
$this->googleDrive->handleCallback($code, $user);
|
||||
} catch (\Throwable $e) {
|
||||
Log::error('Google Drive connection failed', [
|
||||
'error' => $e->getMessage(),
|
||||
'user_id' => $user->id,
|
||||
]);
|
||||
|
||||
return redirect($frontendUrl.'?google_drive_error=connection_failed');
|
||||
}
|
||||
|
||||
return redirect($frontendUrl.'?google_drive_connected=1');
|
||||
}
|
||||
|
||||
public function status(): JsonResponse
|
||||
{
|
||||
$connection = Auth::user()?->googleDriveConnections()->first();
|
||||
|
||||
return response()->json([
|
||||
'connected' => (bool) $connection,
|
||||
'account_email' => $connection?->account_email,
|
||||
]);
|
||||
}
|
||||
|
||||
public function disconnect(): JsonResponse
|
||||
{
|
||||
Auth::user()?->googleDriveConnections()->delete();
|
||||
|
||||
return response()->json(['message' => 'Disconnected']);
|
||||
}
|
||||
|
||||
public function sharedDrives(): JsonResponse
|
||||
{
|
||||
$drives = $this->googleDrive->listSharedDrives(Auth::user());
|
||||
|
||||
return response()->json(['data' => $drives]);
|
||||
}
|
||||
|
||||
public function folders(Request $request): JsonResponse
|
||||
{
|
||||
$parentId = $request->query('parent_id');
|
||||
$driveId = $request->query('drive_id');
|
||||
$folders = $this->googleDrive->listFolders(Auth::user(), $parentId, $driveId);
|
||||
|
||||
return response()->json(['data' => $folders]);
|
||||
}
|
||||
|
||||
public function createFolder(Request $request): JsonResponse
|
||||
{
|
||||
$request->validate([
|
||||
'name' => ['required', 'string', 'max:255'],
|
||||
'parent_id' => ['nullable', 'string'],
|
||||
'drive_id' => ['nullable', 'string'],
|
||||
]);
|
||||
$folder = $this->googleDrive->createFolder(
|
||||
Auth::user(),
|
||||
$request->input('name'),
|
||||
$request->input('parent_id'),
|
||||
$request->input('drive_id')
|
||||
);
|
||||
|
||||
return response()->json(['data' => $folder]);
|
||||
}
|
||||
}
|
||||
55
api/app/Http/Controllers/Admin/UploadsController.php
Normal file
55
api/app/Http/Controllers/Admin/UploadsController.php
Normal file
@@ -0,0 +1,55 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\Upload;
|
||||
use App\Services\GoogleDrive\GoogleDriveService;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class UploadsController extends Controller
|
||||
{
|
||||
public function show(Upload $upload, Request $request): JsonResponse
|
||||
{
|
||||
$this->authorizeUpload($upload, $request);
|
||||
|
||||
return response()->json($upload);
|
||||
}
|
||||
|
||||
public function destroy(Upload $upload, Request $request, GoogleDriveService $googleDrive): JsonResponse
|
||||
{
|
||||
$this->authorizeUpload($upload, $request);
|
||||
|
||||
if ($upload->google_drive_file_id) {
|
||||
try {
|
||||
$googleDrive->deleteFile($request->user(), $upload->google_drive_file_id);
|
||||
} catch (\Throwable) {
|
||||
// Continue to delete record even if Drive delete fails
|
||||
}
|
||||
}
|
||||
$upload->delete();
|
||||
|
||||
return response()->json(null, 204);
|
||||
}
|
||||
|
||||
public function downloadUrl(Upload $upload, Request $request, GoogleDriveService $googleDrive): JsonResponse
|
||||
{
|
||||
$this->authorizeUpload($upload, $request);
|
||||
|
||||
if (! $upload->google_drive_file_id) {
|
||||
return response()->json(['message' => 'File not yet available'], 404);
|
||||
}
|
||||
|
||||
$url = $googleDrive->getFileLink($request->user(), $upload->google_drive_file_id);
|
||||
|
||||
return response()->json(['url' => $url]);
|
||||
}
|
||||
|
||||
protected function authorizeUpload(Upload $upload, Request $request): void
|
||||
{
|
||||
if ($upload->event->user_id !== $request->user()->id) {
|
||||
abort(404);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user