249 lines
9.5 KiB
JavaScript
249 lines
9.5 KiB
JavaScript
"use strict";
|
|
/**
|
|
* UsersController - Controlador de usuarios
|
|
*
|
|
* Endpoints REST para CRUD de usuarios y asignación de roles.
|
|
*
|
|
* @module Users
|
|
*/
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.createUsersController = createUsersController;
|
|
const express_1 = require("express");
|
|
const users_service_1 = require("../services/users.service");
|
|
const auth_middleware_1 = require("../../auth/middleware/auth.middleware");
|
|
const auth_service_1 = require("../../auth/services/auth.service");
|
|
const user_entity_1 = require("../../core/entities/user.entity");
|
|
const tenant_entity_1 = require("../../core/entities/tenant.entity");
|
|
const role_entity_1 = require("../../auth/entities/role.entity");
|
|
const user_role_entity_1 = require("../../auth/entities/user-role.entity");
|
|
const refresh_token_entity_1 = require("../../auth/entities/refresh-token.entity");
|
|
/**
|
|
* Crear router de usuarios
|
|
*/
|
|
function createUsersController(dataSource) {
|
|
const router = (0, express_1.Router)();
|
|
// Repositorios
|
|
const userRepository = dataSource.getRepository(user_entity_1.User);
|
|
const tenantRepository = dataSource.getRepository(tenant_entity_1.Tenant);
|
|
const roleRepository = dataSource.getRepository(role_entity_1.Role);
|
|
const userRoleRepository = dataSource.getRepository(user_role_entity_1.UserRole);
|
|
const refreshTokenRepository = dataSource.getRepository(refresh_token_entity_1.RefreshToken);
|
|
// Servicios
|
|
const usersService = new users_service_1.UsersService(userRepository, roleRepository, userRoleRepository);
|
|
const authService = new auth_service_1.AuthService(userRepository, tenantRepository, refreshTokenRepository);
|
|
const authMiddleware = new auth_middleware_1.AuthMiddleware(authService, dataSource);
|
|
/**
|
|
* GET /users
|
|
* Listar usuarios del tenant
|
|
*/
|
|
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 search = req.query.search;
|
|
const isActive = req.query.isActive === 'true' ? true : req.query.isActive === 'false' ? false : undefined;
|
|
const result = await usersService.findAll({ tenantId, page, limit, search, isActive });
|
|
res.status(200).json({
|
|
success: true,
|
|
data: result.users,
|
|
pagination: {
|
|
page,
|
|
limit,
|
|
total: result.total,
|
|
totalPages: Math.ceil(result.total / limit),
|
|
},
|
|
});
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* GET /users/roles
|
|
* Listar roles disponibles
|
|
*/
|
|
router.get('/roles', authMiddleware.authenticate, async (_req, res, next) => {
|
|
try {
|
|
const roles = await usersService.listRoles();
|
|
res.status(200).json({ success: true, data: roles });
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* GET /users/:id
|
|
* Obtener usuario por ID
|
|
*/
|
|
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 user = await usersService.findById(req.params.id, tenantId);
|
|
if (!user) {
|
|
res.status(404).json({ error: 'Not Found', message: 'User not found' });
|
|
return;
|
|
}
|
|
const roles = await usersService.getUserRoles(user.id, tenantId);
|
|
res.status(200).json({
|
|
success: true,
|
|
data: { ...user, assignedRoles: roles },
|
|
});
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* POST /users
|
|
* Crear usuario
|
|
*/
|
|
router.post('/', authMiddleware.authenticate, authMiddleware.authorize('admin', 'super_admin'), 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,
|
|
tenantId,
|
|
};
|
|
if (!dto.email || !dto.password || !dto.firstName || !dto.lastName) {
|
|
res.status(400).json({
|
|
error: 'Bad Request',
|
|
message: 'Email, password, firstName and lastName are required',
|
|
});
|
|
return;
|
|
}
|
|
const user = await usersService.create(dto, req.user?.sub);
|
|
res.status(201).json({ success: true, data: user });
|
|
}
|
|
catch (error) {
|
|
if (error instanceof Error && error.message === 'Email already exists in this tenant') {
|
|
res.status(409).json({ error: 'Conflict', message: error.message });
|
|
return;
|
|
}
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* PATCH /users/:id
|
|
* Actualizar usuario
|
|
*/
|
|
router.patch('/:id', authMiddleware.authenticate, authMiddleware.authorize('admin', 'super_admin'), 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 user = await usersService.update(req.params.id, tenantId, dto);
|
|
res.status(200).json({ success: true, data: user });
|
|
}
|
|
catch (error) {
|
|
if (error instanceof Error && error.message === 'User not found') {
|
|
res.status(404).json({ error: 'Not Found', message: error.message });
|
|
return;
|
|
}
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* DELETE /users/:id
|
|
* Eliminar usuario (soft delete)
|
|
*/
|
|
router.delete('/:id', authMiddleware.authenticate, authMiddleware.authorize('admin', 'super_admin'), async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
await usersService.delete(req.params.id, tenantId, req.user?.sub);
|
|
res.status(200).json({ success: true, message: 'User deleted' });
|
|
}
|
|
catch (error) {
|
|
if (error instanceof Error && error.message === 'User not found') {
|
|
res.status(404).json({ error: 'Not Found', message: error.message });
|
|
return;
|
|
}
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* POST /users/:id/roles
|
|
* Asignar rol a usuario
|
|
*/
|
|
router.post('/:id/roles', authMiddleware.authenticate, authMiddleware.authorize('admin', 'super_admin'), async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
const { roleCode } = req.body;
|
|
if (!roleCode) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'roleCode is required' });
|
|
return;
|
|
}
|
|
const userRole = await usersService.assignRole({ userId: req.params.id, roleCode, tenantId }, req.user?.sub);
|
|
res.status(200).json({ success: true, data: userRole });
|
|
}
|
|
catch (error) {
|
|
if (error instanceof Error && error.message === 'Role not found') {
|
|
res.status(404).json({ error: 'Not Found', message: error.message });
|
|
return;
|
|
}
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* DELETE /users/:id/roles/:roleCode
|
|
* Remover rol de usuario
|
|
*/
|
|
router.delete('/:id/roles/:roleCode', authMiddleware.authenticate, authMiddleware.authorize('admin', 'super_admin'), async (req, res, next) => {
|
|
try {
|
|
const tenantId = req.tenantId;
|
|
if (!tenantId) {
|
|
res.status(400).json({ error: 'Bad Request', message: 'Tenant ID required' });
|
|
return;
|
|
}
|
|
await usersService.removeRole(req.params.id, req.params.roleCode, tenantId);
|
|
res.status(200).json({ success: true, message: 'Role removed' });
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
/**
|
|
* GET /users/:id/roles
|
|
* Obtener roles de usuario
|
|
*/
|
|
router.get('/:id/roles', 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 roles = await usersService.getUserRoles(req.params.id, tenantId);
|
|
res.status(200).json({ success: true, data: roles });
|
|
}
|
|
catch (error) {
|
|
next(error);
|
|
}
|
|
});
|
|
return router;
|
|
}
|
|
exports.default = createUsersController;
|
|
//# sourceMappingURL=users.controller.js.map
|