using API.Application.Users.Commands; using API.Application.Users.Queries; using API.Models; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using Microsoft.IdentityModel.Tokens; using System.IdentityModel.Tokens.Jwt; using System.Security.Claims; using System.Text; using System.Text.RegularExpressions; namespace API.Controllers { [Route("api/[controller]")] [ApiController] public class UsersController : ControllerBase { private readonly QueryAllUsers _queryAllUsers; private readonly QueryUserById _queryUserById; private readonly CreateUser _createUser; private readonly UpdateUser _updateUser; private readonly DeleteUser _deleteUser; private readonly LoginUser _loginUser; public UsersController( QueryAllUsers queryAllUsers, QueryUserById queryUserById, CreateUser createUser, UpdateUser updateUser, DeleteUser deleteUser, LoginUser loginUser) { _queryAllUsers = queryAllUsers; _queryUserById = queryUserById; _createUser = createUser; _updateUser = updateUser; _deleteUser = deleteUser; _loginUser = loginUser; } // POST: api/Users/login [HttpPost("login")] public async Task Login(LoginDTO login) { return await _loginUser.Handle(login); } // GET: api/Users [HttpGet] public async Task>> GetUsers() { return await _queryAllUsers.Handle(); } // GET: api/Users/5 [HttpGet("{id}")] public async Task> GetUser(string id) { return await _queryUserById.Handle(id); } // PUT: api/Users/5 // To protect from overposting attacks, see https://go.microsoft.com/fwlink/?linkid=2123754 [HttpPut("{id}")] public async Task PutUser(UserDTO userDTO) { return await _updateUser.Handle(userDTO); } // POST: api/Users // To protect from overposting attacks, see https://go.microsoft.com/fwlink/?linkid=2123754 [HttpPost] public async Task> PostUser(SignUpDTO signUpDTO) { return await _createUser.Handle(signUpDTO); } // DELETE: api/Users/5 [HttpDelete("{id}")] public async Task DeleteUser(string id) { return await _deleteUser.Handle(id); } } }