aboutsummaryrefslogtreecommitdiff
path: root/Timeline/Controllers/UserDetailController.cs
blob: 5e1183c10c3f1acd0d34e667d8c66bbdbfa8dc66 (plain)
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
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using System.Threading.Tasks;
using Timeline.Authenticate;
using Timeline.Models;
using Timeline.Models.Http;
using Timeline.Services;

namespace Timeline.Controllers
{
    [Route("users/{username}")]
    [ProducesErrorResponseType(typeof(CommonResponse))]
    [ApiController]
    public class UserDetailController : Controller
    {
        public static class ErrorCodes
        {
            public const int Get_UserNotExist = -1001;

            public const int Patch_Forbid = -2001;
            public const int Patch_UserNotExist = -2002;

            public const int GetNickname_UserNotExist = -3001;
        }

        private readonly ILogger<UserDetailController> _logger;
        private readonly IUserDetailService _service;

        public UserDetailController(ILogger<UserDetailController> logger, IUserDetailService service)
        {
            _logger = logger;
            _service = service;
        }

        [HttpGet("nickname")]
        [UserAuthorize]
        [ProducesResponseType(StatusCodes.Status200OK, Type = typeof(UserDetail))]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public async Task<IActionResult> GetNickname([FromRoute] string username)
        {
            try
            {
                var nickname = await _service.GetUserNickname(username);
                return Ok(new UserDetail
                {
                    Nickname = nickname
                });
            }
            catch (UserNotExistException)
            {
                return NotFound(new CommonResponse(ErrorCodes.GetNickname_UserNotExist, "The user does not exist."));
            }
        }

        [HttpGet("details")]
        [UserAuthorize]
        [ProducesResponseType(StatusCodes.Status200OK, Type = typeof(UserDetail))]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public async Task<IActionResult> Get([FromRoute] string username)
        {
            try
            {
                var detail = await _service.GetUserDetail(username);
                return Ok(detail);
            }
            catch (UserNotExistException)
            {
                return NotFound(new CommonResponse(ErrorCodes.Get_UserNotExist, "The user does not exist."));
            }
        }

        [HttpPatch("details")]
        [Authorize]
        [ProducesResponseType(StatusCodes.Status200OK, Type = typeof(void))]
        [ProducesResponseType(StatusCodes.Status400BadRequest)]
        [ProducesResponseType(StatusCodes.Status403Forbidden)]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public async Task<IActionResult> Patch([FromRoute] string username, [FromBody] UserDetail detail)
        {
            if (!User.IsAdmin() && User.Identity.Name != username)
                return StatusCode(StatusCodes.Status403Forbidden, new CommonResponse(ErrorCodes.Patch_Forbid, "You can't change other's details unless you are admin."));

            try
            {
                await _service.UpdateUserDetail(username, detail);
                return Ok();
            }
            catch (UserNotExistException)
            {
                return NotFound(new CommonResponse(ErrorCodes.Patch_UserNotExist, "The user does not exist."));
            }
        }
    }
}