Files
Yi.Admin/Yi.Furion.Net6/Yi.Furion.Application/Rbac/Event/LoginEventHandler.cs

76 lines
2.6 KiB
C#
Raw Normal View History

2023-04-13 21:12:06 +08:00
using Furion.EventBus;
using IPTools.Core;
using UAParser;
using Yi.Framework.Infrastructure.AspNetCore;
using Yi.Framework.Infrastructure.Ddd.Repositories;
using Yi.Framework.Infrastructure.Helper;
2023-04-15 17:33:42 +08:00
using Yi.Furion.Core.Rbac.Entities;
using Yi.Furion.Core.Rbac.Etos;
2023-04-13 21:12:06 +08:00
2023-04-15 17:33:42 +08:00
namespace Yi.Furion.Application.Rbac.Event
2023-04-13 21:12:06 +08:00
{
2023-04-15 22:44:33 +08:00
public class LoginEventHandler : IEventSubscriber,ISingleton
2023-04-13 21:12:06 +08:00
{
private readonly IRepository<LoginLogEntity> _loginLogRepository;
2023-04-15 22:44:33 +08:00
public LoginEventHandler(IRepository<LoginLogEntity> loginLogRepository)
2023-04-13 21:12:06 +08:00
{
_loginLogRepository = loginLogRepository;
}
2023-04-15 12:19:02 +08:00
//[EventSubscribe(nameof(LoginEventSource))]
2023-04-13 21:12:06 +08:00
public Task HandlerAsync(EventHandlerExecutingContext context)
{
2023-04-15 17:33:42 +08:00
var eventData = (LoginEventArgs)context.Source.Payload;
2023-04-15 22:44:33 +08:00
var loginLogEntity = GetLoginLogInfo(eventData.httpContext);
2023-04-13 21:12:06 +08:00
loginLogEntity.Id = SnowflakeHelper.NextId;
loginLogEntity.LogMsg = eventData.UserName + "登录系统";
loginLogEntity.LoginUser = eventData.UserName;
2023-04-15 22:44:33 +08:00
loginLogEntity.LoginIp = eventData.httpContext.GetClientIp();
2023-04-13 21:12:06 +08:00
_loginLogRepository.InsertAsync(loginLogEntity);
return Task.CompletedTask;
}
/// <summary>
/// 获取客户端信息
/// </summary>
/// <param name="context"></param>
/// <returns></returns>
private static ClientInfo GetClientInfo(HttpContext context)
{
var str = context.GetUserAgent();
var uaParser = Parser.GetDefault();
ClientInfo c = uaParser.Parse(str);
return c;
}
/// <summary>
/// 记录用户登陆信息
/// </summary>
/// <param name="context"></param>
/// <returns></returns>
private static LoginLogEntity GetLoginLogInfo(HttpContext context)
{
var ipAddr = context.GetClientIp();
IpInfo location;
if (ipAddr == "127.0.0.1")
{
location = new IpInfo() { Province = "本地", City = "本机" };
}
else
{
location = IpTool.Search(ipAddr);
}
ClientInfo clientInfo = GetClientInfo(context);
LoginLogEntity entity = new()
{
Browser = clientInfo.Device.Family,
Os = clientInfo.OS.ToString(),
LoginIp = ipAddr,
LoginLocation = location.Province + "-" + location.City
};
return entity;
}
}
}