This project is the backend for the User Management Platform developed for TalentAlke. The goal is to build a robust and secure backend system using NestJS to handle user management, including registration, authentication, and data management. The system uses TypeORM to interact with a MySQL database and implements JWT-based authentication.
@nestjs/platform-express
: Provides integration with the Express framework for handling HTTP requests.@nestjs/typeorm
: TypeORM integration for managing the database connections and operations.typeorm
: ORM library for TypeScript and JavaScript to interact with the MySQL database.bcrypt
: For hashing passwords securely.jsonwebtoken
: For generating and verifying JSON Web Tokens (JWT) for authentication.class-transformer
andclass-validator
: For transforming and validating data transfer objects (DTOs).winston
: For logging with support for different transports and log levels.
PORT=3306
DATABASE="name_database"
USERNAMEDB="root"
PASSWORD="123456"
HOST="localhost"
JWT_SECRET=ead643ce042680b8acf42e5f9e8463318cc63bcd8a51cd40ee9cf1444b718a029e8e342f7083042db0742d8f244af94f8aac2c909a6f73d00060d1b5f5fb40f8
DEFAULT_ADMIN_NAME=Admin
DEFAULT_ADMIN_RUT=11.111.111-1
DEFAULT_ADMIN_EMAIL=admin@admin.cl
DEFAULT_ADMIN_PASSWORD=Password
# Rate Limit Configuration
RATE_LIMIT_LOGIN_WINDOW_MS=60000 # 1 minuto
RATE_LIMIT_LOGIN_MAX_REQUESTS=5 # 5 intentos
RATE_LIMIT_SIGNUP_WINDOW_MS=60000 # 1 minuto
RATE_LIMIT_SIGNUP_MAX_REQUESTS=10 # 10 solicitudes
RATE_LIMIT_GENERAL_WINDOW_MS=60000 # 1 minuto
RATE_LIMIT_GENERAL_MAX_REQUESTS=100 # 100 solicitudes
# CORS Configuration
CORS_ORIGIN="http://localhost:5173"
use talent_alke;
INSERT INTO talent_alke.`user`
(name, rut, email, password, `role`, phone, birthday, country, deletedDate, createDate)
values ('Juan Pérez', '11.222.333-4', 'juan.perez@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56912345678', '1990-05-21', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Ana López', '12.345.678-9', 'ana.lopez@example.com', '$2b$10$abcdefg12345hijklmop67890', 'admin', '+56987654321', '1985-08-10', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Carlos Ramírez', '13.579.246-8', 'carlos.ramirez@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56911223344', '1992-03-15', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Lucía García', '14.683.925-7', 'lucia.garcia@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56922334455', '1998-12-22', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Pedro Fernández', '15.789.654-3', 'pedro.fernandez@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56933445566', '1979-11-01', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Marta Torres', '16.893.432-1', 'marta.torres@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56944556677', '2000-07-09', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Jorge Rodríguez', '17.987.321-0', 'jorge.rodriguez@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56955667788', '1995-04-18', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Sofía Vargas', '18.135.246-9', 'sofia.vargas@example.com', '$2b$10$abcdefg12345hijklmop67890', 'admin', '+56966778899', '1993-02-28', 'CL', NULL, '2024-08-19 09:01:38.146887'),
('Ricardo Morales', '19.246.135-8', 'ricardo.morales@example.com', '$2b$10$abcdefg12345hijklmop67890', 'user', '+56977889900', '1988-09-05', 'CL', NULL, '2024-08-19 09:01:38.146887');
{
"info": {
"name": "User API",
"description": "API for managing users including signup, login, and administrative actions.",
"schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json"
},
"item": [
{
"name": "Signup",
"request": {
"method": "POST",
"url": {
"raw": "http://localhost:3000/user/signup",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "signup"]
},
"header": [
{
"key": "Authorization",
"value": "Bearer <token>",
"type": "text"
}
],
"body": {
"mode": "json",
"json": {
"name": "string",
"rut": "string",
"email": "string",
"password": "string",
"role": "enum (USER, ADMIN)",
"phone": "string",
"birthday": "date",
"country": "string"
}
}
}
},
{
"name": "Login",
"request": {
"method": "POST",
"url": {
"raw": "http://localhost:3000/user/login",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "login"]
},
"body": {
"mode": "json",
"json": {
"email": "string",
"password": "string"
}
}
}
},
{
"name": "Get Profile",
"request": {
"method": "GET",
"url": {
"raw": "http://localhost:3000/user/profile",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "profile"]
},
"header": [
{
"key": "Authorization",
"value": "Bearer <token>",
"type": "text"
}
]
}
},
{
"name": "Get All Users",
"request": {
"method": "GET",
"url": {
"raw": "http://localhost:3000/user/all",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "all"]
},
"header": [
{
"key": "Authorization",
"value": "Bearer <token>",
"type": "text"
}
]
}
},
{
"name": "Update User",
"request": {
"method": "PATCH",
"url": {
"raw": "http://localhost:3000/user/update?rut={rut}",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "update"],
"query": [
{
"key": "rut",
"value": "string"
}
]
},
"header": [
{
"key": "Authorization",
"value": "Bearer <token>",
"type": "text"
}
],
"body": {
"mode": "json",
"json": {
"name": "string",
"email": "string",
}
}
}
},
{
"name": "Delete User",
"request": {
"method": "DELETE",
"url": {
"raw": "http://localhost:3000/user/delete/:id",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "delete", ":id"]
},
"header": [
{
"key": "Authorization",
"value": "Bearer <token>",
"type": "text"
}
]
}
},
{
"name": "Search Users",
"request": {
"method": "GET",
"url": {
"raw": "http://localhost:3000/user/search?query={query}",
"protocol": "http",
"host": ["localhost"],
"port": "3000",
"path": ["user", "search"],
"query": [
{
"key": "query",
"value": "string"
}
]
},
"header": [
{
"key": "Authorization",
"value": "Bearer <token>",
"type": "text"
}
]
}
}
]
}