UserController.cs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. using System;
  2. using Common;
  3. using Common.Constant;
  4. using Common.Http;
  5. using Database.Database;
  6. using Esim.Apis.Business;
  7. using Microsoft.AspNetCore.Authorization;
  8. using Microsoft.AspNetCore.Mvc;
  9. namespace RevoSystem.Apis.Controllers
  10. {
  11. [ApiController]
  12. public class UserController : Controller
  13. {
  14. private static readonly log4net.ILog log = log4net.LogManager.GetLogger(
  15. typeof(UserController)
  16. );
  17. ModelContext dbContext;
  18. IConfiguration configuration;
  19. IUserBusiness userBusiness;
  20. public UserController(
  21. IConfiguration _configuration,
  22. IUserBusiness userBusiness,
  23. ModelContext dbContext
  24. )
  25. {
  26. configuration = _configuration;
  27. this.userBusiness = userBusiness;
  28. this.dbContext = dbContext;
  29. }
  30. private string GetParameter(string key)
  31. {
  32. return configuration.GetSection(key).Value ?? "";
  33. }
  34. /// <summary>
  35. /// Request OTP via email
  36. /// POST /apis/auth/request-otp
  37. /// </summary>
  38. [HttpPost]
  39. [Route(ApiUrlConstant.RequestOtpUrl)]
  40. public async Task<IActionResult> RequestOtp([FromBody] RequestOtpReq request)
  41. {
  42. return await userBusiness.RequestOtp(HttpContext.Request, request);
  43. }
  44. /// <summary>
  45. /// Resend OTP via email
  46. /// POST /apis/auth/resend-otp
  47. /// </summary>
  48. [HttpPost]
  49. [Route(ApiUrlConstant.ResendOtpUrl)]
  50. public async Task<IActionResult> ResendOtp([FromBody] RequestOtpReq request)
  51. {
  52. return await userBusiness.ResendOtp(HttpContext.Request, request);
  53. }
  54. /// <summary>
  55. /// Verify OTP and complete login
  56. /// POST /apis/auth/verify-otp
  57. /// </summary>
  58. [HttpPost]
  59. [Route(ApiUrlConstant.VerifyOtpUrl)]
  60. public async Task<IActionResult> VerifyOtp([FromBody] VerifyOtpReq request)
  61. {
  62. return await userBusiness.VerifyOtp(HttpContext.Request, request);
  63. }
  64. /// <summary>
  65. /// Get Google Login URL
  66. /// POST /apis/auth/google-login
  67. /// </summary>
  68. /// <param name="request">Contains optional 'lang' parameter for response message language</param>
  69. /// <returns>Returns JSON object with 'url' property containing the Google OAuth2 authorization URL</returns>
  70. [ProducesResponseType(typeof(object), 200)]
  71. [HttpPost]
  72. [Route(ApiUrlConstant.GoogleLoginUrl)]
  73. public async Task<IActionResult> GoogleLogin([FromBody] GoogleLoginReq request)
  74. {
  75. return await userBusiness.GoogleLogin(
  76. HttpContext.Request,
  77. request ?? new GoogleLoginReq()
  78. );
  79. }
  80. /// <summary>
  81. /// Google OAuth Callback (Exchange code for token)
  82. /// POST /apis/auth/google-callback
  83. /// </summary>
  84. /// <param name="request">Contains the authorization 'code' (required) and 'redirectUri' (optional)</param>
  85. /// <returns>Returns user profile and JWT tokens (accessToken, refreshToken)</returns>
  86. [ProducesResponseType(typeof(object), 200)]
  87. [HttpPost]
  88. [Route(ApiUrlConstant.GoogleCallbackUrl)]
  89. public async Task<IActionResult> GoogleCallback([FromBody] GoogleCallbackReq request)
  90. {
  91. return await userBusiness.GoogleCallback(HttpContext.Request, request);
  92. }
  93. }
  94. }