76 lines
3.2 KiB
PHP
76 lines
3.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
use App\Models\Application;
|
|
use App\Models\Environment;
|
|
use App\Models\Project;
|
|
use App\Models\Service;
|
|
use App\Models\ServiceApplication;
|
|
use App\Models\ServiceDatabase;
|
|
use App\Models\StandaloneClickhouse;
|
|
use App\Models\StandaloneDragonfly;
|
|
use App\Models\StandaloneKeydb;
|
|
use App\Models\StandaloneMariadb;
|
|
use App\Models\StandaloneMongodb;
|
|
use App\Models\StandaloneMysql;
|
|
use App\Models\StandalonePostgresql;
|
|
use App\Models\StandaloneRedis;
|
|
use Closure;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Gate;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
class CanUpdateResource
|
|
{
|
|
public function handle(Request $request, Closure $next): Response
|
|
{
|
|
return $next($request);
|
|
|
|
// Get resource from route parameters
|
|
// $resource = null;
|
|
// if ($request->route('application_uuid')) {
|
|
// $resource = Application::where('uuid', $request->route('application_uuid'))->first();
|
|
// } elseif ($request->route('service_uuid')) {
|
|
// $resource = Service::where('uuid', $request->route('service_uuid'))->first();
|
|
// } elseif ($request->route('stack_service_uuid')) {
|
|
// // Handle ServiceApplication or ServiceDatabase
|
|
// $stack_service_uuid = $request->route('stack_service_uuid');
|
|
// $resource = ServiceApplication::where('uuid', $stack_service_uuid)->first() ??
|
|
// ServiceDatabase::where('uuid', $stack_service_uuid)->first();
|
|
// } elseif ($request->route('database_uuid')) {
|
|
// // Try different database types
|
|
// $database_uuid = $request->route('database_uuid');
|
|
// $resource = StandalonePostgresql::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneMysql::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneMariadb::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneRedis::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneKeydb::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneDragonfly::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneClickhouse::where('uuid', $database_uuid)->first() ??
|
|
// StandaloneMongodb::where('uuid', $database_uuid)->first();
|
|
// } elseif ($request->route('server_uuid')) {
|
|
// // For server routes, check if user can manage servers
|
|
// if (! auth()->user()->isAdmin()) {
|
|
// abort(403, 'You do not have permission to access this resource.');
|
|
// }
|
|
|
|
// return $next($request);
|
|
// } elseif ($request->route('environment_uuid')) {
|
|
// $resource = Environment::where('uuid', $request->route('environment_uuid'))->first();
|
|
// } elseif ($request->route('project_uuid')) {
|
|
// $resource = Project::ownedByCurrentTeam()->where('uuid', $request->route('project_uuid'))->first();
|
|
// }
|
|
|
|
// if (! $resource) {
|
|
// abort(404, 'Resource not found.');
|
|
// }
|
|
|
|
// if (! Gate::allows('update', $resource)) {
|
|
// abort(403, 'You do not have permission to update this resource.');
|
|
// }
|
|
|
|
// return $next($request);
|
|
}
|
|
}
|