56 lines
1.8 KiB
C#
56 lines
1.8 KiB
C#
using _0_Framework.Application;
|
|
using AccountManagement.Application.Contracts.TicketAccessAccount;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using ServiceHost.BaseControllers;
|
|
using ServiceHost.Controllers;
|
|
|
|
namespace ServiceHost.Areas.Admin.Controllers;
|
|
public record GetAdminProfileDetails(long Id, string Fullname, string Mobile, string RoleName,
|
|
List<int> Permissions, long? PositionValue,UserType UserType,bool HasTicketAccess);
|
|
|
|
public class LoginController:AdminBaseController
|
|
{
|
|
|
|
|
|
private readonly IAuthHelper _authHelper;
|
|
private readonly ITicketAccessAccountApplication _ticketAccessAccount;
|
|
public LoginController(IAuthHelper authHelper, ITicketAccessAccountApplication ticketAccessAccount)
|
|
{
|
|
_authHelper = authHelper;
|
|
_ticketAccessAccount = ticketAccessAccount;
|
|
}
|
|
/// <summary>
|
|
/// جزئیات پروفایل کاربر ادمین را برمی گرداند
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpGet("Profile")]
|
|
public ActionResult<GetAdminProfileDetails> GetProfile()
|
|
{
|
|
if (!_authHelper.IsAuthenticated())
|
|
return Unauthorized();
|
|
|
|
var data = _authHelper.CurrentAccountInfo();
|
|
if (data == null)
|
|
{
|
|
return NotFound("کاربر یافت نشد");
|
|
}
|
|
|
|
var userTypeWithId = _authHelper.GetUserTypeWithId();
|
|
if (userTypeWithId.userType is not UserType.Admin)
|
|
return Unauthorized();
|
|
|
|
var hasTicketAccess = _ticketAccessAccount.HasTicketAccess(data.Id);
|
|
|
|
var details = new GetAdminProfileDetails(
|
|
data.Id,
|
|
data.Fullname,
|
|
data.Mobile,
|
|
data.RoleName,
|
|
data.Permissions,
|
|
data.PositionValue,
|
|
userTypeWithId.userType,
|
|
hasTicketAccess
|
|
);
|
|
return details;
|
|
}
|
|
} |