Finish login-register-system

This commit is contained in:
VegaZ
2018-09-20 20:20:44 +02:00
parent 7452fc4993
commit 8a5daf483f
2 changed files with 58 additions and 33 deletions

View File

@@ -9,7 +9,6 @@ loginBrowser = mp.browsers.new('package://Login/login.html');
mp.gui.chat.activate(false);
mp.gui.cursor.show(true);
mp.events.add('loginInformationToServer', (password) => {
mp.events.callRemote('OnPlayerLogin', password);
@@ -21,11 +20,6 @@ mp.events.add('registerInformationToServer', (password) => {
});
mp.events.add('showLogin',() => {
loginBrowser = mp.browsers.new('package://Login/login.html');
mp.gui.cursor.show(true);
});
mp.events.add('registerSuccess', () => {
mp.gui.chat.push("Erfolgreich registriert!")
if (loginBrowser)
@@ -52,3 +46,19 @@ mp.events.add('loginFail', (reason) => {
mp.gui.chat.push(reason);
});
mp.events.add('loginDeny', (reason) => {
if (loginBrowser) {
loginBrowser.destroy();
}
mp.gui.cursor.show(false);
mp.gui.chat.activate(true);
mp.gui.chat.push(reason);
});
mp.events.add('registerFail', (reason) => {
mp.gui.chat.push(reason);
});

View File

@@ -17,44 +17,59 @@ namespace reallife_gamemode.Server.Events
[RemoteEvent("OnPlayerLogin")]
public void OnPlayerLogin(Client player, string password)
{
string checkPassword = null;
using (var loginContext = new Model.DatabaseContext())
using (var loginUser = new Model.DatabaseContext())
{
var user = loginContext.Users.SingleOrDefault(b => b.Name == player.Name);
if(user.Password == null)
var user = loginUser.Users.SingleOrDefault(b => b.Name == player.Name);
if(user == null)
{
player.TriggerEvent("loginFail", "Benutzer existiert nicht! Registriere dich zuerst!");
}
else
{
checkPassword = user.Password;
}
}
if(checkPassword == NAPI.Util.GetHashSha256(password))
if (user.SocialClubName != player.SocialClubName && user.Password == NAPI.Util.GetHashSha256(password))
{
player.TriggerEvent("loginSuccess");
player.TriggerEvent("loginDeny", "Dieser Benutzer gehört dir nicht!");
//Log einbauen für den bösen Bub.
player.Kick();
}
if (user.Password != NAPI.Util.GetHashSha256(password))
{
player.TriggerEvent("loginFail", "Passwort inkorrekt!");
}
else
{
player.TriggerEvent("loginFail","Passwort inkorrekt!");
player.TriggerEvent("loginSuccess");
}
}
[Command("login")]
public void CmdLogin(Client player)
{
player.TriggerEvent("showLogin",player);
}
}
[RemoteEvent("OnPlayerRegister")]
public void OnPlayerRegister(Client player, string password)
{
using (var registerContext = new Model.DatabaseContext())
using (var checkUser = new Model.DatabaseContext())
{
var checkedUser = checkUser.Users.SingleOrDefault(b => b.Name == player.Name);
if(checkedUser == null)
{
using (var registerUser = new Model.DatabaseContext())
{
var user = new Entities.User { Name = player.Name, SocialClubName = player.SocialClubName, Password = NAPI.Util.GetHashSha256(password) };
registerContext.Users.Add(user);
registerContext.SaveChanges();
registerUser.Users.Add(user);
registerUser.SaveChanges();
}
player.TriggerEvent("registerSuccess");
}
else if (player.SocialClubName == checkedUser.SocialClubName)
{
player.TriggerEvent("registerFail", "Dieser SocialClubAccount ist schon registriert!");
}
else if (checkedUser.Name == player.Name)
{
player.TriggerEvent("registerFail", "Benutzername existiert schon!");
}
}
}
}
}