173 lines
6.5 KiB
JavaScript
173 lines
6.5 KiB
JavaScript
"use strict";
|
|
/**
|
|
* PuestoController - Controller de puestos de trabajo
|
|
*
|
|
* Endpoints REST para gestión de catálogo de puestos.
|
|
*
|
|
* @module HR
|
|
*/
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.createPuestoController = createPuestoController;
|
|
const express_1 = require("express");
|
|
const puesto_service_1 = require("../services/puesto.service");
|
|
const auth_middleware_1 = require("../../auth/middleware/auth.middleware");
|
|
const auth_service_1 = require("../../auth/services/auth.service");
|
|
const puesto_entity_1 = require("../entities/puesto.entity");
|
|
const user_entity_1 = require("../../core/entities/user.entity");
|
|
const tenant_entity_1 = require("../../core/entities/tenant.entity");
|
|
const refresh_token_entity_1 = require("../../auth/entities/refresh-token.entity");
|
|
/**
|
|
* Crear router de puestos
|
|
*/
|
|
function createPuestoController(dataSource) {
|
|
const router = (0, express_1.Router)();
|
|
// Repositorios
|
|
const puestoRepository = dataSource.getRepository(puesto_entity_1.Puesto);
|
|
const userRepository = dataSource.getRepository(user_entity_1.User);
|
|
const tenantRepository = dataSource.getRepository(tenant_entity_1.Tenant);
|
|
const refreshTokenRepository = dataSource.getRepository(refresh_token_entity_1.RefreshToken);
|
|
// Servicios
|
|
const puestoService = new puesto_service_1.PuestoService(puestoRepository);
|
|
const authService = new auth_service_1.AuthService(userRepository, tenantRepository, refreshTokenRepository);
|
|
const authMiddleware = new auth_middleware_1.AuthMiddleware(authService, dataSource);
|
|
// Helper para crear contexto de servicio
|
|
const getContext = (req) => {
|
|
if (!req.tenantId) {
|
|
throw new Error('Tenant ID is required');
|
|
}
|
|
return {
|
|
tenantId: req.tenantId,
|
|
userId: req.user?.sub,
|
|
};
|
|
};
|
|
/**
|
|
* GET /puestos
|
|
* Listar puestos con filtros
|
|
*/
|
|
router.get('/', authMiddleware.authenticate, async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
const page = parseInt(req.query.page) || 1;
|
|
const limit = Math.min(parseInt(req.query.limit) || 20, 100);
|
|
const filters = {
|
|
activo: req.query.activo === 'true' ? true : req.query.activo === 'false' ? false : undefined,
|
|
nivelRiesgo: req.query.nivelRiesgo,
|
|
search: req.query.search,
|
|
};
|
|
const result = await puestoService.findAll(getContext(req), filters, page, limit);
|
|
res.status(200).json({
|
|
success: true,
|
|
data: result.data,
|
|
pagination: result.meta,
|
|
});
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* GET /puestos/:id
|
|
* Obtener puesto por ID con empleados asignados
|
|
*/
|
|
router.get('/:id', authMiddleware.authenticate, async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
const puesto = await puestoService.findById(getContext(req), req.params.id);
|
|
if (!puesto) {
|
|
res.status(404).json({ error: 'Not Found', message: 'Position not found' });
|
|
return;
|
|
}
|
|
res.status(200).json({ success: true, data: puesto });
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* POST /puestos
|
|
* Crear puesto
|
|
*/
|
|
router.post('/', authMiddleware.authenticate, authMiddleware.authorize('admin', 'director'), async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
const dto = req.body;
|
|
if (!dto.codigo || !dto.nombre) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'codigo and nombre are required' });
|
|
return;
|
|
}
|
|
const puesto = await puestoService.create(getContext(req), dto);
|
|
res.status(201).json({ success: true, data: puesto });
|
|
}
|
|
catch (error) {
|
|
if (error instanceof Error && error.message.includes('already exists')) {
|
|
res.status(409).json({ error: 'Conflict', message: error.message });
|
|
return;
|
|
}
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* PATCH /puestos/:id
|
|
* Actualizar puesto
|
|
*/
|
|
router.patch('/:id', authMiddleware.authenticate, authMiddleware.authorize('admin', 'director'), async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
const dto = req.body;
|
|
const puesto = await puestoService.update(getContext(req), req.params.id, dto);
|
|
if (!puesto) {
|
|
res.status(404).json({ error: 'Not Found', message: 'Position not found' });
|
|
return;
|
|
}
|
|
res.status(200).json({ success: true, data: puesto });
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* POST /puestos/:id/toggle-active
|
|
* Activar/desactivar puesto
|
|
*/
|
|
router.post('/:id/toggle-active', authMiddleware.authenticate, authMiddleware.authorize('admin', 'director'), async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
const puesto = await puestoService.toggleActive(getContext(req), req.params.id);
|
|
if (!puesto) {
|
|
res.status(404).json({ error: 'Not Found', message: 'Position not found' });
|
|
return;
|
|
}
|
|
res.status(200).json({
|
|
success: true,
|
|
data: puesto,
|
|
message: puesto.activo ? 'Position activated' : 'Position deactivated',
|
|
});
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
return router;
|
|
}
|
|
exports.default = createPuestoController;
|
|
//# sourceMappingURL=puesto.controller.js.map
|