repuve-backend-v1/app/Http/Controllers/Repuve/CatalogNameImgController.php
Juan Felipe Zapata Moreno 31746867b8 feat: Agrega validaciones de autorización y nuevas clases Request
- Se agregó autorización basada en permisos en múltiples Requests.
- Nuevos Requests para motivos de cancelación y tags con validación y autorización.
- Se añadieron métodos de roles al modelo User (isDeveloper, isAdmin, isPrimary).
- Se actualizó el acceso a Telescope usando validación por roles.
- Mejora en el manejo de excepciones de autorización.
- Actualización de RoleSeeder con nuevas convenciones de permisos.
- Actualización de dependencias (composer.lock).
2026-02-23 13:05:53 -06:00

89 lines
2.2 KiB
PHP

<?php
namespace App\Http\Controllers\Repuve;
use App\Http\Requests\Repuve\CatalogNameImgStoreRequest;
use App\Http\Requests\Repuve\CatalogNameImgUpdateRequest;
use App\Http\Controllers\Controller;
use App\Models\CatalogNameImg;
use Illuminate\Routing\Controllers\HasMiddleware;
use Notsoweb\ApiResponse\Enums\ApiResponse;
class CatalogNameImgController extends Controller implements HasMiddleware
{
/**
* Middleware
*/
public static function middleware(): array
{
return [
self::can('catalogs.name_img.index', ['index']),
self::can('catalogs.name_img.destroy', ['destroy']),
];
}
/**
* Listar
*/
public function index()
{
$names = CatalogNameImg::orderBy('id', 'ASC')->get();
return ApiResponse::OK->response([
'names' => $names,
]);
}
/**
* Crear
*/
public function store(CatalogNameImgStoreRequest $request)
{
$validated = $request->validated();
$catalogNameImg = CatalogNameImg::create($validated);
return ApiResponse::CREATED->response([
'name' => $catalogNameImg,
]);
}
/**
* Actualizar
*/
public function update(CatalogNameImgUpdateRequest $request, $id)
{
$catalogName = CatalogNameImg::findOrFail($id);
$validated = $request->validated([
'name' => 'required|string|max:255|unique:catalog_name_img,name,' . $id,
]);
$catalogName->update($validated);
return ApiResponse::OK->response([
'name' => $catalogName,
]);
}
/**
* Eliminar
*/
public function destroy($id)
{
try {
$catalogName = CatalogNameImg::findOrFail($id);
$catalogName->delete();
return ApiResponse::OK->response([
'message' => 'Nombre del catálogo eliminado correctamente.',
]);
} catch (\Exception $e) {
return ApiResponse::INTERNAL_ERROR->response([
'message' => 'Error al eliminar el nombre del catálogo.',
'error' => $e->getMessage(),
]);
}
}
}