mirror of
https://github.com/project-redbud/FunGame-Core.git
synced 2025-12-05 08:09:02 +00:00
重构RegModel
This commit is contained in:
parent
bbe634b8bb
commit
15ed5152de
@ -2,15 +2,18 @@
|
||||
{
|
||||
public class RegisterEventArgs : GeneralEventArgs
|
||||
{
|
||||
public string Username;
|
||||
public string Password;
|
||||
public string Email;
|
||||
public string Username { get; set; } = "";
|
||||
public string Password { get; set; } = "";
|
||||
public string Email { get; set; } = "";
|
||||
|
||||
public RegisterEventArgs(string username = "", string password = "", string email = "")
|
||||
public RegisterEventArgs(params object[]? objs)
|
||||
{
|
||||
Username = username;
|
||||
Password = password;
|
||||
Email = email;
|
||||
if (objs != null)
|
||||
{
|
||||
if (objs.Length > 0) Username = (string)objs[0];
|
||||
if (objs.Length > 1) Password = (string)objs[1];
|
||||
if (objs.Length > 2) Email = (string)objs[2];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -4,6 +4,8 @@ using Milimoe.FunGame.Desktop.Model;
|
||||
using Milimoe.FunGame.Core.Library.Constant;
|
||||
using Milimoe.FunGame.Desktop.UI;
|
||||
using Milimoe.FunGame.Core.Library.Common.Architecture;
|
||||
using Milimoe.FunGame.Core.Library.Exception;
|
||||
using Milimoe.FunGame.Core.Library.Common.Event;
|
||||
|
||||
namespace Milimoe.FunGame.Desktop.Controller
|
||||
{
|
||||
@ -23,26 +25,26 @@ namespace Milimoe.FunGame.Desktop.Controller
|
||||
RegModel.Dispose();
|
||||
}
|
||||
|
||||
public bool Reg(params object[]? objs)
|
||||
public async Task<bool> Reg(params object[]? objs)
|
||||
{
|
||||
if (Register.OnBeforeRegEvent(Register.EventArgs) == EventResult.Fail) return false;
|
||||
bool result = RegModel.Reg(objs);
|
||||
if (!result)
|
||||
{
|
||||
ShowMessage.ErrorMessage("注册失败!", "注册失败", 5);
|
||||
Register.OnFailedRegEvent(Register.EventArgs);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
bool result = false;
|
||||
|
||||
public bool CheckReg(params object[]? objs)
|
||||
{
|
||||
bool result = RegModel.CheckReg(objs);
|
||||
if (!result)
|
||||
try
|
||||
{
|
||||
ShowMessage.ErrorMessage("注册失败!", "注册失败", 5);
|
||||
RunTime.Register?.OnFailedRegEvent(Register.EventArgs);
|
||||
RegisterEventArgs RegEventArgs = new (objs);
|
||||
if (Register.OnBeforeRegEvent(RegEventArgs) == EventResult.Fail) return false;
|
||||
|
||||
result = await RegModel.Reg(objs);
|
||||
|
||||
if (result) Register.OnSucceedRegEvent(RegEventArgs);
|
||||
else Register.OnFailedRegEvent(RegEventArgs);
|
||||
Register.OnAfterRegEvent(RegEventArgs);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
RunTime.WritelnSystemInfo(e.GetErrorInfo());
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
@ -97,15 +97,12 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
{
|
||||
if (!Working) break;
|
||||
}
|
||||
if (Work != null)
|
||||
// 返回一个确认登录的Key
|
||||
if (Work.Length > 0) key = Work.GetParam<Guid>(0);
|
||||
if (Work.Length > 1) msg = Work.GetParam<string>(1);
|
||||
if (key != Guid.Empty)
|
||||
{
|
||||
// 返回一个确认登录的Key
|
||||
if (Work.Length > 0) key = Work.GetParam<Guid>(0);
|
||||
if (Work.Length > 1) msg = Work.GetParam<string>(1);
|
||||
if (key != Guid.Empty)
|
||||
{
|
||||
Config.Guid_LoginKey = key;
|
||||
}
|
||||
Config.Guid_LoginKey = key;
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
@ -125,11 +122,8 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
{
|
||||
if (!Working) break;
|
||||
}
|
||||
if (Work != null)
|
||||
{
|
||||
// 返回构造User对象的DataTable
|
||||
if (Work.Length > 0) ds = Work.GetParam<DataSet>(0);
|
||||
}
|
||||
// 返回构造User对象的DataSet
|
||||
if (Work.Length > 0) ds = Work.GetParam<DataSet>(0);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
|
||||
@ -12,6 +12,8 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
public class RegisterModel : BaseModel
|
||||
{
|
||||
private readonly Register Register;
|
||||
private SocketObject Work;
|
||||
private bool Working = false;
|
||||
|
||||
public RegisterModel(Register reg) : base(RunTime.Socket)
|
||||
{
|
||||
@ -22,21 +24,10 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
{
|
||||
try
|
||||
{
|
||||
SocketMessageType type = SocketObject.SocketType;
|
||||
object[] objs = SocketObject.Parameters;
|
||||
switch (SocketObject.SocketType)
|
||||
if (SocketObject.SocketType == SocketMessageType.Reg || SocketObject.SocketType == SocketMessageType.CheckReg)
|
||||
{
|
||||
case SocketMessageType.Reg:
|
||||
RegInvokeType invokeType = RegInvokeType.None;
|
||||
if (objs != null && objs.Length > 0)
|
||||
{
|
||||
invokeType = SocketObject.GetParam<RegInvokeType>(0);
|
||||
Register.UpdateUI(invokeType);
|
||||
}
|
||||
break;
|
||||
case SocketMessageType.CheckReg:
|
||||
SocketHandler_CheckReg(SocketObject);
|
||||
break;
|
||||
Work = SocketObject;
|
||||
Working = false;
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
@ -45,51 +36,7 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
}
|
||||
}
|
||||
|
||||
private void SocketHandler_CheckReg(SocketObject SocketObject)
|
||||
{
|
||||
if (SocketObject.Parameters != null && SocketObject.Parameters.Length > 1)
|
||||
{
|
||||
bool successful = SocketObject.GetParam<bool>(0)!;
|
||||
string msg = SocketObject.GetParam<string>(1)!;
|
||||
ShowMessage.Message(msg, "注册结果");
|
||||
if (successful)
|
||||
{
|
||||
Register.OnSucceedRegEvent(Register.EventArgs);
|
||||
Register.OnAfterRegEvent(Register.EventArgs);
|
||||
Register.Close();
|
||||
return;
|
||||
}
|
||||
}
|
||||
Register.OnFailedRegEvent(Register.EventArgs);
|
||||
Register.OnAfterRegEvent(Register.EventArgs);
|
||||
Register.UpdateUI(RegInvokeType.InputVerifyCode);
|
||||
}
|
||||
|
||||
public bool Reg(params object[]? objs)
|
||||
{
|
||||
try
|
||||
{
|
||||
Socket? Socket = RunTime.Socket;
|
||||
if (Socket != null && objs != null)
|
||||
{
|
||||
string username = "";
|
||||
string email = "";
|
||||
if (objs.Length > 0) username = (string)objs[0];
|
||||
if (objs.Length > 1) email = (string)objs[1];
|
||||
if (Socket.Send(SocketMessageType.Reg, username, email) == SocketResult.Success)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
RunTime.WritelnSystemInfo(e.GetErrorInfo());
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public bool CheckReg(params object[]? objs)
|
||||
public async Task<bool> Reg(params object[]? objs)
|
||||
{
|
||||
try
|
||||
{
|
||||
@ -99,15 +46,42 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
string username = "";
|
||||
string password = "";
|
||||
string email = "";
|
||||
string verifycode = "";
|
||||
if (objs.Length > 0) username = (string)objs[0];
|
||||
if (objs.Length > 1) password = (string)objs[1];
|
||||
password = password.Encrypt(username);
|
||||
if (objs.Length > 2) email = (string)objs[2];
|
||||
if (objs.Length > 3) verifycode = (string)objs[3];
|
||||
if (Socket.Send(SocketMessageType.CheckReg, username, password, email, verifycode) == SocketResult.Success)
|
||||
SetWorking();
|
||||
if (Socket.Send(SocketMessageType.Reg, username, email) == SocketResult.Success)
|
||||
{
|
||||
return true;
|
||||
RegInvokeType InvokeType = await Task.Factory.StartNew(GetRegInvokeType);
|
||||
while (true)
|
||||
{
|
||||
switch (InvokeType)
|
||||
{
|
||||
case RegInvokeType.InputVerifyCode:
|
||||
string verifycode = ShowMessage.InputMessageCancel("请输入注册邮件中的6位数字验证码", "注册验证码", out MessageResult cancel);
|
||||
if (cancel != MessageResult.Cancel)
|
||||
{
|
||||
SetWorking();
|
||||
if (Socket.Send(SocketMessageType.CheckReg, username, password, email, verifycode) == SocketResult.Success)
|
||||
{
|
||||
bool success = false;
|
||||
string msg = "";
|
||||
(success, msg) = await Task.Factory.StartNew(GetRegResult);
|
||||
ShowMessage.Message(msg, "注册结果");
|
||||
if (success) return success;
|
||||
}
|
||||
break;
|
||||
}
|
||||
else return false;
|
||||
case RegInvokeType.DuplicateUserName:
|
||||
ShowMessage.WarningMessage("此账号名已被注册,请使用其他账号名。");
|
||||
return false;
|
||||
case RegInvokeType.DuplicateEmail:
|
||||
ShowMessage.WarningMessage("此邮箱已被使用,请使用其他邮箱注册。");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -117,5 +91,49 @@ namespace Milimoe.FunGame.Desktop.Model
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private RegInvokeType GetRegInvokeType()
|
||||
{
|
||||
RegInvokeType type = RegInvokeType.None;
|
||||
try
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
if (!Working) break;
|
||||
}
|
||||
if (Work.Length > 0) type = Work.GetParam<RegInvokeType>(0);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
RunTime.WritelnSystemInfo(e.GetErrorInfo());
|
||||
}
|
||||
return type;
|
||||
}
|
||||
|
||||
private (bool, string) GetRegResult()
|
||||
{
|
||||
bool success = false;
|
||||
string? msg = "";
|
||||
try
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
if (!Working) break;
|
||||
}
|
||||
if (Work.Length > 0) success = Work.GetParam<bool>(0);
|
||||
if (Work.Length > 1) msg = Work.GetParam<string>(1) ?? "";
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
RunTime.WritelnSystemInfo(e.GetErrorInfo());
|
||||
}
|
||||
return (success, msg);
|
||||
}
|
||||
|
||||
private void SetWorking()
|
||||
{
|
||||
Working = true;
|
||||
Work = default;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -1303,7 +1303,7 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
if (!Config.FunGame_isRetrying)
|
||||
{
|
||||
CurrentRetryTimes = -1;
|
||||
Config.FunGame_isAutoLogin = true;
|
||||
Config.FunGame_isAutoRetry = true;
|
||||
RunTime.Connector?.Connect();
|
||||
}
|
||||
else
|
||||
@ -1313,7 +1313,7 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
if (!Config.FunGame_isConnected)
|
||||
{
|
||||
CurrentRetryTimes = -1;
|
||||
Config.FunGame_isAutoLogin = true;
|
||||
Config.FunGame_isAutoRetry = true;
|
||||
RunTime.Connector?.GetServerConnection();
|
||||
}
|
||||
break;
|
||||
@ -1357,7 +1357,7 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
Constant.Server_Address = ip;
|
||||
Constant.Server_Port = port;
|
||||
CurrentRetryTimes = -1;
|
||||
Config.FunGame_isAutoLogin = true;
|
||||
Config.FunGame_isAutoRetry = true;
|
||||
RunTime.Connector?.Connect();
|
||||
}
|
||||
else if (ErrorType == Core.Library.Constant.ErrorType.IsNotIP) ShowMessage.ErrorMessage("这不是一个IP地址!");
|
||||
|
||||
@ -12,7 +12,6 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
public partial class Register : BaseReg
|
||||
{
|
||||
public bool CheckReg { get; set; } = false;
|
||||
public RegisterEventArgs EventArgs { get; set; } = new RegisterEventArgs();
|
||||
|
||||
private readonly RegisterController RegController;
|
||||
|
||||
@ -34,7 +33,7 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
RegController.Dispose();
|
||||
}
|
||||
|
||||
private bool Reg_Handler()
|
||||
private async Task<bool> Reg_Handler()
|
||||
{
|
||||
try
|
||||
{
|
||||
@ -98,57 +97,13 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
EmailText.Focus();
|
||||
return false;
|
||||
}
|
||||
EventArgs = new RegisterEventArgs(username, password, email);
|
||||
if (!RegController.Reg(username, email))
|
||||
{
|
||||
ShowMessage.Message("注册失败!", "注册失败");
|
||||
return false;
|
||||
}
|
||||
return await RegController.Reg(username, password, email);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
RunTime.WritelnSystemInfo(e.GetErrorInfo());
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public void UpdateUI(RegInvokeType type)
|
||||
{
|
||||
try
|
||||
{
|
||||
void Action()
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case RegInvokeType.InputVerifyCode:
|
||||
string username = UsernameText.Text.Trim();
|
||||
string password = PasswordText.Text.Trim();
|
||||
string email = EmailText.Text.Trim();
|
||||
string verifycode = ShowMessage.InputMessageCancel("请输入注册邮件中的6位数字验证码", "注册验证码", out MessageResult cancel);
|
||||
if (cancel != MessageResult.Cancel) RegController.CheckReg(username, password, email, verifycode);
|
||||
else RegButton.Enabled = true;
|
||||
break;
|
||||
case RegInvokeType.DuplicateUserName:
|
||||
ShowMessage.WarningMessage("此账号名已被注册,请使用其他账号名。");
|
||||
RegButton.Enabled = true;
|
||||
break;
|
||||
case RegInvokeType.DuplicateEmail:
|
||||
ShowMessage.WarningMessage("此邮箱已被使用,请使用其他邮箱注册。");
|
||||
RegButton.Enabled = true;
|
||||
break;
|
||||
}
|
||||
};
|
||||
if (!IsDisposed)
|
||||
{
|
||||
if (InvokeRequired) Invoke(Action);
|
||||
else Action();
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
RunTime.WritelnSystemInfo(e.GetErrorInfo());
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -169,10 +124,11 @@ namespace Milimoe.FunGame.Desktop.UI
|
||||
return EventResult.Success;
|
||||
}
|
||||
|
||||
private void RegButton_Click(object sender, EventArgs e)
|
||||
private async void RegButton_Click(object sender, EventArgs e)
|
||||
{
|
||||
RegButton.Enabled = false;
|
||||
if (!Reg_Handler()) RegButton.Enabled = true;
|
||||
if (!await Reg_Handler()) RegButton.Enabled = true;
|
||||
else Dispose();
|
||||
}
|
||||
|
||||
private void GoToLogin_Click(object sender, EventArgs e)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user