paneln8n/app/Http/Controllers/Api/ExecutionController.php
2025-09-12 03:10:00 +02:00

70 lines
2.1 KiB
PHP

<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\Execution;
use App\Models\Project;
use Illuminate\Support\Facades\Auth;
use Illuminate\Validation\ValidationException;
class ExecutionController extends Controller
{
public function store(Request $request)
{
$request->validate([
'project_id' => 'required|exists:projects,id',
'input' => 'required|string',
'output' => 'required|string',
'cost' => 'required|string',
]);
$project = Project::find($request->project_id);
// Validar que el usuario pueda crear la ejecución
if (!$project) { // || (!$request->user()->is_admin && $project->user_id !== $request->user()->id)) {
throw ValidationException::withMessages([
'project_id' => ['No tienes permisos para crear una ejecución en este proyecto.'],
]);
}
$execution = Execution::create([
'project_id' => $request->project_id,
'input' => $request->input,
'output' => $request->output,
'cost' => $request->cost,
]);
return response()->json([
'success' => true,
'execution' => $execution,
], 201);
}
public function tokens(Request $request)
{
$request->validate([
'id' => 'required|exists:executions,id',
'tokens' => 'required|string',
]);
$execution = Execution::find($request->id);
// Validar que el usuario pueda crear la ejecución
if (!$execution) { // || (!$request->user()->is_admin && $project->user_id !== $request->user()->id)) {
throw ValidationException::withMessages([
'project_id' => ['No tienes permisos para crear una ejecución en este proyecto.'],
]);
}
$execution->cost = $request->tokens;
$execution->save();
return response()->json([
'success' => true,
'execution' => $execution,
], 201);
}
}