wsconcilia-laravel/app/Http/Controllers/Api/EmpresasController.php
2025-09-12 13:06:36 -07:00

118 lines
3.2 KiB
PHP

<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Http\JsonResponse;
use Illuminate\Support\Facades\DB;
use Exception;
class EmpresasController extends Controller
{
/**
* Obtiene el listado de empresas desde el procedimiento almacenado
* Migrado desde ObtenEmpresas.php
*
* @return JsonResponse
*/
public function obtenerEmpresas(): JsonResponse
{
try {
// Ejecutar el procedimiento almacenado sapObtenEmpresas
$empresas = DB::select('EXEC sapObtenEmpresas');
$response = [
"tipo" => 0,
"mensaje" => "OK",
"data" => $empresas
];
return response()->json($response, 200);
} catch (Exception $e) {
$response = [
"tipo" => 1,
"mensaje" => "Error al obtener empresas: " . $e->getMessage(),
"data" => []
];
return response()->json($response, 500);
}
}
/**
* Método alternativo usando Query Builder para mayor flexibilidad
*
* @return JsonResponse
*/
public function obtenerEmpresasAlternativo(): JsonResponse
{
try {
// Alternativa usando Query Builder si no tienes procedimientos almacenados
// Ajusta según tu estructura de tabla
$empresas = DB::table('empresas')
->select('*')
->orderBy('nombre')
->get();
$response = [
"tipo" => 0,
"mensaje" => "OK",
"data" => $empresas
];
return response()->json($response, 200);
} catch (Exception $e) {
$response = [
"tipo" => 1,
"mensaje" => "Error al obtener empresas: " . $e->getMessage(),
"data" => []
];
return response()->json($response, 500);
}
}
/**
* Obtener empresa específica por ID
*
* @param int $id
* @return JsonResponse
*/
public function obtenerEmpresaPorId(int $id): JsonResponse
{
try {
$empresa = DB::table('empresas')
->where('id', $id)
->first();
if (!$empresa) {
return response()->json([
"tipo" => 1,
"mensaje" => "Empresa no encontrada",
"data" => null
], 404);
}
$response = [
"tipo" => 0,
"mensaje" => "OK",
"data" => $empresa
];
return response()->json($response, 200);
} catch (Exception $e) {
$response = [
"tipo" => 1,
"mensaje" => "Error al obtener empresa: " . $e->getMessage(),
"data" => null
];
return response()->json($response, 500);
}
}
}