Sic.Framework/MECF.Framework.Common/MECF/Framework/Common/Account/AccountExManager.cs

165 lines
4.6 KiB
C#
Raw Normal View History

2023-04-13 11:51:03 +08:00
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Reflection;
using System.ServiceModel;
using System.ServiceModel.Channels;
2023-04-13 11:51:03 +08:00
using System.Threading;
using Aitex.Common.Util;
using Aitex.Core.Account;
using Aitex.Core.RT.Event;
using Aitex.Core.RT.Log;
using Aitex.Core.Util;
using Aitex.Core.WCF;
using MECF.Framework.Common.Account.Extends;
using MECF.Framework.Common.Equipment;
2023-04-13 11:51:03 +08:00
namespace MECF.Framework.Common.Account
{
public class AccountExManager : Singleton<AccountExManager>
{
#region Variables
2023-04-13 11:51:03 +08:00
2023-08-29 11:16:43 +08:00
private readonly Dictionary<string, LoginResult> _dicLoginNameToLoginResult = new ();
private readonly Dictionary<string, LoginResult> _dicSessionIdToLoginResult = new ();
private readonly string _scAccountFile = PathManager.GetCfgDir() + "Account//Account.xml";
private readonly string _scAccountLocalFile = PathManager.GetCfgDir() + "Account//_Account.xml";
2023-04-13 11:51:03 +08:00
#endregion
#region Properties
2023-04-13 11:51:03 +08:00
/// <summary>
///
/// </summary>
2023-04-13 11:51:03 +08:00
public RoleLoader RoleLoader { get; private set; }
#endregion
#region Methods
/// <summary>
/// 初始化当前对象。
/// </summary>
/// <param name="enableService"></param>
/// <exception cref="ApplicationException"></exception>
2023-04-13 11:51:03 +08:00
public void Initialize(bool enableService)
{
if (!File.Exists(_scAccountLocalFile))
{
if (!File.Exists(_scAccountFile))
{
throw new ApplicationException("Can not initialize account configuration file, " + _scAccountFile);
}
File.Copy(_scAccountFile, _scAccountLocalFile);
Thread.Sleep(10);
}
RoleLoader = new RoleLoader(_scAccountLocalFile);
RoleLoader.Load();
if (enableService)
{
Singleton<WcfServiceManager>.Instance.Initialize(new Type[1] { typeof(AccountService) });
}
}
private RemoteEndpointMessageProperty GetCurrentEndPoint()
{
var context = OperationContext.Current;
var prop = context.IncomingMessageProperties;
var endpoint =
prop[RemoteEndpointMessageProperty.Name] as RemoteEndpointMessageProperty;
return endpoint;
}
public LoginResult AuthLogin(string loginName, string password, string role, LoginClientInfo clientInfo)
2023-04-13 11:51:03 +08:00
{
var endPoint = GetCurrentEndPoint();
var loginResult = new LoginResult
2023-04-13 11:51:03 +08:00
{
ActSucc = true,
SessionId = Guid.NewGuid().ToString(),
LoginIP = endPoint.Address,
LoginPort = endPoint.Port,
LoginTime = DateTime.Now
2023-04-13 11:51:03 +08:00
};
2023-04-13 11:51:03 +08:00
try
{
var accountList = RoleLoader.AccountList;
var accountEx = accountList.FirstOrDefault(x => x.LoginName == loginName);
2023-04-13 11:51:03 +08:00
if (accountEx == null)
{
loginResult.ActSucc = false;
loginResult.Description = AuthorizeResult.NoMatchUser.ToString();
}
else
{
foreach (var account in accountList)
2023-04-13 11:51:03 +08:00
{
if (account.LoginName == loginName && account.Password == password)
2023-04-13 11:51:03 +08:00
{
foreach (var roleId in account.RoleIDs)
2023-04-13 11:51:03 +08:00
{
if (roleId == role)
2023-04-13 11:51:03 +08:00
{
loginResult.ActSucc = true;
loginResult.AccountEx = account;
2023-04-13 11:51:03 +08:00
loginResult.Description = AuthorizeResult.None.ToString();
if (_dicLoginNameToLoginResult.TryGetValue(loginName, out var loggedInfo))
2023-04-13 11:51:03 +08:00
{
// 如果当前用户从其它电脑登录,则踢掉之
_dicSessionIdToLoginResult.Remove(loggedInfo.SessionId);
EV.PostKickoutMessage(
"The current account has been logged in from other places, and the current client is forced to switch to read-only mode");
2023-04-13 11:51:03 +08:00
}
_dicLoginNameToLoginResult[loginName] = loginResult;
_dicSessionIdToLoginResult[loginResult.SessionId] = loginResult;
EV.PostMessage(ModuleName.System.ToString(), EventEnum.UserLoggedIn, loginResult);
2023-04-13 11:51:03 +08:00
return loginResult;
}
// 登录失败,当前账户不在指定的角色中。
2023-04-13 11:51:03 +08:00
loginResult.ActSucc = false;
loginResult.Description = AuthorizeResult.NoMatchRole.ToString();
}
return loginResult;
}
// 登录失败,密码错误
2023-04-13 11:51:03 +08:00
loginResult.ActSucc = false;
loginResult.Description = AuthorizeResult.WrongPwd.ToString();
}
}
}
catch (Exception ex)
{
LOG.Error(ex.Message, ex);
}
return loginResult;
}
internal void Logout(string loginName, string sessionId)
2023-04-13 11:51:03 +08:00
{
foreach (var key in _dicLoginNameToLoginResult.Keys)
2023-04-13 11:51:03 +08:00
{
if (loginName == key && _dicLoginNameToLoginResult[key].SessionId == sessionId)
2023-04-13 11:51:03 +08:00
{
EV.PostMessage(ModuleName.System.ToString(), EventEnum.UserLoggedOff, _dicLoginNameToLoginResult[loginName]);
_dicLoginNameToLoginResult.Remove(loginName);
_dicSessionIdToLoginResult.Remove(key);
2023-04-13 11:51:03 +08:00
break;
}
}
}
#endregion
2023-04-13 11:51:03 +08:00
}
}