1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- using System.Transactions;
- using Microsoft.AspNetCore.Authorization;
- using Microsoft.AspNetCore.Mvc;
- using UnivateProperties_API.Containers.Users;
- using UnivateProperties_API.Model.Users;
- using UnivateProperties_API.Repository;
- using UnivateProperties_API.Repository.Users;
-
- namespace User_API.Controllers
- {
-
- [Route("api/[controller]")]
- [ApiController]
- public class UserController : ControllerBase
- {
- private readonly IUserRepository _Repo;
-
- public UserController(IUserRepository repo)
- {
- _Repo = repo;
- }
-
-
- [HttpGet]
- public IActionResult Get()
- {
- return new OkObjectResult(_Repo.GetAll());
- }
-
- [HttpGet("{id}")]
- public IActionResult Get(int id)
- {
- var currentUserId = int.Parse(User.Identity.Name);
- if (id != currentUserId && !User.IsInRole(Role.SuperAdmin))
- {
- return Forbid();
- }
- return new OkObjectResult(_Repo.Get(x => x.Id == id));
- }
-
- [HttpPost()]
- public IActionResult Post([FromBody] User user)
- {
- using (var scope = new TransactionScope())
- {
- _Repo.Insert(user);
- scope.Complete();
- return CreatedAtAction(nameof(Get), new { id = user.Id }, user);
- }
- }
-
- [HttpPut()]
- public IActionResult Put([FromBody] UserDto user)
- {
- if (user != null)
- {
- using (var scope = new TransactionScope())
- {
- _Repo.Update(user);
- scope.Complete();
- return new OkResult();
- }
- }
- return new NoContentResult();
- }
-
- [HttpDelete("{id}")]
- public IActionResult Delete(int id)
- {
- _Repo.RemoveAtId(id);
- return new OkResult();
- }
- }
- }
|