feat: harden auth ops and deployment baseline

This commit is contained in:
2026-06-27 10:53:53 +09:00
parent a6ca30eec8
commit 28060b71be
41 changed files with 714 additions and 208 deletions
+31 -14
View File
@@ -1,7 +1,6 @@
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using TaxBaik.Application.Services;
using TaxBaik.Domain.Interfaces;
namespace TaxBaik.Web.Controllers;
@@ -10,29 +9,40 @@ namespace TaxBaik.Web.Controllers;
public class InquiryController : ControllerBase
{
private readonly InquiryService _inquiryService;
private readonly IInquiryRepository _inquiryRepository;
public InquiryController(InquiryService inquiryService, IInquiryRepository inquiryRepository)
public InquiryController(InquiryService inquiryService)
{
_inquiryService = inquiryService;
_inquiryRepository = inquiryRepository;
}
[HttpPost]
public async Task<IActionResult> Submit([FromBody] SubmitInquiryRequest request)
{
if (string.IsNullOrWhiteSpace(request.Name) || string.IsNullOrWhiteSpace(request.Phone))
return BadRequest(new { message = "Name and phone are required" });
return BadRequest(new ProblemDetails { Title = "이름과 전화번호를 입력하세요.", Status = StatusCodes.Status400BadRequest });
await _inquiryService.SubmitAsync(request.Name, request.Phone, request.ServiceType, request.Message);
return Ok(new { message = "Inquiry submitted successfully" });
try
{
await _inquiryService.SubmitAsync(
request.Name,
request.Phone,
request.ServiceType,
request.Message,
request.Email,
HttpContext.Connection.RemoteIpAddress?.ToString());
return Ok(new { message = "상담 신청이 접수되었습니다." });
}
catch (ValidationException ex)
{
return BadRequest(new ProblemDetails { Title = ex.Message, Status = StatusCodes.Status400BadRequest });
}
}
[HttpGet]
[Authorize]
public async Task<IActionResult> GetPaged([FromQuery] int page = 1, [FromQuery] int pageSize = 20)
{
var (inquiries, total) = await _inquiryRepository.GetPagedAsync(page, pageSize);
var (inquiries, total) = await _inquiryService.GetPagedAsync(page, pageSize);
return Ok(new { data = inquiries, total, page, pageSize });
}
@@ -40,9 +50,9 @@ public class InquiryController : ControllerBase
[Authorize]
public async Task<IActionResult> GetById(int id)
{
var inquiry = await _inquiryRepository.GetByIdAsync(id);
var inquiry = await _inquiryService.GetByIdAsync(id);
if (inquiry == null)
return NotFound(new { message = "Inquiry not found" });
return NotFound(new ProblemDetails { Title = "문의를 찾을 수 없습니다.", Status = StatusCodes.Status404NotFound });
return Ok(inquiry);
}
@@ -50,12 +60,19 @@ public class InquiryController : ControllerBase
[Authorize]
public async Task<IActionResult> UpdateStatus(int id, [FromBody] UpdateStatusRequest request)
{
var inquiry = await _inquiryRepository.GetByIdAsync(id);
var inquiry = await _inquiryService.GetByIdAsync(id);
if (inquiry == null)
return NotFound(new { message = "Inquiry not found" });
return NotFound(new ProblemDetails { Title = "문의를 찾을 수 없습니다.", Status = StatusCodes.Status404NotFound });
await _inquiryRepository.UpdateStatusAsync(id, request.Status);
return Ok(new { message = "Status updated" });
try
{
await _inquiryService.UpdateStatusAsync(id, request.Status);
return Ok(new { message = "상태가 변경되었습니다." });
}
catch (ValidationException ex)
{
return BadRequest(new ProblemDetails { Title = ex.Message, Status = StatusCodes.Status400BadRequest });
}
}
}