Epoch/Sources/epoch_server/init/server_securityfunctions.sqf

2226 lines
90 KiB
Plaintext
Raw Normal View History

Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
/*
Authors: Aaron Clark - EpochMod.com
Niklas Wagner - skaronator.com
Contributors:
2015-09-17 16:31:04 +00:00
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
Description:
Arma 3 Epoch ANTIHACK/ADMINTOOL
2015-09-17 16:31:04 +00:00
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
Licence:
Arma Public License Share Alike (APL-SA) - https://www.bistudio.com/community/licenses/arma-public-license-share-alike
Github:
2016-06-13 16:54:19 +00:00
https://github.com/EpochModTeam/Epoch/tree/release/Sources/epoch_server/init/server_securityfunctions.sqf
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
*/
2017-08-25 23:44:26 +00:00
private ["_code","_functionName","_remoteExecClientStr","_onLoad","_onUnload","_skn_blockedSpawnMenuUID","_temp","_skn_adminMenuOwner","_case","_skn_adminMenuHigh","_skn_adminMenuLow","_config","_debugClass","_cfg_systemDebug","_skn_systemDebug1","_skn_systemDebug2","_skn_systemDebug3","_skn_systemDebug4","_skn_systemDebug5","_cfg_remoteExecClient","_remoteExecClient_NAMES","_cfg_limits","_skn_playerCryptoLimit","_cfg_learning","_skn_trustedUsers","_str_learningModeCheck","_cfg_quality","_skn_perfMode","_skn_viewDistance","_skn_viewDistanceObects","_skn_terrainGrid","_cfg_blacklistConfig","_skn_badDisplaysArray","_skn_badAnimations","_cfg_variablesConfig","_skn_badVarCheckArray","_skn_nilVarCheckArray","_skn_commandMenuArray","_skn_addEHConfig","_skn_displayAddEHChecks","_skn_addEHArray","_serverSettingsConfig","_skn_enableAntihack","_skn_check_addons","_checkFiles","_skn_check_files","_skn_whitelist_cfgPatches","_skn_adminsOwner","_skn_adminsHigh","_skn_adminsLow","_banReasons","_skn_banReason","_antihack_banDuration","_epoch_banReasons","_kickReasons","_epoch_kickReason","_epoch_kickReasons","_ownerSettings","_skn_adminMenuOwnerSetting","_adminSettings","_skn_adminMenuHighSetting","_lowSettings","_skn_adminMenuLowSetting","_skn_adminMenuMenuKey","_skn_adminMenuInfrontTeleport","_skn_adminMenuBanReasons","_skn_adminMenuCryproCfg","_skn_cfgPatchesCfg","_skn_PVSPrefix","_rndVAR_Count","_skn_rndVA","_skn_PVC_INDEX","_skn_AH_rndVarVehicle","_skn_AH_rndVarPlayer","_skn_AH_rndVarAHInitCheck","_skn_AH_Init","_skn_AH_Code","_skn_AH_Code_CA","_skn_AH_Code_CB","_skn_AH_Ban","_skn_AH_rndVar","_skn_doKickBan","_skn_pv_hackerLog","_skn_pv_adminLog","_skn_server_adminLog","_skn_doAdminRequest","_skn_doAdminLog","_skn_doTokenAuth","_skn_antiTeleportPVC","_skn_Admin_Code","_skn_Admin_Init","_skn_adminRequest_PVC","_skn_adminLog_PVC","_skn_adminLog","_skn_AdminKeyDown","_skn_AdminMenu_Init","_skn_getCtrl","_skn_fnc_Spec","_skn_Update_AdminButtons","_skn_mainMenuCfg","_skn_FillMainMenu","_skn_FillPlayerMenu","_skn_switchMainMenu","_skn_dbClickMainMenu","_skn_spawnMenu","_skn_spawnSpawnMenu","_skn_removespawnMenu","_skn_fillSpawnMenu","_skn_hackerLog","_skn_switchTable","_skn_customBanreason","_skn_flipVehicle","_skn_freeCam","_skn_delete","_skn_deleteMenu","_skn_deleteNow","_skn_doBan","_skn_mapTeleport","_skn_old_esp","_skn_hideAdmin","_skn_old_espMap","_skn_infrontTP","_skn_esp","_skn_godMode","_skn_repairVehicle","_skn_spawnLoot","_skn_mapLootArray","_skn_tg_Spec","_skn_tg_sortOrder","_skn_tg_toggle","_skn_tg_BanPlayer","_skn_tg_delete","_skn_tg_mapTeleport","_skn_tg_spawnTyp","_skn_tg_limitSpawn","_skn_tg_old_espMap","_skn_tg_old_esp","_skn_tg_hideAdmin","_skn_tg_infrontTP","_skn_tg_godMode","_skn_tg_map_player","_skn_tg_map_corpse","_skn_tg_map_loot","_skn_tg_map_vehicle","_skn_tg_map_ai","_skn_tg_map_basebuilding","_skn_t1","_skn_t2","_skn_t3","_skn_t4","_skn_t5","_skn_AH_rndVarAHInitCheckToken","_stringInArray","_displaysArray","_displays","_cfg_displayArray","_skn_adminUIDArray","_skn_adminNAMEArray","_skn_tempuid","_skn_spawnPointCenter","_centerDistance","_sknBanANDSleep","_sknBanANDSleepQuick","_sknPatches","_skn_addonCheckCode","_skn_fileCheckCode","_sknAddActionCheck","_skn_code_ban","_skn_code_init","_skn_code_antihack","_skn_admincode","_skn_admininit","_configs"];
2015-09-17 16:31:04 +00:00
_config = (configFile >> "CfgSecConf");
if (isClass _config) then {diag_log "Loading config..."};
_debugClass = if ([_config,"debug",false] call EPOCH_fnc_returnConfigEntry) then { "DebugActive" } else { "DebugDisabled" };
_cfg_systemDebug = (_config >> _debugClass);
_skn_systemDebug1 = getText(_cfg_systemDebug >> "systemChat1");
_skn_systemDebug2 = getText(_cfg_systemDebug >> "systemChat2");
_skn_systemDebug3 = getText(_cfg_systemDebug >> "systemChat3");
_skn_systemDebug4 = getText(_cfg_systemDebug >> "systemChat4");
_skn_systemDebug5 = getText(_cfg_systemDebug >> "systemChat5");
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_cfg_remoteExecClient = (_config >> "remoteExecClient");
_remoteExecClient_NAMES = [_cfg_remoteExecClient, "functions", []] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
_cfg_limits = (_config >> "limits");
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_skn_playerCryptoLimit = [_cfg_limits, "playerCrypto", 250000] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
_cfg_learning = (_config >> "learning");
_skn_trustedUsers = [_cfg_learning,"trustedUsers",[]] call EPOCH_fnc_returnConfigEntry;
_str_learningModeCheck = if ([_cfg_learning,"mode",true] call EPOCH_fnc_returnConfigEntry) then{"((getPlayerUID _player) in "+str _skn_trustedUsers+")"} else {"true"};
_cfg_quality = (_config >> "forcedQuality");
_skn_perfMode = getText(_cfg_quality >> "mode");
_skn_viewDistance = [_cfg_quality >> _skn_perfMode, "viewDistance", 2500] call EPOCH_fnc_returnConfigEntry;
_skn_viewDistanceObects = [_cfg_quality >> _skn_perfMode, "viewDistanceObects", 2000] call EPOCH_fnc_returnConfigEntry;
_skn_terrainGrid = [_cfg_quality >> _skn_perfMode, "terrainGrid", 10] call EPOCH_fnc_returnConfigEntry;
_cfg_blacklistConfig = (_config >> "blacklist");
_skn_badDisplaysArray = [_cfg_blacklistConfig, "badDisplays", [-1337,17,19,30,32,45,59,69,71,125,132,155,156,157,162,165,166,167,312,1320,1321,2727,2928,2929,316000]] call EPOCH_fnc_returnConfigEntry;
_skn_badAnimations = [_cfg_blacklistConfig, "animations", ['AmovPercMstpSnonWnonDnon_exerciseKata','AmovPercMstpSnonWnonDnon_exercisePushup','GestureSpasm1','GestureSpasm4','GestureNod']] call EPOCH_fnc_returnConfigEntry;
_cfg_variablesConfig = (_config >> "variables");
_skn_badVarCheckArray = [_cfg_variablesConfig, "badVars", ['ESP_map','ESP_mainMap','ESP_adminMap','AntiAntiAntiAntiHax','fnc_usec_damageHandler','fnc_usec_unconscious','VAGINA_secret','yolo','VERSION','life_fnc_handleDamage','EPOCH_spawnVehicle_PVS','CLASS911_Menu','nuke_vars','JJMMEE_INIT_MENU','PLAYERON','PLAYERNEXT2','ALTISLIFEON','LY_Menu','PLAY','LY_SwaggerLikeUs','BIS_fnc_dbg_reminder_value','BIS_fnc_dbg_reminder']] call EPOCH_fnc_returnConfigEntry;
_skn_nilVarCheckArray = [_cfg_variablesConfig, "nilVars", ['EPOCH_antiWallCount','EPOCH_playerEnergy','EPOCH_playerHunger','EPOCH_playerStamina','EPOCH_playerCrypto','EPOCH_target','EPOCH_ESP_TARGETS','EPOCH_ESPMAP_TARGETS','EPOCH_taxRate','EPOCH_ESP_VEHICLEPLAYER','EPOCH_ESP_PLAYER','EPOCH_ESP_VEHICLES']] call EPOCH_fnc_returnConfigEntry;
_skn_commandMenuArray = [(_config >> "commandMenu"), "menus",['','RscSelectTeam','RscTeam','RscMoveHigh','#GETIN','#RscStatus','#WATCH0','RscCombatMode','RscMenuReply','RscCallSupport','#CUSTOM_RADIO','#User:BIS_fnc_addCommMenuItem_menu','RscRadio','RscReply','#ACTION','RscMenuFormations','#WATCH','RscGroupRootMenu','RscMainMenu','RscMenuMove','RscWatchDir','RscWatchMoveDir','#User:BIS_Menu_GroupCommunication','RscMenuStatus','RscFormations']] call EPOCH_fnc_returnConfigEntry;
_skn_addEHConfig = (_config >> "addEventHandler");
_skn_displayAddEHChecks = [_skn_addEHConfig, "checks",[]] call EPOCH_fnc_returnConfigEntry;
_skn_addEHArray = [];
{
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_code = ["CfgEpochClient", _x, ""] call EPOCH_fnc_returnConfigEntryV2;
2015-09-17 16:31:04 +00:00
_skn_addEHArray pushBack [_x,_code,(_code != "")];
} forEach _skn_displayAddEHChecks;
_serverSettingsConfig = configFile >> "CfgEpochServer";
_skn_enableAntihack = [_serverSettingsConfig, "antihack_Enabled", true] call EPOCH_fnc_returnConfigEntry;
_skn_check_addons = [_serverSettingsConfig, "antihack_cfgPatchesCheck", true] call EPOCH_fnc_returnConfigEntry;
_checkFiles = [
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
["epoch_code\compile\setup\EPOCH_clientInit.sqf", "EPOCH_clientInit"],
["epoch_code\compile\EPOCH_onEachFrame.sqf", "EPOCH_onEachFrame"],
["epoch_code\compile\setup\EPOCH_client_rejectPlayer.sqf", "EPOCH_client_rejectPlayer"],
["epoch_code\compile\setup\EPOCH_clientRespawn.sqf", "EPOCH_clientRespawn"]
2015-09-17 16:31:04 +00:00
];
_skn_check_files = [_serverSettingsConfig, "antihack_checkFilesNew", _checkFiles] call EPOCH_fnc_returnConfigEntry;
_skn_whitelist_cfgPatches = [_serverSettingsConfig, "antihack_whitelistedCfgPatches", []] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
_skn_adminsOwner = [_serverSettingsConfig, "adminMenu_Owner", []] call EPOCH_fnc_returnConfigEntry;
_skn_adminsHigh = [_serverSettingsConfig, "adminMenu_High", []] call EPOCH_fnc_returnConfigEntry;
_skn_adminsLow = [_serverSettingsConfig, "adminMenu_Low", []] call EPOCH_fnc_returnConfigEntry;
_banReasons = [
"Mod mismatch, check that the mods you have enabled match server."
];
2015-09-17 16:31:04 +00:00
_skn_banReason = [_serverSettingsConfig, "antihack_banReason", "EpochMod.com Autoban"] call EPOCH_fnc_returnConfigEntry;
_antihack_banDuration = [_serverSettingsConfig, "antihack_banDuration", 5] call EPOCH_fnc_returnConfigEntry;
_epoch_banReasons = [_serverSettingsConfig, "antihack_banReasons", _banReasons] call EPOCH_fnc_returnConfigEntry;
_kickReasons = [
"Mod mismatch, check that mods enabled match server."
];
_epoch_kickReason = [_serverSettingsConfig, "antihack_kickReason", "EpochMod.com Autokick"] call EPOCH_fnc_returnConfigEntry;
_epoch_kickReasons = [_serverSettingsConfig, "antihack_kickReasons", _kickReasons] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
_ownerSettings = ["ESP-PLAYER","ESP-VEHICLE","ESP-LOOT","OLD-ESP","OLD-MAP","PLAYER-TELEPORT","MAP-TELEPORT","INFRONT-TELEPORT","MAP-PLAYER","MAP-CORPSE","MAP-LOOT","MAP-VEHICLE","MAP-AI","MAP-BASEBUILDING","TARGET-HEAL","TARGET-AMMO","TARGET-KILL","TARGET-CRYPTO","TARGET-VEHICLEREPAIR","VEHICLEFLIP","BANPANNEL","SPAWN-MENU","FREE-CAM","INVISIBLE","SPAWNLOOT","GODMODE","HEAL","VEHICLEREPAIR"];
_skn_adminMenuOwnerSetting = [_serverSettingsConfig, "adminMenu_OwnerSetting", _ownerSettings] call EPOCH_fnc_returnConfigEntry;
_adminSettings = ["PLAYER-TELEPORT","MAP-TELEPORT","TARGET-HEAL","TARGET-AMMO","TARGET-KILL","VEHICLEFLIP","BANPANNEL"];
_skn_adminMenuHighSetting = [_serverSettingsConfig, "adminMenu_HighSetting", _adminSettings] call EPOCH_fnc_returnConfigEntry;
_lowSettings = ["PLAYER-TELEPORT","MAP-TELEPORT","TARGET-HEAL"];
_skn_adminMenuLowSetting = [_serverSettingsConfig, "adminMenu_LowSetting", _lowSettings] call EPOCH_fnc_returnConfigEntry;
_skn_adminMenuMenuKey = [_serverSettingsConfig, "adminMenu_menuKey", 0x3B] call EPOCH_fnc_returnConfigEntry;
_skn_adminMenuInfrontTeleport = [_serverSettingsConfig, "adminMenu_infrontTeleport", 0x06] call EPOCH_fnc_returnConfigEntry;
_skn_adminMenuBanReasons = [_serverSettingsConfig, "adminMenu_BanReasons", ["Traderzone","Hacking","Glitch","Combat Log"]] call EPOCH_fnc_returnConfigEntry;
_skn_adminMenuCryproCfg = [_serverSettingsConfig, "adminMenu_cryptoCfg", [2500,1000,500,100,50,-1000]] call EPOCH_fnc_returnConfigEntry;
_skn_cfgPatchesCfg = [_serverSettingsConfig, "antihack_cfgPatchesMode", [2]] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
_skn_PVSPrefix = [_serverSettingsConfig, "antihack_PVSPrefix", "EPAH_"] call EPOCH_fnc_returnConfigEntry;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
// build array with X number of random strings
_rndVAR_Count = 84; // 85 = number of (_skn_rndVA deleteAt 0)
_skn_rndVA = parseSimpleArray ('epochserver' callExtension format['810|%1', _rndVAR_Count]);
2015-09-17 16:31:04 +00:00
EPOCH_hiveWhitelistVarsArray = [];
// For client PVC
_skn_PVC_INDEX = _skn_rndVA deleteAt 0;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
// [["function", _transferBankBalance],_transferTarget]
EPOCH_sendRemoteExecClient = compileFinal ("
params ['_first','_target'];
_first params ['_functionName','_data'];
[_functionName, _data] remoteExec ['EPOCH_"+_skn_PVC_INDEX+"',_target];
");
// build dynamic RE-C functions
_remoteExecClientStr = "params [""_function"",""_data""];switch (_function) do {";
2015-09-17 16:31:04 +00:00
{
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_functionName = format ["EPOCH_dyn_%1",_x];
missionNamespace setVariable [_functionName, compileFinal ([_cfg_remoteExecClient, _x, ""] call EPOCH_fnc_returnConfigEntry), true];
_remoteExecClientStr = _remoteExecClientStr + format['case "%1": {_data call %2};',_x,_functionName];
} forEach _remoteExecClient_NAMES;
_remoteExecClientStr = _remoteExecClientStr + "};";
2015-09-17 16:31:04 +00:00
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
// broadcast main RE-C function
missionNamespace setVariable [format["EPOCH_%1",_skn_PVC_INDEX], compileFinal _remoteExecClientStr, true];
// diag_log format["DEBUG: _remoteExecClientStr %1",_remoteExecClientStr];
2015-09-17 16:31:04 +00:00
_skn_AH_rndVarVehicle = _skn_rndVA deleteAt 0;
_skn_AH_rndVarPlayer = _skn_rndVA deleteAt 0;
EPOCH_server_getVToken = compileFinal ("_this getVariable ['"+_skn_AH_rndVarVehicle+"',false]");
EPOCH_server_setVToken = compileFinal ("_this setVariable ['"+_skn_AH_rndVarVehicle+"',true];true");
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
EPOCH_server_getPToken = compileFinal ("private['_ret','_var'];_ret = false;if ((_this select 0) isEqualType objNull)then{if (!isNull(_this select 0))then{_var=(_this select 0) getVariable '"+_skn_AH_rndVarPlayer+"';if (!isNil '_var') then {_ret= _var==(_this select 1)}}};if(!_ret)then{['kick',(_this select 0),'Token Check Failed'] call EPOCH_serverCommand};_ret");
2015-09-17 16:31:04 +00:00
EPOCH_server_setPToken = compileFinal ("private '_var';_var = 'epochserver' callExtension '810';_this setVariable ['"+_skn_AH_rndVarPlayer+"',_var];_var");
if (!_skn_enableAntihack) exitWith {
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
EPOCH_server_pushPlayer = compileFinal ("
params ['_playerNetID','_playerUID','_C_SET','_fsmHandle'];
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_C_SET pushBack '';
[_fsmHandle,['_C_SET', _C_SET]] remoteExecCall ['setFSMVariable', _playerNetID];
");
2015-09-17 16:31:04 +00:00
EPOCH_server_isPAdmin = compileFinal ("false");
EPOCH_server_Authed = compileFinal ("true");
EPOCH_server_disconnect = compileFinal("true");
};
2015-10-28 15:16:00 +00:00
// Check AH init code
2015-09-17 16:31:04 +00:00
_skn_AH_rndVarAHInitCheck = _skn_rndVA deleteAt 0;
// Init as array
call compile(_skn_AH_rndVarAHInitCheck+"=[];");
_skn_AH_Init = _skn_rndVA deleteAt 0;
_skn_AH_Code = _skn_rndVA deleteAt 0;
_skn_AH_Code_CA = _skn_rndVA deleteAt 0;
_skn_AH_Code_CB = _skn_rndVA deleteAt 0;
_skn_AH_Ban = _skn_rndVA deleteAt 0;
_skn_AH_rndVar = _skn_rndVA deleteAt 0;
_skn_doKickBan = _skn_PVSPrefix + (_skn_rndVA deleteAt 0);
//ADMIN STUFF:
//PVC from SERVER:
_skn_pv_hackerLog = _skn_rndVA deleteAt 0;
_skn_pv_adminLog = _skn_rndVA deleteAt 0;
//Server Functions:
_skn_server_adminLog = _skn_rndVA deleteAt 0;
//PVS from CLIENT:
_skn_doAdminRequest = _skn_PVSPrefix + (_skn_rndVA deleteAt 0);
_skn_doAdminLog = _skn_PVSPrefix + (_skn_rndVA deleteAt 0);
_skn_doTokenAuth = _skn_PVSPrefix + (_skn_rndVA deleteAt 0);
_skn_antiTeleportPVC = _skn_rndVA deleteAt 0;
//ADMIN MENU CODE & INIT
_skn_Admin_Code = _skn_rndVA deleteAt 0;
_skn_Admin_Init = _skn_rndVA deleteAt 0;
//ADMIN FUNCTIONS
_skn_adminRequest_PVC = _skn_rndVA deleteAt 0;
_skn_adminLog_PVC = _skn_rndVA deleteAt 0;
_skn_adminLog = _skn_rndVA deleteAt 0;
_skn_AdminKeyDown = _skn_rndVA deleteAt 0;
_skn_AdminMenu_Init = _skn_rndVA deleteAt 0;
_skn_getCtrl = _skn_rndVA deleteAt 0;
_skn_fnc_Spec = _skn_rndVA deleteAt 0;
_skn_Update_AdminButtons = _skn_rndVA deleteAt 0;
_skn_mainMenuCfg = _skn_rndVA deleteAt 0;
_skn_FillMainMenu = _skn_rndVA deleteAt 0;
_skn_FillPlayerMenu = _skn_rndVA deleteAt 0;
_skn_switchMainMenu = _skn_rndVA deleteAt 0;
_skn_dbClickMainMenu = _skn_rndVA deleteAt 0;
_skn_spawnMenu = _skn_rndVA deleteAt 0;
_skn_spawnSpawnMenu = _skn_rndVA deleteAt 0;
_skn_removespawnMenu = _skn_rndVA deleteAt 0;
_skn_fillSpawnMenu = _skn_rndVA deleteAt 0;
_skn_hackerLog = _skn_rndVA deleteAt 0;
_skn_switchTable = _skn_rndVA deleteAt 0;
_skn_customBanreason = _skn_rndVA deleteAt 0;
_skn_flipVehicle = _skn_rndVA deleteAt 0;
_skn_freeCam = _skn_rndVA deleteAt 0;
_skn_delete = _skn_rndVA deleteAt 0;
_skn_deleteMenu = _skn_rndVA deleteAt 0;
_skn_deleteNow = _skn_rndVA deleteAt 0;
_skn_doBan = _skn_rndVA deleteAt 0;
_skn_mapTeleport = _skn_rndVA deleteAt 0;
_skn_old_esp = _skn_rndVA deleteAt 0;
_skn_hideAdmin = _skn_rndVA deleteAt 0;
_skn_old_espMap = _skn_rndVA deleteAt 0;
_skn_infrontTP = _skn_rndVA deleteAt 0;
_skn_esp = _skn_rndVA deleteAt 0;
_skn_godMode = _skn_rndVA deleteAt 0;
_skn_repairVehicle = _skn_rndVA deleteAt 0;
_skn_spawnLoot = _skn_rndVA deleteAt 0;
_skn_mapLootArray = _skn_rndVA deleteAt 0;
//ADMIN TOGGLE VARIABLES
_skn_tg_Spec = _skn_rndVA deleteAt 0;
_skn_tg_sortOrder = _skn_rndVA deleteAt 0;
_skn_tg_toggle = _skn_rndVA deleteAt 0;
_skn_tg_BanPlayer = _skn_rndVA deleteAt 0;
_skn_tg_delete = _skn_rndVA deleteAt 0;
_skn_tg_mapTeleport = _skn_rndVA deleteAt 0;
_skn_tg_spawnTyp = _skn_rndVA deleteAt 0;
_skn_tg_limitSpawn = _skn_rndVA deleteAt 0;
_skn_tg_old_espMap = _skn_rndVA deleteAt 0;
_skn_tg_old_esp = _skn_rndVA deleteAt 0;
_skn_tg_hideAdmin = _skn_rndVA deleteAt 0;
_skn_tg_infrontTP = _skn_rndVA deleteAt 0;
_skn_tg_godMode = _skn_rndVA deleteAt 0;
_skn_tg_map_player = _skn_rndVA deleteAt 0;
_skn_tg_map_corpse = _skn_rndVA deleteAt 0;
_skn_tg_map_loot = _skn_rndVA deleteAt 0;
_skn_tg_map_vehicle = _skn_rndVA deleteAt 0;
_skn_tg_map_ai = _skn_rndVA deleteAt 0;
_skn_tg_map_basebuilding = _skn_rndVA deleteAt 0;
_skn_t1 = _skn_rndVA deleteAt 0;
_skn_t2 = _skn_rndVA deleteAt 0;
_skn_t3 = _skn_rndVA deleteAt 0;
_skn_t4 = _skn_rndVA deleteAt 0;
_skn_t5 = _skn_rndVA deleteAt 0;
_skn_AH_rndVarAHInitCheckToken = _skn_t1+_skn_t2+_skn_t3+_skn_t4+_skn_t5;
EPOCH_server_Authed = compileFinal("_this in "+_skn_AH_rndVarAHInitCheck);
EPOCH_server_disconnect = compileFinal("
_ret = false;
_index = " +_skn_AH_rndVarAHInitCheck + " find _this;
if (_index != -1) then {
" +_skn_AH_rndVarAHInitCheck + " deleteAt _index;
_ret = true;
};
2015-10-28 15:16:00 +00:00
_ret
2015-09-17 16:31:04 +00:00
");
EPOCH_server_movePlayer = compileFinal("
2016-12-18 19:21:42 +00:00
params [['_playerObj',objNull,[objNull]],['_pos',[],[[]]]];
if !(isNull _playerObj) then {
"+_skn_antiTeleportPVC+" = true;
(owner _playerObj) publicVariableClient '"+_skn_antiTeleportPVC+"';
[format['Teleport %1 (%2) To Position: %3', name _playerObj, getPlayerUID _playerObj,_pos], 0] call "+_skn_server_adminLog+";
[vehicle _playerObj,_pos] spawn {
uiSleep 0.5;
(_this select 0) setPosATL (_this select 1);
};
};
");
EPOCH_server_teleportCheck = compileFinal("
2016-12-18 19:21:42 +00:00
params [['_playerObj',objNull,[objNull]],'_allow'];
if !(isNull _playerObj) then {
"+_skn_antiTeleportPVC+" = _allow;
(owner _playerObj) publicVariableClient '"+_skn_antiTeleportPVC+"';
};
");
2015-09-17 16:31:04 +00:00
_stringInArray = {
private "_ret";
_ret = false;
{if (_x in _case)exitWith {_ret = true}}forEach _this;
_ret
};
_displaysArray = [];
{_displaysArray pushBack [_x,[],[]]} forEach ["RscDisplayMainMap","RscDisplayGetReady","RscDisplayInventory","RscDisplayLoadMission","RscDisplayInterrupt","RscDisplayOptionsVideo","RscDisplayOptions","RscDisplayAVTerminal","RscDisplayConfigure","RscDisplayConfigureAction","RscDisplayConfigureControllers","RscDisplayControlSchemes","RscDisplayCustomizeController","RscDisplayDebriefing","RscDisplayDiary","RscDisplayGameOptions","RscDisplayJoystickSchemes","RscDisplayLoading","RscDisplayMicSensitivityOptions","RscDisplayOptionsAudio","RscDisplayOptionsLayout","RscDisplayStart","RscDisplayVehicleMsgBox","RscDisplayInsertMarker"];
_displays = [(_config >> "displayOnload"), "checkDisplays", _displaysArray] call EPOCH_fnc_returnConfigEntry;
_cfg_displayArray = [];
{
2016-09-25 21:32:10 +00:00
_onLoad = (getText(configFile >> (_x select 0) >> "onLoad"));
_onUnload = (getText(configFile >> (_x select 0) >> "onUnload"));
2015-09-17 16:31:04 +00:00
_onLoad = [_onLoad];
_onUnload = [_onUnload];
{
2016-09-25 21:32:10 +00:00
_onLoad pushBack _x;
2015-09-17 16:31:04 +00:00
} forEach(_x select 1);
{
2016-09-25 21:32:10 +00:00
_onUnload pushBack _x;
2015-09-17 16:31:04 +00:00
} forEach(_x select 2);
_cfg_displayArray pushBack[(_x select 0), _onLoad, _onUnload];
}forEach _displays;
_skn_adminUIDArray = [];
_skn_adminNAMEArray = [];
_skn_tempuid = [];
{
_skn_adminUIDArray pushBack(_x select 0);
_skn_adminNAMEArray pushBack(_x select 1);
} forEach _skn_adminsOwner;
_skn_adminsOwner = _skn_adminUIDArray;
{
_skn_tempuid pushBack(_x select 0);
_skn_adminUIDArray pushBack(_x select 0);
_skn_adminNAMEArray pushBack(_x select 1);
} forEach _skn_adminsHigh;
_skn_adminsHigh = _skn_tempuid;
_skn_tempuid = [];
{
_skn_adminUIDArray pushBack(_x select 0);
_skn_tempuid pushBack(_x select 0);
_skn_adminNAMEArray pushBack(_x select 1);
} forEach _skn_adminsLow;
_skn_adminsLow = _skn_tempuid;
_skn_tempuid = nil;
{_skn_adminMenuOwnerSetting set[_forEachIndex, toUpper _x]}forEach _skn_adminMenuOwnerSetting;
{_skn_adminMenuHighSetting set [_forEachIndex,toUpper _x]}forEach _skn_adminMenuHighSetting;
{_skn_adminMenuLowSetting set [_forEachIndex,toUpper _x]}forEach _skn_adminMenuLowSetting;
_skn_adminMenuOwner = "[]";
_skn_adminMenuHigh = "[]";
_skn_adminMenuLow = "[]";
_skn_blockedSpawnMenuUID = [];
if !("SPAWN-MENU" in _skn_adminMenuHighSetting) then {_skn_blockedSpawnMenuUID = _skn_adminsHigh};
if !("SPAWN-MENU" in _skn_adminMenuLowSetting) then {{_skn_blockedSpawnMenuUID pushBack _x}forEach _skn_adminsLow};
if !("SPAWN-MENU" in _skn_adminMenuOwnerSetting) then {{_skn_blockedSpawnMenuUID pushBack _x}forEach _skn_adminsOwner};
_case = _skn_adminMenuOwnerSetting; //All Cfg for Owner Menu
for "_i" from 1 to 3 do {
_temp = "[['=============== MAIN MENU ===============',[],'','1',[]]";
if (["PLAYER-TELEPORT","MAP-TELEPORT","INFRONT-TELEPORT"] call _stringInArray) then {
2015-10-28 15:16:00 +00:00
2015-09-17 16:31:04 +00:00
if ("PLAYER-TELEPORT" in _case) then {
_temp = _temp + "
,[' Player To Admin',[],{[101,_this select 1] call "+_skn_adminRequest_PVC+"},'4',[]]
,[' Admin To Player', [], { [102, _this select 1] call "+_skn_adminRequest_PVC+" },'4',[]]
";
};
if ("INFRONT-TELEPORT" in _case) then {
_temp = _temp + "
,[' In Front', [], {"+_skn_tg_infrontTP+" = !"+_skn_tg_infrontTP+"},'2',[]]
";
};
if ("MAP-TELEPORT" in _case) then {
_temp = _temp + "
,[' Ctrl+Click Map', [], {"+_skn_tg_mapTeleport+"=!"+_skn_tg_mapTeleport+";['Map to Teleport', if ("+_skn_tg_mapTeleport+") then[{2}, { 1 }]] call "+_skn_adminLog_PVC+" },'2',[]]
";
};
};
if (["FREE-CAM","INVISIBLE"] call _stringInArray) then {
_temp = _temp + ",['Spectate', [],'','1',[]]";
if ("MAP-TELEPORT" in _case) then {
_temp = _temp + "
,[' Free Look Cam ', [], "+_skn_freeCam+",'0',[]]
";
};
if ("INVISIBLE" in _case) then {
_temp = _temp + "
,[' Invisible Mode', [], "+_skn_hideAdmin+", '2', []]
";
};
};
if (["MAP-PLAYER","MAP-CORPSE","MAP-LOOT","MAP-VEHICLE","MAP-AI","MAP-BASEBUILDING"] call _stringInArray) then {
_temp = _temp + ",['Map Tools', [],'','1',[]]";
if ("MAP-PLAYER" in _case) then {
_temp = _temp + "
,[' Player Marker', [], {"+_skn_tg_map_player+" = !"+_skn_tg_map_player+"; ['Player MARKER',if ("+_skn_tg_map_player+") then [{2},{1}]] call "+_skn_adminLog_PVC+"}, '2', []]
";
};
if ("MAP-CORPSE" in _case) then {
_temp = _temp + "
,[' Corpse Marker', [], {"+_skn_tg_map_corpse+" = !"+_skn_tg_map_corpse+"; ['Corpse MARKER',if ("+_skn_tg_map_corpse+") then [{2},{1}]] call "+_skn_adminLog_PVC+"}, '2', []]
";
};
if ("MAP-LOOT" in _case) then {
_temp = _temp + "
,[' Loot Marker', [], {"+_skn_tg_map_loot+" = !"+_skn_tg_map_loot+"; if ("+_skn_tg_map_loot+") then {waitUntil {"+_skn_mapLootArray+" = nearestObjects[player, ['WH_Loot', 'Animated_Loot'], 10000];uiSleep 10;!"+_skn_tg_map_loot+"};"+_skn_mapLootArray+" = []};['Loot MARKER',if ("+_skn_tg_map_loot+") then [{2},{1}]] call "+_skn_adminLog_PVC+"}, '2', []]
2015-09-17 16:31:04 +00:00
";
};
if ("MAP-VEHICLE" in _case) then {
_temp = _temp + "
,[' Vehicle Marker', [], {"+_skn_tg_map_vehicle+" = !"+_skn_tg_map_vehicle+"; ['Vehicle MARKER',if ("+_skn_tg_map_vehicle+") then [{2},{1}]] call "+_skn_adminLog_PVC+"}, '2', []]
";
};
if ("MAP-AI" in _case) then {
_temp = _temp + "
,[' AI Marker', [], {"+_skn_tg_map_ai+" = !"+_skn_tg_map_ai+"; ['AI MARKER',if ("+_skn_tg_map_ai+") then [{2},{1}]] call "+_skn_adminLog_PVC+"}, '2', []]
";
};
if ("MAP-BASEBUILDING" in _case) then {
_temp = _temp + "
,[' Base Building Marker', [], {"+_skn_tg_map_basebuilding+" = !"+_skn_tg_map_basebuilding+"; ['Base Building MARKER',if ("+_skn_tg_map_basebuilding+") then [{2},{1}]] call "+_skn_adminLog_PVC+"}, '2', []]
2015-09-17 16:31:04 +00:00
";
};
};
if (["ESP-PLAYER","ESP-LOOT","ESP-VEHICLE"] call _stringInArray) then {
_temp = _temp + ",['3D Tools', [],'','1',[]]";
if ("ESP-PLAYER" in _case) then {
_temp = _temp + "
,[' Player ESP', true, "+_skn_esp+", '2', []]
";
};
if ("ESP-VEHICLE" in _case) then {
_temp = _temp + "
,[' Vehicle ESP', false, "+_skn_esp+", '2', []]
";
};
if ("ESP-LOOT" in _case) then {
_temp = _temp + "
,[' Loot ESP (WIP)', [], '', '1', []]
";
};
};
if (["OLD-ESP","OLD-MAP"] call _stringInArray) then {
_temp = _temp + ",['Old Visualisation Tools', [],'','1',[]]";
if ("OLD-ESP" in _case) then {
_temp = _temp + ",[' 3D ESP', [], "+_skn_old_esp+", '2', []]";
2015-10-28 15:16:00 +00:00
};
2015-09-17 16:31:04 +00:00
if ("OLD-MAP" in _case) then {
_temp = _temp + ",[' MAP ESP', [], "+_skn_old_espMap+", '2', []]";
};
};
if (["GODMODE","HEAL","VEHICLEREPAIR"] call _stringInArray) then {
_temp = _temp + ",['Self Menu', [], '', '1', []]";
if ("GODMODE" in _case) then {
_temp = _temp + ",[' Godmode', [], "+_skn_godMode+", '2', []]";
};
if ("HEAL" in _case) then {
_temp = _temp + ",[' Heal',[],{[103,netId player] call "+_skn_adminRequest_PVC+"},'4',[0.016,0.702,0.078,1]]";
};
if ("VEHICLEREPAIR" in _case) then {
_temp = _temp + ",[' Repair Vehicle', [], "+_skn_repairVehicle+", '0', []]";
};
};
if (["TARGET-HEAL","TARGET-AMMO","TARGET-KILL","TARGET-CRYPTO","TARGET-VEHICLEREPAIR"] call _stringInArray) then {
_temp = _temp + ",['Target Actions', [], '', '1', []]";
if ("TARGET-HEAL" in _case) then {
_temp = _temp + ",[' Heal',[],{[103,_this select 1] call "+_skn_adminRequest_PVC+"},'4',[0.016,0.702,0.078,1]]";
};
if ("TARGET-KILL" in _case) then {
_temp = _temp + ",[' Kill',[],{[100,_this select 1] call "+_skn_adminRequest_PVC+"},'4',[0.859,0.094,0.094,1]]";
};
if ("TARGET-AMMO" in _case) then {
_temp = _temp + ",[' Give Ammo',[],{[200,_this select 1] call "+_skn_adminRequest_PVC+"},'4',[]]";
};
if ("TARGET-VEHICLEREPAIR" in _case) then {
_temp = _temp + ",[' Repair Vehicle', [], "+_skn_flipVehicle+", '0', []]";
};
if ("TARGET-CRYPTO" in _case) then {
{
_temp = _temp + ",[' Give Crypto - "+str _x+"',"+str _x+",{[107,[_this select 1,_this select 2]] call "+_skn_adminRequest_PVC+"},'4',[]]"
}count _skn_adminMenuCryproCfg;
};
};
_temp = _temp + ",['Custom Stuff', [], '', '1', []]";
if ("VEHICLEFLIP" in _case) then {
_temp = _temp + ",[' Unflip Vehicle', [], "+_skn_flipVehicle+", '0', []]";
};
if ("SPAWNLOOT" in _case) then {
_temp = _temp + ",[' Loot Buildings (25m)', 25, "+_skn_spawnLoot+", '0', []]";
};
_temp = _temp + ",[' Disconnect yourself', [], { (findDisplay 46) closeDisplay 0 }, '0', []]";
if ("BANPANNEL" in _case) then {
_temp = _temp + ",['Ban Menu',[],'','1',[]]
,[' BattlEye Ban - Custom Ban Reason',[],"+_skn_customBanreason+",'4',[]]
";
{
_temp = _temp + ",[' BattlEye Ban - "+_x+"','"+_x+"',"+_skn_customBanreason+",'4',[]]"
}count _skn_adminMenuBanReasons;
};
_temp = _temp + "
,['Key Binds',[],'','1',[]]
,[' 3 Key - Teleport In Front',[],'','1',[]]
,[' F2 - Cancel Spectating',[],'','1',[]]
,[' F5 - Delete Target',[],'','1',[]]
];
";
if (_i == 1) then {
_skn_adminMenuOwner = _temp;
_case = _skn_adminMenuHighSetting;
};
if (_i == 2) then {
_skn_adminMenuHigh = _temp;
_case = _skn_adminMenuLowSetting;
};
if (_i == 3) then {
_skn_adminMenuLow = _temp;
};
};
_skn_spawnPointCenter = getMarkerPos "respawn_west";
_centerDistance = [_serverSettingsConfig, "antihack_TPcenterDistance", 30] call EPOCH_fnc_returnConfigEntry;
_maxTravelDistance = [_serverSettingsConfig, "antihack_maxTravelDistance", 30] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
// Only set these if prefix is not used since we can filter for it
if (_skn_PVSPrefix == "") then {
"epochserver" callExtension format["800|%1|%2|%3|%4", _skn_doKickBan, _skn_doAdminRequest, _skn_doAdminLog, _skn_doTokenAuth];
};
EPOCH_server_pushPlayer = compileFinal ("
params ['_playerNetID','_playerUID','_C_SET','_fsmHandle'];
if (_playerUID in "+ str _skn_adminUIDArray+") then {
_playerNetID publicVariableClient '"+_skn_Admin_Code+"';
_playerNetID publicVariableClient '"+_skn_pv_adminLog+"';
_playerNetID publicVariableClient '"+_skn_pv_hackerLog+"';
_C_SET pushBack '[] spawn "+_skn_Admin_Init+"';
2015-09-17 16:31:04 +00:00
} else {
_C_SET pushBack '[] spawn "+_skn_AH_Init+"';
2015-09-17 16:31:04 +00:00
};
[_fsmHandle,['_C_SET', _C_SET]] remoteExecCall ['setFSMVariable', _playerNetID];
2015-09-17 16:31:04 +00:00
true
");
EPOCH_server_isPAdmin = compileFinal ("if (isNull _this) then {false} else {getPlayerUID _this in "+str _skn_adminUIDArray+"}");
_sknBanANDSleep = _skn_AH_Ban+"; uiSleep 60";
_sknBanANDSleepQuick = _skn_AH_Ban+"; uiSleep 1";
// CfgPatches Check
_sknPatches = [];
"_sknPatches pushBack (configName _x); true" configClasses (configFile >> "CfgPatches");
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
{_sknPatches pushBackUnique _x}forEach _skn_whitelist_cfgPatches;
_skn_addonCheckCode = if (_skn_check_addons) then {"[] spawn{_config = '!(configName _x in "+str _sknPatches+")' configClasses (configFile >> 'CfgPatches');if !(_config isEqualTo []) then {[format['Disallowed Addon %1',_config],["+str (_skn_cfgPatchesCfg select 0)+",0]] call "+_skn_AH_Ban+"}};"} else {""};
2015-09-17 16:31:04 +00:00
_skn_fileCheckCode = if (_skn_check_files isEqualTo []) then {""} else {"{if (str(compile preprocessFileLineNumbers (_x select 0)) != str(missionNamespace getVariable [_x select 1,'']))exitWith{[format['Modified File %1 (%2/%3)',_x select 1,count toArray str (compile preprocessFileLineNumbers (_x select 0)),count toArray str(missionNamespace getVariable [_x select 1,''])],0] call "+_skn_AH_Ban+"}} forEach "+str _skn_check_files+";"};
// Addaction Checks
2015-09-17 16:31:04 +00:00
_sknAddActionCheck = if ([_serverSettingsConfig, "antihack_addActionCheck", true] call EPOCH_fnc_returnConfigEntry) then{ "
if (player == _ActionVehicle) then[{_ActionCount = _ActionCount + 1}, { _ActionVehicle = player; _ActionCount = 0 }];
_addCase = player addAction['', '', [], -5, false, true, '', 'false'];
player removeAction _addCase;
if (_addCase != _ActionCount) then{
[format['addAction %1/%2', _addCase, _ActionCount], 0] call "+_sknBanANDSleep+";
};
"} else {""};
// Anti teleport checks
_antiTeleportCheck = if ([_serverSettingsConfig, "antihack_antiTeleportCheck", true] call EPOCH_fnc_returnConfigEntry) then{"
_cntBan = 0;
while {true} do {
_lastTime = diag_tickTime;
_lastPos = getPosATL vehicle player;
_notNearbySpawn = _lastPos distance "+str _skn_spawnPointCenter+" > "+str _centerDistance+";
while {alive player} do {
_curTime = diag_tickTime;
_curPos = getPosATL vehicle player;
_distance = _lastPos distance _curPos;
if ((_curTime-_lastTime) > 1 || _distance > "+str _maxTravelDistance+") then {
if (((_distance/(_curTime-_lastTime)) > "+str _maxTravelDistance+") && _notNearbySpawn && (player == vehicle player)) then {
if (isNil '"+_skn_antiTeleportPVC+"') then {
[format['[TEST] TP from %1 to %2, %3 meters, now at %4', _lastPos, _curPos, round _distance, getPosATL player],1] call "+_sknBanANDSleep+";
vehicle player setPosATL _lastPos;
_cntBan = _cntBan + 1;
if (_cntBan > 4) then {
2015-09-17 16:31:04 +00:00
};
} else {
uiSleep 10;
_lastPos = getPosATL vehicle player;
_lastTime = diag_tickTime;
_notNearbySpawn = false;
};
} else {
_lastPos = _curPos;
_lastTime = _curTime;
_notNearbySpawn = _lastPos distance "+str _skn_spawnPointCenter+" > "+str _centerDistance+";
};
};
};
uiSleep 0.1;
};
uiSleep 0.25;
"} else {""};
2015-09-17 16:31:04 +00:00
// Init Server Side Event Handlers
2015-09-17 16:31:04 +00:00
//[_data,_player,_token];
call compile("'"+_skn_doTokenAuth+"' addPublicVariableEventHandler {
_array = _this select 1;
_tokenSet = false;
if !([_array select 1, _array select 2] call EPOCH_server_getPToken) exitWith{};
2016-06-06 21:12:15 +00:00
if (_array select 0 isEqualTo '"+_skn_AH_rndVarAHInitCheckToken+"') then {
_tokenSet = true;
_puid = (_array select 1) getVariable['PUID', ''];
if (_puid != '') then {
if !(_puid in "+_skn_AH_rndVarAHInitCheck+") then {
"+_skn_AH_rndVarAHInitCheck+" pushBack _puid;
diag_log format['DEBUG: player auth token set %1', _array];
2015-09-17 16:31:04 +00:00
};
};
};
if !(_tokenSet) then {
_playerUID = getPlayerUID (_array select 1);
if (_playerUID != '') then{
'epochserver' callExtension format['911|%1|%2', _playerUID, 'Auth failure, Please reconnect'];
};
};
};");
call compile ("'"+_skn_doKickBan+"' addPublicVariableEventHandler {
_array = _this select 1;
_array params ['_text','_mode','_player','_token'];
if !([_player,_token] call EPOCH_server_getPToken) exitWith {
2015-09-17 16:31:04 +00:00
['ahe', format['Token is different [%1,%2] %3',if (!isNull _player) then { _player getVariable ['"+_skn_AH_rndVarPlayer+"','']}else{'PlayerObj NULL'}, _array select 3, _array]] call EPOCH_fnc_server_hiveLog;
};
_text = toString(_text);
_reasonIndex = -1;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
if (_mode isEqualType []) then{
_mode = _mode select 0;
_reasonIndex = _mode select 1;
2015-09-17 16:31:04 +00:00
};
_reason = '';
_logName = 'ahl';
_logMode = 1;
_logColor = [1,1,1,1];
switch _mode do {
case 0: {
_logName = 'ahb';
_logColor = [1,0,0,1];
_logMode = 0;
if (_reasonIndex != -1) then {
_reason = "+str(_epoch_banReasons)+" select _reasonIndex;
2015-09-17 16:31:04 +00:00
};
['ban', _player , format['"+_skn_banReason+" %1',_reason], "+str(_antihack_banDuration)+"] call EPOCH_serverCommand;
};
case 2: {
_logName = 'ahk';
_logColor = [0,0,1,1];
if (_reasonIndex != -1) then {
_reason = "+str(_epoch_kickReasons)+" select _reasonIndex;
};
['kick', _player , format['"+_epoch_kickReason+" %1',_reason]] call EPOCH_serverCommand;
2015-09-17 16:31:04 +00:00
};
};
"+_skn_pv_hackerLog+" pushBack[[_logMode, call EPOCH_server_getRealTime, name _player, getPlayerUID _player, _text], _logColor];
[_logName, format['%1 (%2): %3', name _player, getPlayerUID _player, _text]] call EPOCH_fnc_server_hiveLog;
diag_log str([_logName, format['%1 (%2): %3', name _player, getPlayerUID _player, _text]]);
2015-09-17 16:31:04 +00:00
{
if (_x call EPOCH_server_isPAdmin) then {
(owner _x) publicVariableClient '"+_skn_pv_hackerLog+"';
};
}forEach allPlayers;
2015-09-17 16:31:04 +00:00
};");
//0 = BAN
//1 = LOG
//2 = KICK
2015-09-17 16:31:04 +00:00
_skn_code_ban = compileFinal ("
_this set [0,toArray (_this select 0)];
_this pushBack player;
_this pushBack Epoch_personalToken;
"+_skn_doKickBan+" = _this;
publicVariableServer '"+_skn_doKickBan+"';
true
");
_skn_code_init = compileFinal ("
comment 'Epoch Mod Antihack - Niklas Wagner - www.skaronator.com - Aaron Clark - www.epochmod.com - License: (CC) Attribution-NonCommercial-NoDerivatives 4.0 International';
waitUntil {(getPlayerUID player) != ''};
_start = diag_tickTime;
waitUntil {!isNil '"+_skn_AH_Code+"' || (diag_tickTime-_start > 20)};
if (isNil '"+_skn_AH_Code+"') exitWith {
"+_skn_doKickBan+" = [format['Cannot Load AH [%1,%2]',!isNil '"+_skn_AH_Code_CA+"',!isNil '"+_skn_AH_Code_CB+"'],2,player,Epoch_personalToken];
2015-09-17 16:31:04 +00:00
publicVariableServer '"+_skn_doKickBan+"';
(findDisplay 46) closeDisplay 0
};
[] spawn "+_skn_AH_Code+";
uiSleep 3;
if ((isNil '"+_skn_AH_Code_CA+"') || (isNil '"+_skn_AH_Code_CB+"')) then {
uiSleep 5;
if ((isNil '"+_skn_AH_Code_CA+"') || (isNil '"+_skn_AH_Code_CB+"')) then {
[] spawn "+_skn_AH_Code+";
uiSleep 3;
};
};
uiSleep 5;
if ((isNil '"+_skn_AH_Code_CA+"') || (isNil '"+_skn_AH_Code_CB+"')) then {
"+_skn_doKickBan+" = [format['Cannot Load AH [%1,%2]',!isNil '"+_skn_AH_Code_CA+"',!isNil '"+_skn_AH_Code_CB+"'],2,player,Epoch_personalToken];
2015-09-17 16:31:04 +00:00
publicVariableServer '"+_skn_doKickBan+"';
(findDisplay 46) closeDisplay 0
};
");
_skn_code_antihack = compileFinal ("
comment 'Epoch Mod Antihack - Niklas Wagner - www.skaronator.com - Aaron Clark - www.epochmod.com - License: (CC) Attribution-NonCommercial-NoDerivatives 4.0 International';
if ((!isNil '"+_skn_AH_Code_CA+"') && (!isNil '"+_skn_AH_Code_CB+"')) exitWith {};
"+_skn_AH_Code_CA+" = true;
"+_skn_addonCheckCode+"
_t = '"+_skn_t1+"';
[] spawn {
uiSleep 5;
FW"+_skn_AH_rndVar+" = '';
FA"+_skn_AH_rndVar+" = 0;
FWC"+_skn_AH_rndVar+" = 0;
_sknOnFire = {
_wep = _this select 1;
_ammo = player ammo _wep;
if !(_wep in ['Throw','Put']) then {
if (FW"+_skn_AH_rndVar+" == _wep && FA"+_skn_AH_rndVar+" == _ammo) then {
if (FWC"+_skn_AH_rndVar+" > 1) then {
[format['[TEST] Unlimited Ammo: [%1,%2]', _wep, _ammo], 1] call "+_skn_AH_Ban+";
[] spawn {uiSleep 60;FWC"+_skn_AH_rndVar+" = 0};
};
FWC"+_skn_AH_rndVar+" = FWC"+_skn_AH_rndVar+" +1;
[] spawn {uiSleep 20;FWC"+_skn_AH_rndVar+" = 0};
};
};
FA"+_skn_AH_rndVar+" = _ammo;
FW"+_skn_AH_rndVar+" = _wep;
true
};
uiNamespace setVariable['RscDisplayRemoteMissions',displayNull];
uiNamespace setVariable['RscDisplayArsenal',displayNull];
missionnamespace setVariable['BIS_fnc_showNotification_queue',nil];
while {true} do {
{
if (!isNull (_x select 0)) then {
[format['Menu: %1',_x select 1],0] call "+_sknBanANDSleep+";
};
}forEach[
[(findDisplay 64) displayCtrl 1002,'findDisplay 64'],
[(findDisplay 49) displayCtrl 0,'findDisplay 49'],
[uiNamespace getVariable 'RscDisplayRemoteMissions','RscDisplayRemoteMissions'],
[uiNamespace getVariable 'RscDisplayArsenal','RscDisplayArsenal'],
[missionnamespace getvariable 'BIS_fnc_showNotification_queue','showNotification']
];
{
if (!isNull (findDisplay _x)) then {
[format['Menu: findDisplay %1',_x],0] call "+_sknBanANDSleep+";
};
}forEach "+str _skn_badDisplaysArray+";
if (!isNull (uiNamespace getVariable 'RscDisplayConfigureAction')) then {
_ctrlTxt = toLower ctrlText 1000;
if (_ctrlTxt != '') then {
if (_ctrlTxt != toLower localize 'STR_A3_RscDisplayConfigureAction_Title') then {
[format['Menu: RscDisplayConfigureAction-A %1',_ctrlTxt],0] call "+_sknBanANDSleep+";
};
};
{
if (buttonAction _x != '') then {
[format['Menu: RscDisplayConfigureAction-B (%1)',_x],0] call "+_sknBanANDSleep+";
};
}forEach [1,104,105,106,107,108,109];
};
if (!isNull (uiNamespace getVariable 'RscDisplayInsertMarker')) then {
_ctrlTxt = toLower ctrlText 1001;
if (_ctrlTxt != '') then {
if (_ctrlTxt != toLower localize 'STR_A3_RscDisplayInsertMarker_Title') then {
[format['Menu: RscDisplayInsertMarker-A %1',_ctrlTxt],0] call "+_sknBanANDSleep+";
};
};
if ((buttonAction 1 != '') || (buttonAction 2 != '')) then {
[format['Menu: RscDisplayInsertMarker-B [%1,%2]',buttonAction 1,buttonAction 2],0] call "+_sknBanANDSleep+";
};
};
if (!isNull (findDisplay 129)) then {closeDialog 0};
if !(commandingMenu in "+str _skn_commandMenuArray+") then {
[format['Menu: commandMenu: %1',commandingMenu],0] call "+_sknBanANDSleep+";
};
2015-10-28 15:16:00 +00:00
2015-09-17 16:31:04 +00:00
onMapSingleClick '';
player allowDamage true;
vehicle player allowDamage true;
{
_ehKey = _x select 0;
if (_x select 2) then {
player removeEventHandler [_ehKey, 0];
};
_ehCode = _x select 1;
if (_ehKey == 'Fired') then {_ehCode = (_ehCode + '_this call '+str(_sknOnFire)) };
_addCase = player addEventHandler [_ehKey, _ehCode];
if !(_x select 2) then {
player removeEventHandler [_ehKey, 0];
};
if (_addCase > 0) then {
[format['EH: %1 %2',_ehKey,_addCase],0] call "+_sknBanANDSleep+";
};
} forEach "+str _skn_addEHArray+";
2015-10-28 15:16:00 +00:00
2015-09-17 16:31:04 +00:00
uiSleep 0.01;
};
};
_t = _t + '"+_skn_t2+"';
[] spawn {
disableSerialization;
_ActionCount = -1;
_ActionVehicle = player;
_displayCount = 0;
_personalToken = Epoch_personalToken;
_antiWallCount = 0;
waitUntil{!isNull (findDisplay 46)};
2015-10-28 15:16:00 +00:00
setViewDistance "+str _skn_viewDistance+";
2015-09-17 16:31:04 +00:00
setObjectViewDistance["+str _skn_viewDistanceObects+", 100];
setTerrainGrid "+str _skn_terrainGrid+";
uiSleep 5;
while {true} do {
if (isNil 'Epoch_personalToken') then {
"+_skn_doKickBan+" = [format['personalToken NIL: %1/%2',Epoch_personalToken,_personalToken],0,player,_personalToken];
publicVariableServer '"+_skn_doKickBan+"';
uiSleep 60;
};
{
if (isNil _x) then {
[format['%1: nil',_x],0] call "+_sknBanANDSleep+";
};
}forEach "+str _skn_nilVarCheckArray+";
if !(groupIconsVisible isEqualTo [false,false]) then {
[format['GroupIcons %1',groupIconsVisible],0] call "+_sknBanANDSleep+";
};
if (unitRecoilCoefficient player != 1) then {
[format['Recoil %1',unitRecoilCoefficient player],0] call "+_sknBanANDSleep+";
};
if (animationState player in "+str _skn_badAnimations+") then {
[format['BadMove: %1',animationState player],0] call "+_sknBanANDSleep+";
};
if (EPOCH_playerEnergy > 2500 || EPOCH_playerEnergy < 0) then {
[format['Energy: %1',EPOCH_playerEnergy],0] call "+_sknBanANDSleep+";
};
if (EPOCH_playerHunger > 5000 || EPOCH_playerHunger < 0) then {
[format['Hunger: %1',EPOCH_playerHunger],0] call "+_sknBanANDSleep+";
};
if (EPOCH_playerThirst > 2500 || EPOCH_playerThirst < 0) then {
[format['Thirsk: %1',EPOCH_playerThirst],0] call "+_sknBanANDSleep+";
};
if (EPOCH_playerStamina > 2500 || EPOCH_playerStamina < 0) then {
[format['Stamina: %1',EPOCH_playerStamina],0] call "+_sknBanANDSleep+";
};
if (EPOCH_playerCrypto > "+str _skn_playerCryptoLimit+" || EPOCH_playerCrypto < 0) then {
[format['Crypto: %1',EPOCH_playerCrypto],0] call "+_sknBanANDSleep+";
};
if (_antiWallCount != EPOCH_antiWallCount) then {
if (_antiWallCount > EPOCH_antiWallCount) then {
[format['antiWall: %1/%2',EPOCH_antiWallCount,_antiWallCount],0] call "+_sknBanANDSleep+";
};
_antiWallCount = EPOCH_antiWallCount;
};
if (EPOCH_target isEqualTo player) then {
[format['setVelocityTarget: %1', EPOCH_target], 0] call "+_sknBanANDSleep+";
};
if !(EPOCH_ESP_TARGETS isEqualTo []) then {
[format['ESP-O: %1', EPOCH_ESP_TARGETS], 0] call "+_sknBanANDSleep+";
};
if !(EPOCH_ESPMAP_TARGETS isEqualTo []) then {
[format['MAP-ESP: %1', EPOCH_ESPMAP_TARGETS], 0] call "+_sknBanANDSleep+";
};
if !(EPOCH_ESP_VEHICLEPLAYER isEqualTo []) then {
[format['ESP-N: %1', EPOCH_ESP_VEHICLEPLAYER], 0] call "+_sknBanANDSleep+";
};
if (EPOCH_ESP_PLAYER || EPOCH_ESP_VEHICLES) then {
[format['ESP-N: %1', EPOCH_ESP_VEHICLES], 0] call "+_sknBanANDSleep+";
};
if (EPOCH_taxRate != "+str EPOCH_taxRate+") then {
[format['taxTate: %1',EPOCH_taxRate],0] call "+_sknBanANDSleep+";
};
if !(EPOCH_group_upgrade_lvl isEqualTo "+str EPOCH_group_upgrade_lvl+") then {
[format['groupUpgradeLvL: %1',EPOCH_group_upgrade_lvl],0] call "+_sknBanANDSleep+";
};
if (viewDistance != "+str _skn_viewDistance+") then{
[format['viewDistance %1',viewDistance],0] call "+_sknBanANDSleep+";
};
"+_sknAddActionCheck+"
2016-04-22 23:54:04 +00:00
_display = findDisplay 46;
if !(isNull _display) then {
{
_display displayRemoveAllEventHandlers _x;
_addCase = _display displayAddEventHandler [_x,([""CfgEpochClient"", _x, """"] call EPOCH_fnc_returnConfigEntryV2)];
if (_addCase != _displayCount) then {
[format['DEH: %3 %1/%2',_addCase,_displayCount,_x],0] call "+_sknBanANDSleep+";
};
} forEach (['CfgEpochClient', 'displayAddEventHandler', []] call EPOCH_fnc_returnConfigEntryV2);
2015-09-17 16:31:04 +00:00
};
uiSleep ((random 1)+1);
};
};
_t = _t + '"+_skn_t3+"';
[] spawn {"+_antiTeleportCheck+"};
2015-09-17 16:31:04 +00:00
_t = _t + '"+_skn_t4+"';
[] spawn {
uiNamespace setVariable['ESP_mainMap', nil];
uiNamespace setVariable['ESP_adminMap', nil];
while {true} do {
{
_badVar = _x;
{
_var = _x getVariable _badVar;
if (!isNil '_var') then {
[format['BadVar %1=%2 (%3)',_badVar,_var,_forEachIndex],0] call "+_sknBanANDSleep+";
_x setVariable [_badVar,nil];
};
}forEach [missionNamespace, parsingNamespace, uiNamespace];
}forEach "+str _skn_badVarCheckArray+";
"+_skn_fileCheckCode+"
{
_display = _x select 0;
_displayCheckOkay = false;
{
if ((getText(configFile>>_display>>'onLoad'))==_x) exitWith { _displayCheckOkay = true };
}forEach (_x select 1);
if (!_displayCheckOkay) then {
[format['Changed %1 >> onLoad >> %2', _display, getText(configFile>>_display>>'onLoad')],0] call "+_sknBanANDSleep+";
_displayCheckOkay = false;
};
{
if ((getText(configFile>>_display>>'onUnload'))==_x) exitWith { _displayCheckOkay = true };
}forEach (_x select 2);
if (!_displayCheckOkay) then {
[format['Changed %1 >> onUnload >> %2', _display, getText(configFile>>_display>>'onUnload')],0] call "+_sknBanANDSleep+";
}
}forEach "+str _cfg_displayArray+";
uiSleep ((random 10)+10);
};
};
_t = _t + '"+_skn_t5+"';
"+_skn_doTokenAuth+" = [_t,player,Epoch_personalToken];
publicVariableServer '"+_skn_doTokenAuth+"';
"+_skn_doTokenAuth+" = nil;
"+_skn_AH_Code_CB+" = true;
true
");
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
missionNamespace setVariable [_skn_AH_Ban, _skn_code_ban, true];
missionNamespace setVariable [_skn_AH_Code, _skn_code_antihack, true];
missionNamespace setVariable [_skn_AH_Init, _skn_code_init, true];
2015-09-17 16:31:04 +00:00
/*********************************************** ADMIN MENU *****************************************************/
/*********************************************** ADMIN MENU *****************************************************/
/*********************************************** ADMIN MENU *****************************************************/
/*********************************************** ADMIN MENU *****************************************************/
/*********************************************** ADMIN MENU *****************************************************/
call compile ("
"+_skn_pv_adminLog+" = [];
"+_skn_pv_hackerLog+" = [];
"+_skn_server_adminLog+" = {
_toggle = ' -----';
if ((_this select 1) != 0) then {
_toggle = if ((_this select 1) == 2) then {' -ON-'} else {'-OFF-'};
};
_adminUID = getPlayerUID _admin;
_adminNAME = "+str _skn_adminNAMEArray+" select ("+str _skn_adminUIDArray+" find _adminUID);
['aml', format['%1 (%2): [%4] %3',_adminNAME,_adminUID,_this select 0,_toggle]] call EPOCH_fnc_server_hiveLog;
"+_skn_pv_adminLog+" pushBack [call EPOCH_server_getRealTime,_adminNAME,_toggle,_this select 0];
2015-09-17 16:31:04 +00:00
diag_log format ['SKN2 AdminRequest %1',"+_skn_pv_adminLog+"];
{
if (_x call EPOCH_server_isPAdmin) then {
(owner _x) publicVariableClient '"+_skn_pv_adminLog+"';
};
}forEach allPlayers;
2015-09-17 16:31:04 +00:00
true
};
");
//[text,toggle,admin,token]
//toggle: 0:NOTHING 1:OFF 2:ON
call compile ("'"+_skn_doAdminLog+"' addPublicVariableEventHandler {
_array = _this select 1;
diag_log format ['SKN AdminLog %1',_array];
_admin = _array select 2;
if !([_admin,_array select 3] call EPOCH_server_getPToken) exitWith {};
if !(_admin call EPOCH_server_isPAdmin) exitWith {};
[_array select 0,_array select 1] call "+_skn_server_adminLog+"};
");
//[case,[contentarray],player,token]
call compile ("'"+_skn_doAdminRequest+"' addPublicVariableEventHandler {
_array = _this select 1;
diag_log format ['SKN AdminRequest %1',_array];
_admin = _array select 2;
if !([_admin,_array select 3] call EPOCH_server_getPToken) exitWith {};
if !(_admin call EPOCH_server_isPAdmin) exitWith {};
_case = _array select 0;
_content = _array select 1;
if (_case == 100) then {
_playerObj = objectFromNetId _content;
[format['Kill Target: %1 (%2)',name _playerObj,getPlayerUID _playerObj],0] call "+_skn_server_adminLog+";
_playerObj setDamage 1;
};
if (_case == 101) then {
_playerObj = objectFromNetId _content;
"+_skn_antiTeleportPVC+" = true;
(owner _playerObj) publicVariableClient '"+_skn_antiTeleportPVC+"';
[format['Teleport To Admin: %1 (%2)', name _playerObj, getPlayerUID _playerObj], 0] call "+_skn_server_adminLog+";
[vehicle _playerObj,_admin] spawn {
uiSleep 0.5;
(_this select 0) setPos ((_this select 1) modelToWorld [0,1,0]);
(_this select 0) setDir (getDir (_this select 1));
};
};
if (_case == 102) then {
_playerObj = objectFromNetId _content;
_behindM = if (vehicle _playerObj == _playerObj) then [{-1},{-5}];
vehicle _admin setPos (_playerObj modelToWorld [0,_behindM,0]);
vehicle _admin setDir (getDir _playerObj);
[format['Teleport Admin To: %1 (%2)', name _playerObj, getPlayerUID _playerObj], 0] call "+_skn_server_adminLog+";
};
if (_case == 103) then {
_playerObj = objectFromNetId _content;
_playerObj setDamage 0;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
[['healPlayer',true], _playerObj] call EPOCH_sendRemoteExecClient;
2015-09-17 16:31:04 +00:00
if (_playerObj == _admin) then {
['Healed Self',0] call "+_skn_server_adminLog+";
} else {
[format['Heal Target: %1 (%2)',name _playerObj,getPlayerUID _playerObj],0] call "+_skn_server_adminLog+";
}
};
if (_case == 104) then {
if ((_content isKindOf 'LandVehicle') || (_content isKindOf 'Air') || (_content isKindOf 'Ship') || (_content isKindOf 'Tank')) then {
[_content, _admin] call EPOCH_server_save_killedVehicle;
} else {
2015-10-28 15:16:00 +00:00
if (_content isKindOf 'Constructions_lockedstatic_F' || (_content isKindOf 'Buildable_Storage')) then{
2015-09-17 16:31:04 +00:00
[_content, _admin] call EPOCH_server_save_killedStorage;
} else {
[_content, _admin] call EPOCH_server_save_killedBuilding;
};
};
[format['Delete: %1 at [%2]',typeOf _content, getPos _content],0] call "+_skn_server_adminLog+";
_content spawn {
if !(isNull _this) then {
_this hideObjectGlobal true;
sleep 1;
if !(isNull _this) then {deleteVehicle _this};
};
};
2015-09-17 16:31:04 +00:00
};
if (_case == 106) then {
_admin hideObjectGlobal _content;
};
if (_case == 107) then {
_player = objectFromNetId (_content select 0);
if (!isNull _player) then {
_cIndex = EPOCH_customVars find 'Crypto';
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_vars = _player getVariable['VARS', call EPOCH_defaultVars_SEPXVar];
2015-09-17 16:31:04 +00:00
_current_crypto = (((_vars select _cIndex) + (_content select 1)) min "+str _skn_playerCryptoLimit+") max 0;
_current_crypto remoteExec ['EPOCH_effectCrypto',_player];
2015-09-17 16:31:04 +00:00
_vars set[_cIndex, _current_crypto];
_player setVariable['VARS', _vars];
if (_player == _admin) then {
[format['Give Crypto Myself: %1',_content select 1],0] call "+_skn_server_adminLog+";
} else {
[format['Give Crypto to %1 (%2): %3',name _player,getPlayerUID _player,_content select 1],0] call "+_skn_server_adminLog+";
}
};
};
if (_case == 108) then {
if (!isNull _content) then {
[format['Repaire Vehicle: %1',typeOf _content],0] call "+_skn_server_adminLog+";
_content setDamage 0;
diag_log format ['Debug-Vehicle: Repair: 108,%1',_content];
if (local _content) then {
_content setFuel 1;
} else {
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
[_content, 1] remoteExec ['EPOCH_client_fillVehicle',_admin];
2015-09-17 16:31:04 +00:00
};
_content call EPOCH_server_save_vehicle;
};
};
if (_case == 109) then {
if (surfaceIsWater _content) then [{vehicle _admin setPosASL _content},{vehicle _admin setPosATL _content}];
};
if (_case == 200) then {
_playerObj = objectFromNetId _content;
_weaponClass = currentWeapon _playerObj;
_mags = getArray(configFile >> 'CfgWeapons' >> _weaponClass >> 'magazines');
if !(_mags isEqualTo[]) then {
_firstMag = _mags select 0;
_magazineSizeMax = getNumber(configFile >> 'CfgMagazines' >> _firstMag >> 'count');
_playerObj addMagazine[_firstMag, _magazineSizeMax];
if (_playerObj == _admin) then {
[format['Gave Ammo (%1) to Self', _firstMag], 0] call "+_skn_server_adminLog+";
} else {
[format['Gave Ammo (%3) to Target: %1 (%2)', name _playerObj, getPlayerUID _playerObj, _firstMag], 0] call "+_skn_server_adminLog+";
};
};
};
if (_case == 555) then {
_target = objectFromNetId (_content select 1);
_itemSpawner = {
_nearbyWH = objNull;
if (vehicle _target != _target) then {
_nearbyWH = vehicle _target;
} else {
_nearbyWHArr = nearestObjects[_target, ['groundWeaponHolder'], 2];
if !(_nearbyWHArr isEqualTo[]) then {
_nearbyWH = _nearbyWHArr select 0;
} else {
_posWH = getposATL _target;
_nearbyWH = createVehicle['groundWeaponHolder', _posWH, [], 0, 'CAN_COLLIDE'];
_nearbyWH setPosATL _posWH;
};
};
if !(isNull _nearbyWH) then {
switch (_this select 1) do {
case 1: { _nearbyWH addMagazineCargoGlobal[(_this select 0), 1] };
case 2: { _nearbyWH addWeaponCargoGlobal[(_this select 0), 1] };
case 3: { _nearbyWH addItemCargoGlobal[(_this select 0), 1] };
case 4: { _nearbyWH addBackpackCargoGlobal[(_this select 0), 1] };
};
};
};
_permVehicleSpawner = {
_item = _this;
_return = false;
if (_item isKindOf 'Air' || _item isKindOf 'Ship' || _item isKindOf 'LandVehicle') then {
if !(EPOCH_VehicleSlots isEqualTo[]) then {
2016-08-31 17:46:49 +00:00
_serverSettingsConfig = configFile >> 'CfgEpochServer';
_removeweapons = [_serverSettingsConfig, 'removevehweapons', []] call EPOCH_fnc_returnConfigEntry;
_removemagazinesturret = [_serverSettingsConfig, 'removevehmagazinesturret', []] call EPOCH_fnc_returnConfigEntry;
2015-09-17 16:31:04 +00:00
_position = getPosATL _target;
_slot = EPOCH_VehicleSlots select 0;
EPOCH_VehicleSlots = EPOCH_VehicleSlots - [_slot];
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
missionNamespace setVariable ['EPOCH_VehicleSlotCount', count EPOCH_VehicleSlots, true];
2015-09-17 16:31:04 +00:00
_vehObj = createVehicle[_item, _position, [], 20, 'NONE'];
_return = true;
_vehObj call EPOCH_server_setVToken;
addToRemainsCollector[_vehObj];
_vehObj disableTIEquipment true;
clearWeaponCargoGlobal _vehObj;
clearMagazineCargoGlobal _vehObj;
clearBackpackCargoGlobal _vehObj;
clearItemCargoGlobal _vehObj;
2016-09-25 21:32:10 +00:00
2016-08-31 17:45:12 +00:00
if !(_removeweapons isequalto []) then {
{
_vehObj removeWeaponGlobal _x;
} foreach _removeweapons;
};
if !(_removemagazinesturret isequalto []) then {
{
_vehObj removeMagazinesTurret _x;
} foreach _removemagazinesturret;
};
2015-09-17 16:31:04 +00:00
_vehObj lock true;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_playerUID = getPlayerUID _target;
_playerGroup = _target getVariable['GROUP', ''];
2015-09-17 16:31:04 +00:00
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_lockOwner = _playerUID;
if (_playerGroup != '') then {
_lockOwner = _playerGroup;
2015-09-17 16:31:04 +00:00
};
_vehLockHiveKey = format['%1:%2', (call EPOCH_fn_InstanceID), _slot];
['VehicleLock', _vehLockHiveKey, EPOCH_vehicleLockTime, [_lockOwner]] call EPOCH_fnc_server_hiveSETEX;
2015-10-28 15:16:00 +00:00
_cfgEpochVehicles = 'CfgEpochVehicles' call EPOCH_returnConfig;
_availableColorsConfig = (_cfgEpochVehicles >> _item >> 'availableColors');
if (isArray(_availableColorsConfig)) then {
_textureSelectionIndex = (_cfgEpochVehicles >> _item >> 'textureSelectionIndex');
2015-09-17 16:31:04 +00:00
_selections = if (isArray(_textureSelectionIndex)) then {getArray(_textureSelectionIndex)} else {[0]};
_colors = getArray(_availableColorsConfig);
2015-09-17 16:31:04 +00:00
_textures = _colors select 0;
_color = floor(random(count _textures));
_count = (count _colors) - 1;
{
if (_count >= _forEachIndex) then {
_textures = _colors select _forEachIndex;
};
_vehObj setObjectTextureGlobal[_x, (_textures select _color)];
} forEach _selections;
_vehObj setVariable['VEHICLE_TEXTURE', _color];
};
_vehObj setVariable['VEHICLE_SLOT', _slot, true];
_vehObj call EPOCH_server_save_vehicle;
_vehObj call EPOCH_server_vehicleInit;
} else {
diag_log 'ADMIN: Unable to spawn vehicle, no slots available';
};
};
_return
};
_allClasses = [];
{
_classname = _x select 0;
_allClasses pushBack _classname;
_type = _x select 1;
if (_type in [0,1,2]) then {_classname call _permVehicleSpawner};
if (_type in [3,4,5]) then {[_classname,2] call _itemSpawner};
if (_type in [6,7]) then {[_classname,1] call _itemSpawner};
if (_type == 8) then {[_classname,4] call _itemSpawner};
if (_type == 9) then {[_classname,3] call _itemSpawner};
}forEach (_content select 0);
if (_target == _admin) then {
[format['Spawn: %1',_allClasses], 0] call "+_skn_server_adminLog+";
} else {
[format['Spawn Target: %1 (%2) %3', name _target, getPlayerUID _target, _allClasses], 0] call "+_skn_server_adminLog+";
};
};
if (_case == 666) then {
_playerObj = objectFromNetId (_content select 1);
_banID = 0;
'epochserver' callExtension format['820|%1|"+_skn_banReason+" #%2',getPlayerUID _playerObj,_banID];
['amb', format['%1 (%2): %3', name _playerObj, getPlayerUID _playerObj, _content select 0]] call EPOCH_fnc_server_hiveLog;
};
};");
_skn_admincode = compileFinal ("
2015-09-17 16:31:04 +00:00
waitUntil {(getPlayerUID player) != ''};
"+_skn_tg_sortOrder+" = 'Range';
"+_skn_tg_toggle+" = [];
"+_skn_tg_BanPlayer+" = objNull;
"+_skn_tg_delete+" = objNull;
"+_skn_tg_mapTeleport+" = false;
"+_skn_tg_old_esp+" = false;
"+_skn_tg_godMode+" = false;
"+_skn_tg_old_espMap+" = false;
"+_skn_tg_spawnTyp+" = 64;
"+_skn_tg_hideAdmin+" = false;
"+_skn_tg_infrontTP+" = false;
"+_skn_tg_map_player+" = false;
"+_skn_tg_map_corpse+" = false;
"+_skn_tg_map_loot+" = false;
"+_skn_mapLootArray+" = [];
"+_skn_tg_map_vehicle+" = false;
"+_skn_tg_map_ai+" = false;
"+_skn_tg_map_basebuilding+" = false;
uiNamespace setVariable['ESP_mainMap', findDisplay 12 displayCtrl 51];
uiNamespace setVariable['ESP_adminMap', findDisplay -1337 displayCtrl 7];
(findDisplay 46) displayAddEventHandler ['KeyDown','_this call "+_skn_AdminKeyDown+"'];
((findDisplay 12) displayCtrl 51) ctrlAddEventHandler ['MouseButtonDown', 'if (_this select 5) then {_this call "+_skn_mapTeleport+"}'];
{
(uiNamespace getVariable _x) ctrlRemoveAllEventHandlers 'Draw';
(uiNamespace getVariable _x) ctrlAddEventHandler['Draw',{
_getDmgColor = {
_dmg = damage _this;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
[0,1,_dmg,1] call EPOCH_colorRange
2015-09-17 16:31:04 +00:00
};
_display = _this select 0;
if ("+_skn_tg_map_player+") then {
_size = (0.5/ctrlMapScale _display) max 20;
{
_display drawIcon [
getText (configFile >> 'CfgVehicles' >> typeOf _x >> 'Icon'), _x call _getDmgColor, visiblePosition _x, _size, _size, getDir _x, name _x
];
}forEach (allPlayers select {alive _x});
2015-09-17 16:31:04 +00:00
};
if ("+_skn_tg_map_corpse+") then {
_size = (1/ctrlMapScale _display) max 20;
{
if (!isNull _x) then {
2015-10-28 15:16:00 +00:00
_color = [1,1,1,1];
2015-09-17 16:31:04 +00:00
_display drawIcon [
getText (configFile >> 'CfgVehicles' >> typeOf _x >> 'Icon'), _color, visiblePosition _x, _size, _size, getDir _x, typeOf _x
];
};
}forEach allDeadMen;
2015-09-17 16:31:04 +00:00
};
if ("+_skn_tg_map_loot+") then {
{
if (!isNull _x) then {
2015-10-28 15:16:00 +00:00
_color = [1,1,1,1];
2015-09-17 16:31:04 +00:00
_display drawRectangle [
visiblePosition _x,
5,
5,
getDir _x,
[1,1,1,1],
'#(rgb,8,8,3)color(1,0,0,1)'
];
};
}forEach "+_skn_mapLootArray+";
};
if ("+_skn_tg_map_vehicle+") then {
_size = (1/ctrlMapScale _display) max 20;
{
2015-10-28 15:16:00 +00:00
if (alive _x) then {
2015-09-17 16:31:04 +00:00
_display drawIcon [
getText (configFile >> 'CfgVehicles' >> typeOf _x >> 'Icon'), _x call _getDmgColor, visiblePosition _x, _size, _size, getDir _x,
getText (configFile >> 'CfgVehicles' >> typeOf _x >> 'displayName')
];
};
}forEach vehicles;
};
if ("+_skn_tg_map_ai+") then {
_size = (0.5/ctrlMapScale _display) max 20;
{
2016-01-19 19:30:37 +00:00
_agent = agent _x;
_display drawIcon [
getText (configFile >> 'CfgVehicles' >> typeOf _agent >> 'Icon'), _agent call _getDmgColor, visiblePosition _agent, _size, _size, getDir _agent,
getText (configFile >> 'CfgVehicles' >> typeOf _agent >> 'displayName')
];
}forEach agents;
2015-09-17 16:31:04 +00:00
};
if ("+_skn_tg_map_basebuilding+") then {
_size = (1/ctrlMapScale _display) max 20;
{
2017-06-16 23:16:32 +00:00
_display drawIcon [
getText (configFile >> 'CfgVehicles' >> 'PlotPole_Epoch' >> 'Icon'), _x call _getDmgColor, visiblePosition _x, _size, _size, getDir _x,
getText (configFile >> 'CfgVehicles' >> 'PlotPole_Epoch' >> 'displayName')
];
} forEach ((epoch_centerMarkerPosition) nearObjects ['PlotPole_Epoch',(EPOCH_dynamicVehicleArea)]);
2015-09-17 16:31:04 +00:00
};
if ("+_skn_tg_old_espMap+") then {
{
if !(isNull _x) then {
_pos = visiblePosition _x;
if (isPlayer _x) then {
_lastPos = _x getVariable['ESP_old_MAP', []];
_playerGrp = group _x;
_grpColorIndex = EPOCH_ESPGROUPS find _playerGrp;
if (_grpColorIndex == -1) then {
EPOCH_ESPGROUPCOLORS pushBack[random 1, random 1, random 1, 1];
_grpColorIndex = EPOCH_ESPGROUPS pushBack _playerGrp;
};
_color = EPOCH_ESPGROUPCOLORS select _grpColorIndex;
(_this select 0) drawIcon[getText(configFile >> 'CfgVehicles' >> typeOf(vehicle _x) >> 'Icon'), _color, _pos, 0.5 / ctrlMapScale(_this select 0), 0.5 / ctrlMapScale(_this select 0), getDir _x, name _x, 1, 0.05, 'PuristaMedium'];
if ((count _lastPos) >= 100) then {
for '_i' from 10 to 100 step 10 do {
_pos1 = _lastPos select(_i - 10);
_pos2 = _lastPos select _i;
if (!isNil '_pos1' && !isNil '_pos2') then {
(_this select 0) drawLine[_pos1, _pos2, [1, 0, 0, 1]];
};
};
};
};
};
2015-10-28 15:16:00 +00:00
}forEach EPOCH_ESPMAP_TARGETS;
2015-09-17 16:31:04 +00:00
};
}];
}forEach ['ESP_mainMap','ESP_adminMap'];
"+_skn_adminRequest_PVC+" = {
_this pushBack player;
_this pushBack Epoch_personalToken;
"+_skn_doAdminRequest+" = _this;
publicVariableServer '"+_skn_doAdminRequest+"';
};
"+_skn_adminLog_PVC+" = {
_this pushBack player;
_this pushBack Epoch_personalToken;
"+_skn_doAdminLog+" = _this;
publicVariableServer '"+_skn_doAdminLog+"';
};
"+_skn_AdminKeyDown+" = {
_keyDown = _this select 1;
if (_keyDown == "+str _skn_adminMenuMenuKey+") then {call "+_skn_AdminMenu_Init+"};
if (_keyDown == 0x3C) then {if (cameraOn != vehicle player) then { vehicle player switchCamera 'External' } };
if (_keyDown == "+str _skn_adminMenuInfrontTeleport+") then {call "+_skn_infrontTP+"};
if (_keyDown == 0x3F) then {call "+_skn_delete+"};
};
"+_skn_AdminMenu_Init+" = {
disableSerialization;
_hours = floor(servertime/60/60);
_minutes = round((serverTime/60)-(_hours*60));
if (!dialog) then {createDialog 'Skaronator_AdminMenu';
{(_x call "+_skn_getCtrl+") ctrlShow false}forEach[40,41,42,43,50,51,52,60,61,62,63,64,65,66,67,68,69,70,71] };
if (getPlayerUID player in "+str _skn_blockedSpawnMenuUID+") then {ctrlEnable [21,false]};
ctrlEnable [22,false];
(1 call "+_skn_getCtrl+") ctrlSetText format['Players %1 of %2',count allPlayers,playersNumber civilian];
2015-09-17 16:31:04 +00:00
(2 call "+_skn_getCtrl+") ctrlSetText format['Epoch Mod Admin Menu by Skaronator.com - Server Uptime: %1h %2min', _hours, _minutes];
(5 call "+_skn_getCtrl+") ctrlSetEventHandler ['LBDblClick', '_this call "+_skn_fnc_Spec+"'];
(6 call "+_skn_getCtrl+") ctrlSetEventHandler ['LBDblClick', '_this call "+_skn_dbClickMainMenu+"'];
(7 call "+_skn_getCtrl+") ctrlSetEventHandler ['MouseButtonDown', 'if (_this select 5) then {_this call "+_skn_mapTeleport+"}'];
if (call "+_skn_removespawnMenu+") then {uiSleep 0.4};
call "+_skn_Update_AdminButtons+";
_menu = call "+_skn_mainMenuCfg+";
_menu call "+_skn_FillMainMenu+";
call "+_skn_FillPlayerMenu+";
0 call "+_skn_switchMainMenu+";
};
"+_skn_hideAdmin+" = {
"+_skn_tg_hideAdmin+" = !"+_skn_tg_hideAdmin+";
[106, "+_skn_tg_hideAdmin+"] call "+_skn_adminRequest_PVC+";
};
"+_skn_esp+" = {
_enable = false;
if (_this) then {
EPOCH_ESP_PLAYER = !EPOCH_ESP_PLAYER;
if (EPOCH_ESP_PLAYER) then {
['Player ESP',2] call "+_skn_adminLog_PVC+";
_enable = true
} else {
['Player ESP',1] call "+_skn_adminLog_PVC+";
}
} else {
EPOCH_ESP_VEHICLES = !EPOCH_ESP_VEHICLES;
if (EPOCH_ESP_VEHICLES) then {
['Vehicle ESP',2] call "+_skn_adminLog_PVC+";
_enable = true
} else {
['Vehicle ESP',1] call "+_skn_adminLog_PVC+";
}
};
if (EPOCH_ESP_VEHICLEPLAYER isEqualTo [] && _enable) then {
waitUntil {
EPOCH_ESP_VEHICLEPLAYER = (cameraOn nearEntities [['Epoch_Male_F', 'Epoch_Female_F', 'LandVehicle', 'Ship', 'Air', 'Tank'], viewDistance max 1000 min 2500]) - [vehicle player];
uiSleep 1;
!EPOCH_ESP_PLAYER && !EPOCH_ESP_VEHICLES
};
EPOCH_ESP_VEHICLEPLAYER = [];
};
};
"+_skn_godMode+" = {
"+_skn_tg_godMode+" = !"+_skn_tg_godMode+";
if ("+_skn_tg_godMode+") then {
['God Mode',2] call "+_skn_adminLog_PVC+";
player setVariable ['EPOCH_gm_enabled',true,true];
2015-09-17 16:31:04 +00:00
waitUntil {
player setBleedingRemaining 0;
player setOxygenRemaining 1;
player allowDamage false;
{
missionNamespace setVariable[format['EPOCH_player%1', _x], EPOCH_defaultVars select(EPOCH_customVars find _x)]
} forEach['Temp','Hunger','Thirst','Toxicity','Stamina','BloodP'];
EPOCH_playerEnergy = missionNamespace getVariable ['EPOCH_playerEnergyMax', 2500];
2015-09-17 16:31:04 +00:00
uiSleep 0.25;
!"+_skn_tg_godMode+"
};
player allowDamage true;
player setVariable ['EPOCH_gm_enabled',false,true];
2015-09-17 16:31:04 +00:00
} else {
['God Mode',1] call "+_skn_adminLog_PVC+";
}
};
"+_skn_repairVehicle+" = {
"+_skn_systemDebug5+"
_veh = objNull;
if (_this isEqualTo []) then {
if (vehicle player == player) then {
_veh = cursorTarget
} else {
_veh = vehicle player
}
} else {
_player = netId (_this select 1);
if (vehicle _player != _player) then {
_veh = vehicle _player
}
};
"+_skn_systemDebug4+"
if (!isNull _veh) then {
if ((_veh isKindOf 'LandVehicle') || (_veh isKindOf 'Air') || (_veh isKindOf 'Ship') || (_veh isKindOf 'Tank')) then {
[108,_veh] call "+_skn_adminRequest_PVC+";
"+_skn_systemDebug3+"
}
}
};
"+_skn_spawnLoot+" = {
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_masterConfig = 'CfgBuildingLootPos' call EPOCH_returnConfig;
_lootClasses = [];
_lootClassesIgnore = ['Default'];
'_cN = configName _x;if !(_cN in _lootClassesIgnore)then{_lootClasses pushBack _cN}; true' configClasses _masterConfig;
2015-09-17 16:31:04 +00:00
_cntBuildings = 0;
{
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
if (_x call EPOCH_spawnLoot) then {
2015-09-17 16:31:04 +00:00
_cntBuildings = _cntBuildings + 1;
};
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
}forEach (nearestObjects[player, _lootClasses, _this]);
2016-06-06 21:12:15 +00:00
[format['Looting %2 Buildings within (%1)m',_this,_cntBuildings],0] call "+_skn_adminLog_PVC+";
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
hint format['Spawned Loot for %1 Buildings',_cntBuildings];
2015-09-17 16:31:04 +00:00
};
"+_skn_old_esp+" = {
"+_skn_tg_old_esp+" = !"+_skn_tg_old_esp+";
if ("+_skn_tg_old_esp+") then {
['ESP Old',2] call "+_skn_adminLog_PVC+";
waitUntil{
EPOCH_ESP_TARGETS = (cameraOn nearEntities[['Epoch_Male_F', 'Epoch_Female_F', 'LandVehicle', 'Ship', 'Air', 'Tank'], 1000]) - [vehicle player];
uiSleep 1;
!"+_skn_tg_old_esp+"
};
} else {
['ESP Old',1] call "+_skn_adminLog_PVC+";
EPOCH_ESP_TARGETS = [];
};
};
"+_skn_old_espMap+" = {
"+_skn_tg_old_espMap+" = !"+_skn_tg_old_espMap+";
if ("+_skn_tg_old_espMap+") then {
['ESP-map Old', 2] call "+_skn_adminLog_PVC+";
waitUntil{
uiSleep 1;
EPOCH_ESPMAP_TARGETS = (cameraOn nearEntities[['CAManBase', 'LandVehicle', 'Ship', 'Air', 'Tank'], 10000]) - [player, vehicle player];
{
if (isPlayer _x) then {
_pos = visiblePosition _x;
_lastPos = _x getVariable['ESP_old_MAP', []];
_lastPos pushBack _pos;
if (count _lastPos > 101) then {
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_lastPos deleteAt 0;
2015-09-17 16:31:04 +00:00
};
_x setVariable['ESP_old_MAP', _lastPos];
};
}forEach EPOCH_ESPMAP_TARGETS;
!"+_skn_tg_old_espMap+"
};
} else {
['ESP-map Old', 1] call "+_skn_adminLog_PVC+";
EPOCH_ESPMAP_TARGETS = [];
};
};
"+_skn_getCtrl+" = compileFinal '(findDisplay -1337) displayCtrl _this';
"+_skn_Update_AdminButtons+" = {
disableSerialization;
{((_x select 0) call "+_skn_getCtrl+") ctrlSetText (_x select 1)}forEach
[
[23,format['Hacker Log (%1)',count "+_skn_pv_hackerLog+"]],
[24,format['Admin Log (%1)',count "+_skn_pv_adminLog+"]]
];
};
"+_skn_mapTeleport+" = {
if ("+_skn_tg_mapTeleport+") then {
_pos = (_this select 0) posScreenToWorld [_this select 2, _this select 3];
if (vehicle player == player) then {
if (surfaceIsWater _pos) then [{vehicle player setPosASL _pos},{vehicle player setPosATL _pos}];
} else {
[109,_pos] call "+_skn_adminRequest_PVC+";
2015-10-28 15:16:00 +00:00
};
2015-09-17 16:31:04 +00:00
if (!dialog) then {openMap [false, false]};
};
};
"+_skn_deleteMenu+" = [
['Delete Menu',true],
[format ['%1',typeOf "+_skn_tg_delete+"], [-1], '', -5, [['expression', '']], '1', '0'],
['Delete', [2], '', -5, [['expression', '[] spawn "+_skn_deleteNow+"']], '1', '1'],
['Exit', [0], '', -5, [['expression', '']], '1', '1']
];
"+_skn_deleteNow+" = {
if (!isNull "+_skn_tg_delete+") then {
if (!isPlayer "+_skn_tg_delete+") then {
[104,"+_skn_tg_delete+"] call "+_skn_adminRequest_PVC+";
};
};
"+_skn_tg_delete+" = objNull;
};
"+_skn_delete+" = {
showCommandingMenu '';
if (!isNull cursorTarget) then {
"+_skn_tg_delete+" = cursorTarget;
showCommandingMenu '#USER:"+_skn_deleteMenu+"';
};
};
"+_skn_fnc_Spec+" = {
_player = objectFromNetId (_this select 0 lbData (_this select 1));
if (isNull _player) exitWith {};
if (!isPlayer _player) exitWith {};
cutText ['F2 To Cancel!','PLAIN DOWN',1];
vehicle _player switchCamera 'External';
};
"+_skn_mainMenuCfg+" = {"+_skn_adminMenuLow+"};
if (getPlayerUID player in "+str _skn_adminsOwner+") then {
"+_skn_mainMenuCfg+" = {"+_skn_adminMenuOwner+"};
};
if (getPlayerUID player in "+str _skn_adminsHigh+") then {
"+_skn_mainMenuCfg+" = {"+_skn_adminMenuHigh+"};
};
"+_skn_freeCam+" = {
_getPos = player modelToWorld[0, -1.5, 1.75];
_cam = 'camera' camCreate _getPos;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_cam setDir (_getPos getDir player);
2015-09-17 16:31:04 +00:00
_cam camCommand 'MANUAL ON';
_cam camCommand 'INERTIA OFF';
_cam cameraEffect['INTERNAL', 'BACK'];
showCinemaBorder false;
cutText['Right Click To Cancel!', 'PLAIN DOWN', 1];
};
"+_skn_FillMainMenu+" = {
lbClear (8 call "+_skn_getCtrl+");
_ctrl = 6 call "+_skn_getCtrl+";
lbClear _ctrl;
for '_i' from 0 to count _menu -1 do {
_item = _menu select _i;
_titleoption = _item select 3;
_color = _item select 4;
_index = _ctrl lbAdd format['%1',_item select 0];
if (count _color == 0) then {
_color = [1, 1, 1, 1];
if (_titleoption == '1') then {_color = [0.42,0.64,0.88,1]};
if (_titleoption == '3') then {_color = [0.27,0.39,0.53,1]};
};
if (_titleoption == '2') then {
_color = if (_index in "+_skn_tg_toggle+") then [{[0.17,1,0,1]},{[0.51,0.51,0.51,1]}];
};
_ctrl lbSetColor [_i,_color];
_ctrl lbSetData [_i,str [_item select 1,_item select 2,_titleoption]];
};
};
"+_skn_switchMainMenu+" = {
disableSerialization;
_main = 6 call "+_skn_getCtrl+";
_map = 7 call "+_skn_getCtrl+";
_table = 8 call "+_skn_getCtrl+";
if (_this == 0) then {
_main ctrlSetPosition [0.293698 * safezoneW + safezoneX,0.2888 * safezoneH + safezoneY,0.206297 * safezoneW,0.4862 * safezoneH];
_map ctrlSetPosition [0.501031 * safezoneW + safezoneX,0.28836 * safezoneH + safezoneY,0.205265 * safezoneW,0.486548 * safezoneH];
_table ctrlShow false;
_table ctrlSetPosition [0.293698 * safezoneW + safezoneX,0.2888 * safezoneH + safezoneY,0.206297 * safezoneW,0.4862 * safezoneH];
_table ctrlCommit 0;
_main ctrlSetFade 0;
_map ctrlShow true;
};
if (_this in [1,2]) then {
{(_x call "+_skn_getCtrl+") ctrlShow false}forEach[30,31,32,33,34];
_main ctrlSetPosition [0.293698 * safezoneW + safezoneX,0.2888 * safezoneH + safezoneY,0.412598 * safezoneW,0.4862 * safezoneH];
_map ctrlSetPosition [0.709388 * safezoneW + safezoneX,0.28836 * safezoneH + safezoneY,-0.00312413 * safezoneW,0.486548 * safezoneH];
_main ctrlSetFade 0;
if (_this == 2) then {
_main ctrlcommit 0;
_main ctrlSetFade 1;
};
};
_main ctrlCommit 0.8;
_map ctrlCommit 0.8;
};
"+_skn_dbClickMainMenu+" = {
_currentSelect = _this select 1;
_data = call compile (_this select 0 lbData _currentSelect);
_tO = _data select 2;
if (_tO == '1') exitWith {};
if (_tO == '2') exitWith {
(_data select 0) spawn (_data select 1);
if (_currentSelect in "+_skn_tg_toggle+") then {
lbSetColor [6,_currentSelect,[0.51,0.51,0.51,1]];
"+_skn_tg_toggle+" = "+_skn_tg_toggle+" - [_currentSelect];
} else {
lbSetColor [6,_currentSelect,[0.165,1,0,1]];
"+_skn_tg_toggle+" pushBack _currentSelect;
};
};
if (_tO == '4') exitWith {
if ((lbCurSel 5) >= 0) then {
[_text,lbData [5, lbCurSel 5],(_data select 0)] spawn (_data select 1);
};
};
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
if ((_data select 1) isEqualType {}) then {(_data select 0) spawn (_data select 1)};
2015-09-17 16:31:04 +00:00
};
Skaronator_fnc_handleButton = compileFinal ('
disableSerialization;
_idc = ctrlIDC (_this select 0);
if (_idc == 10) then { "+_skn_tg_sortOrder+" = ''Range''; call "+_skn_FillPlayerMenu+"};
if (_idc == 11) then { "+_skn_tg_sortOrder+" = ''Alphabetically''; call "+_skn_FillPlayerMenu+"};
if (_idc == 20) then {call "+_skn_AdminMenu_Init+"};
if (_idc == 21) then {call "+_skn_spawnMenu+"};
if (_idc == 23) then {call "+_skn_hackerLog+"};
if (_idc == 24) then {call "+_skn_adminLog+"};
if (_idc == 32) then {true call "+_skn_doBan+"};
if (_idc == 33) then {false call "+_skn_doBan+"};
if (_idc == 50) then {lbClear 43;"+_skn_tg_limitSpawn+" = [true,true,true,true,true,true,true,true,true,true,true]};
if (_idc == 51) then {true call "+_skn_spawnSpawnMenu+"};
if (_idc == 52) then {false call "+_skn_spawnSpawnMenu+"};
if (_idc in [61,62,63,64,65,66,67,68,69,70,71]) then {
"+_skn_tg_spawnTyp+" = _idc;
_idc call "+_skn_fillSpawnMenu+";
};
');
"+_skn_spawnSpawnMenu+" = {
_target = objNull;
if (_this) then {
if ((lbCurSel 5) >= 0) then {
_target = objectFromNetId (lbData [5, lbCurSel 5]);
};
} else {
_target = player;
};
if (isNull _target) exitWith {};
_ctrl = 43 call "+_skn_getCtrl+";
_spawn = [];
for '_i' from 0 to (lbSize _ctrl)-1 do {
_data = call compile (_ctrl lbData _i);
_spawn pushBack [_data select 0, _data select 2];
};
lbClear _ctrl;
"+_skn_tg_limitSpawn+" = [true,true,true,true,true,true,true,true,true,true,true];
"+_skn_systemDebug2+"
[555,[_spawn,netId _target]] call "+_skn_adminRequest_PVC+";
};
"+_skn_spawnMenu+" = {
false call "+_skn_doBan+";
if (!isNull "+_skn_tg_BanPlayer+") then {uiSleep 0.8;false spawn "+_skn_switchTable+"};
2 call "+_skn_switchMainMenu+";
lbclear (6 call "+_skn_getCtrl+");
_table = 8 call "+_skn_getCtrl+";
lbclear _table;
_table ctrlShow false;
"+_skn_tg_limitSpawn+" = [true,true,true,true,true,true,true,true,true,true,true];
comment '[primaryWeapon,secondaryWeapon,launcher,backpack,map,rangefinderSlot,vehicleSlot]';
(41 call "+_skn_getCtrl+") ctrlSetEventHandler ['LBDblClick', ""
_ctrl = _this select 0;
_currentSelect = _this select 1;
_type = call compile (_ctrl lbData _currentSelect) select 1;
_allowed = true;
if (_type != -1) then {
_allowed = "+_skn_tg_limitSpawn+" select _type;
"+_skn_tg_limitSpawn+" set [_type,false];
};
"+_skn_systemDebug1+"
if (_allowed) then {
_otherList = 43 call "+_skn_getCtrl+";
_index = _otherList lbAdd format ['%1',_ctrl lbText _currentSelect];
_otherList lbSetData [_index, _ctrl lbData _currentSelect];
_otherList lbSetPicture [_index,_ctrl lbPicture _currentSelect];
} else {
hint 'You can just select one Weapon/Item of this Type!';
};
""];
(43 call "+_skn_getCtrl+") ctrlSetEventHandler ['LBDblClick', '
_ctrl = _this select 0;
_currentSelect = _this select 1;
_type = call compile (_ctrl lbData _currentSelect) select 1;
if (_type != -1) then {
"+_skn_tg_limitSpawn+" set [_type,true];
};
_ctrl lbDelete _currentSelect;
'];
{_i = _x call "+_skn_getCtrl+";_i ctrlShow true;_i ctrlSetFade 1;_i ctrlcommit 0;_i ctrlSetFade 0;_i ctrlcommit 0.8}forEach[40,41,42,43,50,51,52,60,61,62,63,64,65,66,67,68,69,70,71];
"+_skn_tg_spawnTyp+" call "+_skn_fillSpawnMenu+";
};
"+_skn_removespawnMenu+" = {
if (ctrlShown (40 call "+_skn_getCtrl+")) then {
{_i = _x call "+_skn_getCtrl+";_i ctrlShow true;_i ctrlSetFade 1;_i ctrlcommit 0.8}forEach[40,41,42,43,50,51,52,60,61,62,63,64,65,66,67,68,69,70,71];
[] spawn {uiSleep 0.8;{_x call "+_skn_getCtrl+" ctrlShow false}forEach[40,41,42,43,50,51,52,60,61,62,63,64,65,66,67,68,69,70,71]};
true
} else {false};
};
"+_skn_fillSpawnMenu+" = {
_ctrl = 41 call "+_skn_getCtrl+";
lbclear _ctrl;
_button = _this call "+_skn_getCtrl+";
_button ctrlSetTextColor [1, 0, 0, 1];
{_x call "+_skn_getCtrl+" ctrlSetTextColor [1, 1, 1, 1]}forEach([61,62,63,64,65,66,67,68,69,70,71]-[_this]);
if (_this == 61) then {
_airVehicles = ""
getText(_x >> 'displayName') != '' &&
getText(_x >> 'picture') != '' &&
getNumber(_x >> 'type') != 0 &&
getText (_x >> 'vehicleClass') in ['Air']
""configClasses (configFile >> 'CfgVehicles');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_ctrl lbSetData[_index, str[configName _x, 6, 0]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _airVehicles;
};
if (_this == 62) then {
_landVehicles = ""
getText(_x >> 'displayName') != '' &&
getText(_x >> 'picture') != '' &&
configName _x != 'PaperCar' &&
getText (_x >> 'vehicleClass') in ['Car']
""configClasses (configFile >> 'CfgVehicles');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_ctrl lbSetData[_index, str[configName _x, 6, 1]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _landVehicles;
};
if (_this == 63) then {
_shipVehicles = ""
getText(_x >> 'displayName') != '' &&
getText(_x >> 'picture') != '' &&
getNumber(_x >> 'type') in [1,2,3,4] &&
getText (_x >> 'vehicleClass') in ['Ship']
""configClasses (configFile >> 'CfgVehicles');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_ctrl lbSetData[_index, str[configName _x, 6, 2]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _shipVehicles;
};
if (_this == 64) then {
_weapons = ""
getText(_x >> 'displayName') != '' &&
getText(_x >> 'picture') != '' &&
getNumber(_x >> 'scope') in [0,2] &&
getNumber(_x >> 'type') in [1,2,4]
""configClasses (configFile >> 'CfgWeapons');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_type = getNumber(_x >> 'type') - 1;
if (getNumber(_x >> 'type') == 4) then { _type = 2 };
_ctrl lbSetData[_index, str[configName _x, _type, _type + 3]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _weapons;
};
if (_this == 65) then {
_magazines = ""
getText(_x >> 'displayName') != '' &&
getText(_x >> 'picture') != '' &&
getNumber(_x >> 'scope') in [0,2] &&
getText(_x >> 'ammo') != ''
""configClasses (configFile >> 'CfgMagazines');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_ctrl lbSetData[_index, str[configName _x, -1, 6]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _magazines;
};
if (_this == 66) then {
_magazines = ""
getText(_x >> 'displayName') != '' &&
getText(_x >> 'picture') != '' &&
getNumber(_x >> 'scope') in[0, 2] &&
getText(_x >> 'ammo') == ''
""configClasses(configFile >> 'CfgMagazines');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_ctrl lbSetData[_index, str[configName _x, -1, 7]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _magazines;
};
if (_this == 67) then {
_backpack = ""getText(_x >> 'displayName') != '' && getText(_x >> 'picture') != '' && getNumber(_x >> 'isbackpack') == 1""configClasses(configFile >> 'CfgVehicles');
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> configName _x)) then{
_index = _ctrl lbAdd format['%1', getText(_x >> 'displayName')];
_ctrl lbSetData[_index, str[configName _x, 3, 8]];
_ctrl lbSetPicture[_index, getText(_x >> 'picture')];
};
}forEach _backpack;
};
if (_this == 68) then {
_uniforms = ['U_O_FullGhillie_lsh',
'U_O_FullGhillie_sard',
'U_O_FullGhillie_ard',
'U_O_CombatUniform_ocamo',
'U_O_GhillieSuit',
'U_O_PilotCoveralls',
'U_O_Wetsuit',
'U_OG_Guerilla1_1',
'U_OG_Guerilla2_1',
'U_OG_Guerilla2_2',
'U_OG_Guerilla2_3',
'U_OG_Guerilla3_1',
'U_OG_Guerilla3_2',
'U_OG_leader',
'U_C_Poloshirt_stripped',
'U_C_Poloshirt_blue',
'U_C_Poloshirt_burgundy',
'U_C_Poloshirt_tricolour',
'U_C_Poloshirt_salmon',
'U_C_Poloshirt_redwhite',
'U_C_Poor_1',
'U_C_WorkerCoveralls',
'U_C_Journalist',
'U_C_Scientist',
'U_OrestesBody',
'U_Wetsuit_uniform',
'U_Wetsuit_White',
'U_Wetsuit_Blue',
'U_Wetsuit_Purp',
'U_Wetsuit_Camo',
'U_CamoRed_uniform',
'U_CamoAloha_uniform',
'U_CamoBiker_uniform',
'U_CamoBubblegum_uniform',
'U_CamoLumberjack_uniform',
'U_CamoOutback_uniform',
'U_CamoPink_uniform',
'U_CamoPinkPolka_uniform',
2015-09-17 16:31:04 +00:00
'U_CamoBrn_uniform',
'U_CamoBlue_uniform',
'U_Camo_uniform',
'U_ghillie1_uniform',
'U_ghillie2_uniform',
'U_ghillie3_uniform',
'U_C_Driver_1',
'U_C_Driver_2',
'U_C_Driver_3',
'U_C_Driver_4',
'U_C_Driver_1_black',
'U_C_Driver_1_blue',
'U_C_Driver_1_green',
'U_C_Driver_1_red',
'U_C_Driver_1_white',
'U_C_Driver_1_yellow',
'U_C_Driver_1_orange',
'U_C_Driver_1_red'];
{
_index = _ctrl lbAdd format['%1', getText(configFile >> 'CfgWeapons' >> _x >> 'displayName')];
_ctrl lbSetData[_index, str[_x, -1, 9]];
_ctrl lbSetPicture[_index, getText(configFile >> 'CfgWeapons' >> _x >> 'picture')];
}forEach _uniforms;
};
if (_this == 69) then {
_optics = ['optic_Arco', 'optic_Hamr', 'optic_Aco', 'optic_ACO_grn', 'optic_Aco_smg', 'optic_ACO_grn_smg', 'optic_Holosight', 'optic_Holosight_smg', 'optic_SOS', 'optic_MRCO', 'optic_DMS', 'optic_Yorris', 'optic_MRD', 'optic_LRPS', 'optic_NVS', 'optic_tws', 'optic_tws_mg'];
_muzzles = ['muzzle_snds_H','muzzle_snds_L','muzzle_snds_M','muzzle_snds_B','muzzle_snds_H_MG','muzzle_snds_acp','Heal_EPOCH','Defib_EPOCH','Repair_EPOCH','acc_flashlight','acc_pointer_IR'];
_misc = ['Binocular','NVG_EPOCH','ItemCompass','ItemGPS','ItemGeigerCounter_EPOCH','ItemMap','EpochRadio0','EpochRadio1','EpochRadio2','EpochRadio3','EpochRadio4','EpochRadio5','EpochRadio6','EpochRadio7','EpochRadio8','EpochRadio9','ItemWatch'];
2015-09-17 16:31:04 +00:00
_attachments = _optics + _muzzles + _misc;
{
_config = 'CfgPricing' call EPOCH_returnConfig;
if (isClass(_config >> _x)) then{
_index = _ctrl lbAdd format['%1', getText(configFile >> 'CfgWeapons' >> _x >> 'displayName')];
_ctrl lbSetData[_index, str[_x, -1, 9]];
_ctrl lbSetPicture[_index, getText(configFile >> 'CfgWeapons' >> _x >> 'picture')];
};
}forEach _attachments;
};
if (_this == 70) then {
2015-09-30 20:16:59 +00:00
_headgear = ['wolf_mask_epoch','pkin_mask_epoch','clown_mask_epoch'];
2015-09-17 16:31:04 +00:00
for '_h' from 1 to 104 do
{
_headgear pushBack format['H_%1_EPOCH',_h];
};
{
_index = _ctrl lbAdd format['%1', getText(configFile >> 'cfgWeapons' >> _x >> 'displayName')];
_ctrl lbSetData[_index, str[_x, -1, 9]];
_ctrl lbSetPicture[_index, getText(configFile >> 'cfgWeapons' >> _x >> 'picture')];
}forEach _headgear;
};
if (_this == 71) then {
_vests = [];
for '_v' from 1 to 40 do
{
_vests pushBack format['V_%1_EPOCH', _v];
};
{
_index = _ctrl lbAdd format['%1', getText(configFile >> 'cfgWeapons' >> _x >> 'displayName')];
_ctrl lbSetData[_index, str[_x, -1, 9]];
_ctrl lbSetPicture[_index, getText(configFile >> 'cfgWeapons' >> _x >> 'picture')];
}forEach _vests;
};
};
"+_skn_FillPlayerMenu+" = {
_ctrl = 5 call "+_skn_getCtrl+";
lbclear _ctrl;
_sorted = [];
_unsorted = allPlayers;
2015-09-17 16:31:04 +00:00
_buttonRange = 10 call "+_skn_getCtrl+";
_buttonRange ctrlSetText 'Range';
_buttonAlphabetically = 11 call "+_skn_getCtrl+";
_buttonAlphabetically ctrlSetText 'Alphabet';
if ("+_skn_tg_sortOrder+" == 'Range') then {
_pos = getPosATL vehicle player;
{
_temp = _x;
{
if ((getPosATL _x distance _pos) < (getPosATL _temp distance _pos)) exitWith {
_unsorted = _unsorted - [_x];
_sorted pushBack _x;
_temp = _x;
};
}forEach _unsorted;
}forEach _unsorted;
_buttonRange ctrlSetTextColor [1, 0, 0, 1];
_buttonAlphabetically ctrlSetTextColor [1, 1, 1, 1];
};
if ("+_skn_tg_sortOrder+" == 'Alphabetically') then {
_unsortedName = [];
{
_unsortedName pushBack (name _x);
}forEach _unsorted;
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
_alphabetically = _unsortedName;
_alphabetically sort true;
2015-09-17 16:31:04 +00:00
{
{
if (name _x == (_alphabetically select 0)) exitWith {
_alphabetically = _alphabetically - [_alphabetically select 0];
_unsorted = _unsorted - [_x];
_sorted pushBack _x;
};
}forEach _unsorted;
}forEach _unsorted;
_buttonAlphabetically ctrlSetTextColor [1, 0, 0, 1];
_buttonRange ctrlSetTextColor [1, 1, 1, 1];
};
if (_sorted isEqualTo []) then {_sorted = [player]};
_skn_fnc_addPlayerToList = {
_player = _this select 0;
_index = _ctrl lbAdd format ['%1', name _player];
_ctrl lbSetData [_index, netId _player];
_ctrl lbSetColor [_index, _this select 1];
if (vehicle _player == _player) then {
_pic = '';
if (currentWeapon _player != '') then {
_pic = getText(configFile >> 'CfgWeapons' >> currentweapon _player >> 'picture')
} else {
if (primaryWeapon _player == '') then {
_pic = getText(configFile >> 'CfgVehicles' >> typeof vehicle _player >> 'picture')
} else {
_pic = getText(configFile >> 'CfgWeapons' >> primaryweapon _player >> 'picture')
};
};
_ctrl lbSetPicture [_index,_pic];
} else {
_ctrl lbSetPicture [_index,getText(configFile >> 'CfgVehicles' >> typeof vehicle _player >> 'picture')];
};
};
_ctrl lbAdd ' Admins';
_ctrl lbSetColor [(lbsize _ctrl)-1, [0,0.6,1,1]];
{
if (getPlayerUID _x in "+str _skn_adminUIDArray+") then {_sorted = _sorted - [_x];[_x,[0,1,0,1]] call _skn_fnc_addPlayerToList};
}forEach _sorted;
_ctrl lbAdd '';
_ctrl lbAdd ' Normal Player';
_ctrl lbSetColor [(lbsize _ctrl)-1, [1,1,1,1]];
{
if (vehicle _x == _x) then {_sorted = _sorted - [_x];[_x,[0,1,0,1]] call _skn_fnc_addPlayerToList};
}forEach _sorted;
_ctrl lbAdd '';
_ctrl lbAdd ' Vehicle Player';
_ctrl lbSetColor [(lbsize _ctrl)-1, [1,1,1,1]];
{[_x,[0,1,0,1]] call _skn_fnc_addPlayerToList}forEach _sorted;
_ctrl lbAdd '';_ctrl lbAdd '';
};
"+_skn_switchTable+" = {
disableSerialization;
_map = 7 call "+_skn_getCtrl+";
_table = 8 call "+_skn_getCtrl+";
if ((ctrlPosition _table) isEqualTo [0.293698 * safezoneW + safezoneX,0.2888 * safezoneH + safezoneY,0.206297 * safezoneW,0.4862 * safezoneH]) then {
_table ctrlSetPosition [0.293698 * safezoneW + safezoneX,0.2888 * safezoneH + safezoneY,0.206297 * safezoneW,0.4862 * safezoneH];
_table ctrlCommit 0;
_table ctrlSetEventHandler ['LBSelChanged', 'if ((_this select 1) != -1) then {lnbSetCurSelRow [8,-1]};'];
_table ctrlShow _this;
_table ctrlSetPosition [0.293698 * safezoneW + safezoneX,0.2888 * safezoneH + safezoneY,0.412598 * safezoneW,0.4862 * safezoneH];
_table ctrlCommit 0.8;
};
_time = diag_tickTime;
waitUntil {
if (diag_tickTime-_time>1) exitWith {true};
if ((ctrlPosition _map) isEqualTo [0.709388 * safezoneW + safezoneX,0.28836 * safezoneH + safezoneY,-0.00312413 * safezoneW,0.486548 * safezoneH]) exitWith {_map ctrlShow false;true};
};
};
"+_skn_hackerLog+" = {
1 call "+_skn_switchMainMenu+";
lbClear (6 call "+_skn_getCtrl+");
_table = 8 call "+_skn_getCtrl+";
lbClear _table;
true spawn "+_skn_switchTable+";
if (call "+_skn_removespawnMenu+") then {
uiSleep 0.4;
_table ctrlSetFade 1;
_table ctrlcommit 0;
_table ctrlSetFade 0;
_table ctrlcommit 0.8;
};
_table ctrlShow true;
_table lnbAddRow ['==================================== HACKER LOG ======================================'];
{
_player = _x select 0;
_color = _x select 1;
_index = _table lnbAddRow [_player select 1,_player select 2,nil,if (_player select 0 == 0) then [{format['BANNED: %1',_player select 4]},{_player select 4}]];
if (count _color > 0) then {
lnbSetColor [8,[_index,0],_color];
lnbSetColor [8,[_index,1],_color];
lnbSetColor [8,[_index,3],_color];
};
}forEach "+_skn_pv_hackerLog+";
};
"+_skn_adminLog+" = {
1 call "+_skn_switchMainMenu+";
lbClear (6 call "+_skn_getCtrl+");
_table = 8 call "+_skn_getCtrl+";
lbClear _table;
true spawn "+_skn_switchTable+";
if (call "+_skn_removespawnMenu+") then {uiSleep 0.4;
_table ctrlSetFade 1;
_table ctrlcommit 0;
_table ctrlSetFade 0;
_table ctrlcommit 0.8;
};
_table ctrlShow true;
_table lnbAddRow ['===================================== ADMIN LOG ======================================'];
{_table lnbAddRow _x}forEach "+_skn_pv_adminLog+";
};
"+_skn_flipVehicle+" = {
_target = cursorTarget;
if (isNull _target) then {
_vehicles = player nearEntities[['LandVehicle', 'Ship', 'Air'], 15];
if !(_vehicles isEqualTo []) then {
_target = _vehicles select 0;
};
};
if (!isNull _target) then {
if (!isPlayer _target) then {
_target setVectorUp [0, 0, 1];
cutText [format ['Unflipping Vehicle..'],'PLAIN DOWN'];
};
};
};
"+_skn_infrontTP+" = {
"+_skn_tg_infrontTP+" = !"+_skn_tg_infrontTP+";
if ("+_skn_tg_infrontTP+") then {
if (vehicle player == player) then {
_distance = 10;
_object = vehicle player;
_dir = getdir _object;
_pos = getPosATL _object;
if (_object isKindOf 'Air') then {
_distance = 50;
_pos = [(_pos select 0)+_distance*sin(_dir),(_pos select 1)+_distance*cos(_dir),((getpos _object) select 2)+100];
} else {
_pos = [(_pos select 0)+_distance*sin(_dir),(_pos select 1)+_distance*cos(_dir),0];
if (surfaceIsWater _pos) then {_pos set [2,2]};
};
if (surfaceIsWater _pos) then [{vehicle player setPosASL _pos},{vehicle player setPosATL _pos}];
} else {
cutText ['You can just Teleport Infront when you are not inside of a Vehicle!','PLAIN DOWN'];
};
};
};
"+_skn_customBanreason+" = {
disableSerialization;
_player = objectFromNetId (_this select 1);
_name = name _player;
{(_x call "+_skn_getCtrl+") ctrlShow true}forEach[30,31,32,33,34];
_edit = 31 call "+_skn_getCtrl+";
_edit ctrlSetText '';
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
if ((_this select 2) isEqualType 'STRING') then {
2015-09-17 16:31:04 +00:00
_edit ctrlSetText format['%1',(_this select 2)];
};
_text = 34 call "+_skn_getCtrl+";
_text ctrlSetText format ['Custom Banreason for %1:',_name];
"+_skn_tg_BanPlayer+" = _player;
findDisplay -1337 displayAddEventHandler ['Unload', {"+_skn_tg_BanPlayer+" = objNull}];
_map = 7 call "+_skn_getCtrl+";
_map ctrlSetPosition [0.501031 * safezoneW + safezoneX,0.44456 * safezoneH + safezoneY,0.205265 * safezoneW,0.328148 * safezoneH];
_map ctrlCommit 0.8;
};
"+_skn_doBan+" = {
disableSerialization;
if (_this && !isNull "+_skn_tg_BanPlayer+") then {
_reason = ctrlText 31;
if (_reason == '') then {
ctrlSetText [31, 'Please enter a banreason!'];
} else {
[666,[_reason,netId "+_skn_tg_BanPlayer+"]] call "+_skn_adminRequest_PVC+";
};
};
{_i = _x call "+_skn_getCtrl+";_i ctrlShow false;_i ctrlShow true}forEach[32,33];
"+_skn_tg_BanPlayer+" = objNull;
_map = 7 call "+_skn_getCtrl+";
_map ctrlSetPosition [0.501031 * safezoneW + safezoneX,0.28836 * safezoneH + safezoneY,0.205265 * safezoneW,0.486548 * safezoneH];
_map ctrlCommit 0.8;
};
");
_skn_admininit = compileFinal ("waitUntil {(!isNil '"+_skn_Admin_Code+"') && (!isNil '"+_skn_pv_adminLog+"') && (!isNil '"+_skn_pv_hackerLog+"')};[] spawn "+_skn_Admin_Code+"");
call compile (_skn_Admin_Code+" = _skn_admincode");
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
missionNamespace setVariable [_skn_Admin_Init, _skn_admininit, true];