blob: fbbbbffa0b094ab97b53d28581897c0e6a962928 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
using System;
using System.Threading.Tasks;
using AutoMapper;
using DevHive.Services.Models.Identity.User;
using DevHive.Web.Models.Identity.User;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using DevHive.Common.Models.Identity;
using DevHive.Services.Interfaces;
using Microsoft.AspNetCore.JsonPatch;
using DevHive.Common.Models.Misc;
using System.Collections.Generic;
namespace DevHive.Web.Controllers
{
[ApiController]
[Route("/api/[controller]")]
[Authorize(Roles = "User")]
public class UserController : ControllerBase
{
private readonly IUserService _userService;
private readonly IMapper _userMapper;
public UserController(IUserService userService, IMapper mapper)
{
this._userService = userService;
this._userMapper = mapper;
}
#region Authentication
[HttpPost]
[Route("Login")]
[AllowAnonymous]
public async Task<IActionResult> Login([FromBody] LoginWebModel loginModel)
{
LoginServiceModel loginServiceModel = this._userMapper.Map<LoginServiceModel>(loginModel);
TokenModel TokenModel = await this._userService.LoginUser(loginServiceModel);
TokenWebModel tokenWebModel = this._userMapper.Map<TokenWebModel>(TokenModel);
return new OkObjectResult(tokenWebModel);
}
[HttpPost]
[Route("Register")]
[AllowAnonymous]
public async Task<IActionResult> Register([FromBody] RegisterWebModel registerModel)
{
RegisterServiceModel registerServiceModel = this._userMapper.Map<RegisterServiceModel>(registerModel);
TokenModel TokenModel = await this._userService.RegisterUser(registerServiceModel);
TokenWebModel tokenWebModel = this._userMapper.Map<TokenWebModel>(TokenModel);
return new CreatedResult("Register", tokenWebModel);
}
#endregion
#region Read
[HttpGet]
public async Task<IActionResult> GetById(Guid id, [FromHeader] string authorization)
{
if (!await this._userService.ValidJWT(id, authorization))
return new UnauthorizedResult();
UserServiceModel userServiceModel = await this._userService.GetUserById(id);
UserWebModel userWebModel = this._userMapper.Map<UserWebModel>(userServiceModel);
return new OkObjectResult(userWebModel);
}
[HttpGet]
[Route("GetUser")]
[AllowAnonymous]
public async Task<IActionResult> GetUser(string username)
{
UserServiceModel friendServiceModel = await this._userService.GetUserByUsername(username);
UserWebModel friend = this._userMapper.Map<UserWebModel>(friendServiceModel);
return new OkObjectResult(friend);
}
#endregion
#region Update
[HttpPut]
public async Task<IActionResult> Update(Guid id, [FromBody] UpdateUserWebModel updateUserWebModel, [FromHeader] string authorization)
{
if (!await this._userService.ValidJWT(id, authorization))
return new UnauthorizedResult();
UpdateUserServiceModel updateUserServiceModel = this._userMapper.Map<UpdateUserServiceModel>(updateUserWebModel);
updateUserServiceModel.Id = id;
UserServiceModel userServiceModel = await this._userService.UpdateUser(updateUserServiceModel);
UserWebModel userWebModel = this._userMapper.Map<UserWebModel>(userServiceModel);
return new AcceptedResult("UpdateUser", userWebModel);
}
#endregion
#region Delete
[HttpDelete]
public async Task<IActionResult> Delete(Guid id, [FromHeader] string authorization)
{
if (!await this._userService.ValidJWT(id, authorization))
return new UnauthorizedResult();
await this._userService.DeleteUser(id);
return new OkResult();
}
#endregion
}
}
|