mirror of
https://github.com/EpochModTeam/DayZ-Epoch.git
synced 2025-12-13 19:52:38 +03:00
Achievements are saved in the state field, so we don't have room to save friendlies there anymore. DZE_FriendlySaving is removed for now. I will add it back later with a save to player profile instead. The dayz_players variable is not used for anything. There were several other unused variables in server_playerLogin.sqf.
148 lines
5.0 KiB
Plaintext
148 lines
5.0 KiB
Plaintext
private ["_doLoop","_hiveVer","_isHiveOk","_playerID","_playerObj","_primary","_key","_charID","_playerName","_backpack","_isNew","_inventory","_survival","_model","_config","_mags","_wpns","_bcpk","_newPlayer","_isInfected"];
|
|
|
|
#include "\z\addons\dayz_server\compile\server_toggle_debug.hpp"
|
|
|
|
#ifdef LOGIN_DEBUG
|
|
diag_log ("STARTING LOGIN: " + str(_this));
|
|
#endif
|
|
|
|
_playerID = _this select 0;
|
|
_playerObj = _this select 1;
|
|
_playerName = name _playerObj;
|
|
if (_playerName == '__SERVER__' || _playerID == '' || local player) exitWith {};
|
|
|
|
// Cancel any login until server_monitor terminates.
|
|
// This is mandatory since all vehicles must be spawned before the first players spawn on the map.
|
|
// Otherwise, all vehicle event handlers won't be created on players' client side.
|
|
if (isNil "sm_done") exitWith { diag_log ("Login cancelled, server is not ready. " + str(_playerObj)); };
|
|
|
|
_inventory = [];
|
|
_backpack = [];
|
|
_survival = [0,0,0];
|
|
_model = "";
|
|
_isInfected = 0;
|
|
|
|
if (_playerID == "") then {
|
|
_playerID = [_playerObj] call FNC_GetPlayerUID;
|
|
};
|
|
|
|
if ((_playerID == "") or (isNil "_playerID")) exitWith {
|
|
diag_log ("LOGIN FAILED: Player [" + _playerName + "] has no login ID");
|
|
};
|
|
|
|
#ifdef LOGIN_DEBUG
|
|
diag_log ("LOGIN ATTEMPT: " + str(_playerID) + " " + _playerName);
|
|
#endif
|
|
|
|
_endMission = false;
|
|
_timeleft = 0;
|
|
{
|
|
//if ((_playerID select _i) in activePlayers) exitWith { diag_log ("Login cancelled, player has logged out within the past 2 mins. " + str(_playerObj)); };
|
|
_0 = _x select 0;
|
|
_1 = _x select 1;
|
|
_timeleft = diag_ticktime - _1;
|
|
|
|
if (_playerID == _0) then {
|
|
//If players last logoff is about the ghost timer remove player from ghost que.
|
|
if ((_timeleft > dayz_ghostTimer) or (_timeleft < 0)) then {
|
|
dayz_ghostPlayers = dayz_ghostPlayers - [_0];
|
|
dayz_activePlayers set [_forEachIndex, _0];
|
|
dayz_activePlayers = dayz_activePlayers - [_0];
|
|
} else {
|
|
//if player is in died allow them passage.
|
|
if (_playerID in dayz_died) then {
|
|
dayz_died = dayz_died - [_playerID];
|
|
dayz_ghostPlayers = dayz_ghostPlayers - [_0];
|
|
dayz_activePlayers set [_forEachIndex, _0];
|
|
dayz_activePlayers = dayz_activePlayers - [_0];
|
|
} else {
|
|
// Logoff time is not beyond ghost time and player didn't die
|
|
_endMission = true;
|
|
};
|
|
};
|
|
};
|
|
} forEach dayz_activePlayers;
|
|
|
|
//Do Connection Attempt
|
|
_doLoop = 0;
|
|
while {_doLoop < 5} do {
|
|
_key = format["CHILD:101:%1:%2:%3:",_playerID,dayZ_instance,_playerName];
|
|
_primary = _key call server_hiveReadWrite;
|
|
if (count _primary > 0) then {
|
|
if ((_primary select 0) != "ERROR") then {
|
|
_doLoop = 9;
|
|
};
|
|
};
|
|
_doLoop = _doLoop + 1;
|
|
};
|
|
|
|
if (isNull _playerObj or !isPlayer _playerObj) exitWith {
|
|
diag_log ("LOGIN RESULT: Exiting, player object null: " + str(_playerObj));
|
|
};
|
|
|
|
if ((_primary select 0) == "ERROR") exitWith {
|
|
diag_log format ["LOGIN RESULT: Exiting, failed to load _primary: %1 for player: %2 ",_primary,_playerID];
|
|
};
|
|
|
|
//Process request
|
|
_newPlayer = _primary select 1;
|
|
_isNew = count _primary < 7; //_result select 1;
|
|
_charID = _primary select 2;
|
|
//diag_log ("LOGIN RESULT: " + str(_primary));
|
|
|
|
/* PROCESS */
|
|
_hiveVer = 0;
|
|
|
|
if (!_isNew) then {
|
|
//RETURNING CHARACTER
|
|
_inventory = _primary select 4;
|
|
_backpack = _primary select 5;
|
|
_survival = _primary select 6;
|
|
_model = _primary select 7;
|
|
_hiveVer = _primary select 8;
|
|
if !(_model in AllPlayers) then {_model = "Survivor2_DZ";};
|
|
} else {
|
|
_isInfected = if (DZE_PlayerZed) then {_primary select 3} else {0};
|
|
_model = _primary select 4;
|
|
_hiveVer = _primary select 5;
|
|
if (isNil "_model") then {
|
|
_model = "Survivor2_DZ";
|
|
} else {
|
|
if (_model == "") then {_model = "Survivor2_DZ";};
|
|
};
|
|
|
|
//Record initial inventory only if not player zombie
|
|
if (_isInfected != 1) then {
|
|
_config = configFile >> "CfgSurvival" >> "Inventory" >> "Default";
|
|
_mags = getArray (_config >> "magazines");
|
|
_wpns = getArray (_config >> "weapons");
|
|
_bcpk = getText (_config >> "backpack");
|
|
if (!isNil "DefaultMagazines") then {_mags = DefaultMagazines;};
|
|
if (!isNil "DefaultWeapons") then {_wpns = DefaultWeapons;};
|
|
if (!isNil "DefaultBackpack") then {_bcpk = DefaultBackpack;};
|
|
|
|
//Wait for HIVE to be free
|
|
_key = format["CHILD:203:%1:%2:%3:",_charID,[_wpns,_mags],[_bcpk,[],[]]];
|
|
_key call server_hiveWrite;
|
|
};
|
|
};
|
|
|
|
_isHiveOk = if (_hiveVer >= dayz_hiveVersionNo) then {true} else {false}; //EDITED
|
|
|
|
PVCDZ_plr_Login = [_charID,_inventory,_backpack,_survival,_isNew,dayz_versionNo,_model,_isHiveOk,_newPlayer,_isInfected];
|
|
diag_log str(PVCDZ_plr_Login);
|
|
(owner _playerObj) publicVariableClient "PVCDZ_plr_Login";
|
|
|
|
//Make player wait until ghost timer is up.
|
|
if (_endMission) exitwith {
|
|
_remaining = dayz_ghostTimer - _timeleft;
|
|
diag_log format["LOGIN CANCELLED: player: %1 is in ghost mode. Time remianing: %2 before login!!",_playerObj,_remaining];
|
|
PVCDZ_plr_Ghost = [_remaining];
|
|
(owner _playerObj) publicVariableClient "PVCDZ_plr_Ghost";
|
|
};
|
|
|
|
//Record Player Login/LogOut
|
|
[_playerID,_charID,1] call dayz_recordLogin;
|
|
|
|
PVCDZ_plr_PlayerAccepted = [_playerName,diag_ticktime];
|
|
(owner _playerObj) publicVariableClient "PVCDZ_plr_PlayerAccepted"; |