using BPA.SAAS.Manage.Application.Auth.Dtos;
using BPA.SAAS.Manage.Comm.Const;
using BPA.SAAS.Manage.Comm.Enum;
using BPA.SAAS.Manage.Core.Org;
using Mapster;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace BPA.SAAS.Manage.Application.Auth
{
public class AuthService : IAuthService, IDynamicApiController
{
private readonly ISqlSugarClient _db;
private readonly IHttpContextAccessor _httpContextAccessor;
public AuthService(ISqlSugarClient db, IHttpContextAccessor httpContextAccessor)
{
_db = db;
_httpContextAccessor = httpContextAccessor;
}
///
/// 用户名密码登录
///
/// 1平台用户登录,0加盟商登录
///
///
[HttpPost("/api/auth/login")]
[AllowAnonymous]
public async Task Login([FromHeader] string logintype, [Required] LoginInput input)
{
// 获取加密后的密码
var encryptPasswod = MD5Encryption.Encrypt(input.Password).ToLower();
// 判断用户名和密码是否正确 忽略全局过滤器
var user = await _db.Queryable().Where(u => u.Account.Equals(input.Account)
&& u.Password.Equals(encryptPasswod)
&& u.IsDeleted == 0
).FirstAsync();
_ = user ?? throw Oops.Oh("用户名或密码不正确");
//获取权限
List conModels = new List();
conModels.Add(new ConditionalModel() { FieldName = "Id", ConditionalType = ConditionalType.Equal, FieldValue = user.GroupId });
conModels.Add(new ConditionalModel() { FieldName = "Status", ConditionalType = ConditionalType.Equal, FieldValue = CommonStatus.ENABLE.ToString() });
conModels.Add(new ConditionalModel() { FieldName = "IsDeleted", ConditionalType = ConditionalType.Equal, FieldValue ="0" });
//if (user.AdminType != 1)
//{
// conModels.Add(new ConditionalModel() { FieldName = "Type", ConditionalType = ConditionalType.Equal, FieldValue = input.Type.ToString() });
//}
var company = _db.Queryable().Where(conModels).First();
string CLAINM_SUPERADMIN = "Customer";
if (user.AdminType == 1)
{
CLAINM_SUPERADMIN = "1";
}
_ = company ?? throw Oops.Oh("企业被锁定,请联系管理员");
var accessToken = JWTEncryption.Encrypt(new Dictionary
{
{ ClaimConst.CLAINM_USERID, user.Id },
{ ClaimConst.LoginType, 0},
{ ClaimConst.CLAINM_ACCOUNT, user.Account },
{ ClaimConst.CLAINM_NAME, user.Name },
{ ClaimConst.CLAINM_SUPERADMIN, CLAINM_SUPERADMIN },
{ ClaimConst.GroupId, user.GroupId},
{ ClaimConst.OrgId,user.SysOrgId},
//{ ClaimConst.SupplyPlatformId,company?.SupplyPlatformId}
}, 1440);
// 设置Swagger自动登录
// _httpContextAccessor.SigninToSwagger(accessToken);
// 生成刷新Token令牌
var refreshToken = JWTEncryption.GenerateRefreshToken(accessToken, 1445);
_httpContextAccessor.HttpContext.Response.Headers["access-token"] = accessToken;
// 设置刷新Token令牌
_httpContextAccessor.HttpContext.Response.Headers["x-access-token"] = refreshToken;
LoginOutInfo loginOutInfo = new LoginOutInfo()
{
userID = user.Id,
token = accessToken
};
return loginOutInfo;
}
///
/// 获取当前登录用户信息
///
///
[HttpGet("/api/auth/getLoginUser")]
[AllowAnonymous]
public async Task GetLoginUserAsync()
{
string userid = App.User.FindFirst(ClaimConst.CLAINM_USERID)?.Value;
var user = await _db.Queryable().Where(u => u.Id == userid).FirstAsync();
if (user != null)
{
var reslut = user.Adapt();
return reslut;
}
else
{
throw Oops.Oh($"用户不存在");
}
}
///
/// 退出
///
///
[HttpGet("/api/auth/logout")]
public async Task LogoutAsync()
{
// _httpContextAccessor.SignoutToSwagger();
await Task.CompletedTask;
}
}
}