100 lines
3.7 KiB
C#
100 lines
3.7 KiB
C#
using DAL;
|
|
using DAL._Shared.SharedModels;
|
|
using DAL._Shared.SharedRepositories;
|
|
using HRD.LDAPService.JWT;
|
|
using HRD.WebApi.Controllers;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Net.Http.Headers;
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace StaffDBServer.SharedControllers
|
|
{
|
|
[JWTAuthorize]
|
|
public class WebAppUserController : BaseMiniController
|
|
{
|
|
private readonly WebAppUserRepository webAppUserRepository;
|
|
private readonly WebAppUserHelper webAppUserHelper;
|
|
|
|
public WebAppUserController(WebApiContext context, WebAppUserRepository webAppUserRepository, WebAppUserHelper webAppUserHelper) : base(context)
|
|
{
|
|
this.webAppUserRepository = webAppUserRepository;
|
|
this.webAppUserHelper = webAppUserHelper;
|
|
}
|
|
|
|
[HttpPost("Culture")]
|
|
public async Task<IActionResult> UpdateCultureAsync([FromBody] WebAppUser userFromClient)
|
|
{
|
|
try
|
|
{
|
|
WebAppUser userFromDB = await webAppUserRepository.GetByAsync(u => u.LoginName == userFromClient.LoginName, false);
|
|
|
|
if (userFromDB != default) //first login, get User from WebAppEmployeeInfo
|
|
{
|
|
userFromDB.Language = userFromClient.Language;
|
|
userFromDB.Culture = userFromClient.Culture;
|
|
if (!await webAppUserRepository.UpdateAsync(userFromDB))
|
|
{
|
|
return StatusCode(StatusCodes.Status400BadRequest, $"Cannot set User's language/culture");
|
|
}
|
|
}
|
|
return new OkObjectResult(userFromClient);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
WriteLogException(ex, ex.Message);
|
|
return StatusCode(StatusCodes.Status400BadRequest, $"Cannot set User's language/culture");
|
|
}
|
|
}
|
|
|
|
[HttpPost("LoginWithJWT")]
|
|
public async Task<IActionResult> LoginWithAuthorizationAsync([FromBody] WebAppUser userFromClient)
|
|
{
|
|
try
|
|
{
|
|
var accessToken = Request.Headers[HeaderNames.Authorization];
|
|
|
|
WebAppUser result = await webAppUserHelper.CheckLoginWithJWTAsync(accessToken, userFromClient.ClientVersion);
|
|
return new OkObjectResult(result);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
WriteLogException(ex, ex.Message);
|
|
return Unauthorized(ex.Message);
|
|
}
|
|
}
|
|
|
|
[HttpPost("LoginWithNameAndPassword/{webApiId}"),]
|
|
[Microsoft.AspNetCore.Authorization.AllowAnonymous]
|
|
public async Task<IActionResult> LoginWithNameAndPasswordAsync([FromBody] WebAppUser userFromClient, int webApiId)
|
|
{
|
|
try
|
|
{
|
|
var result = await webAppUserHelper.CheckLoginWithNameAndPasswordAsync(userFromClient, webApiId);
|
|
return new OkObjectResult(result);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
WriteLogException(ex, ex.Message);
|
|
return NotFound(ex.Message);
|
|
}
|
|
}
|
|
|
|
[HttpPost("LoginWithNameAndPassword")]
|
|
[Microsoft.AspNetCore.Authorization.AllowAnonymous]
|
|
public async Task<IActionResult> LoginWithNameAndPasswordAsync([FromBody] WebAppUser userFromClient)
|
|
{
|
|
try
|
|
{
|
|
var result = await webAppUserHelper.CheckLoginWithNameAndPasswordAsync(userFromClient);
|
|
return new OkObjectResult(result);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
WriteLogException(ex, ex.Message);
|
|
return NotFound(ex.Message);
|
|
}
|
|
}
|
|
}
|
|
} |