Merge pull request 'improve inventory check performance and logging' (#10) from #7-inventory-compliance-message into inv_expan

Reviewed-on: https://17th-gs.iceberg-gaming.com:5443/hizumi/MissionTemplate/pulls/10
This commit was merged in pull request #10.
This commit is contained in:
2024-01-29 23:37:07 -06:00
4 changed files with 350 additions and 269 deletions

View File

@@ -39,11 +39,13 @@ addMissionEventHandler ["HandleChatMessage",
["ace_arsenal_displayClosed", {
player remoteExec["milsim_fnc_logPlayerInventory", 0];
private _lines = [player] call milsim_fnc_logPlayerInventory;
["milsim_logText", [_lines]] call CBA_fnc_globalEvent;
}] call CBA_fnc_addEventHandler;
[missionNamespace, "arsenalClosed", {
player remoteExec["milsim_fnc_logPlayerInventory", 0];
private _lines = [player] call milsim_fnc_logPlayerInventory;
["milsim_logText", [_lines]] call CBA_fnc_globalEvent;
}] call BIS_fnc_addScriptedEventHandler;
diag_log text "[MILSIM] (client) event handlers bound";

View File

@@ -1,5 +1,14 @@
if ( !hasInterface ) exitWith {};
if (!isServer) then {
["milsim_logText", {
params [["_strArray", [""], [[]]]];
{
diag_log text _x;
} forEach _strArray;
}] call CBA_fnc_addEventHandler;
};
["InitializePlayer", [player, true]] call BIS_fnc_dynamicGroups;
nil;

View File

@@ -53,7 +53,12 @@ publicVariable "milsim_var_rotaryAssets";
// Initializes the Dynamic Groups framework and groups
["Initialize", [true]] call BIS_fnc_dynamicGroups;
["milsim_logText", {
params [["_strArray", [""], [[]]]];
{
diag_log text _x;
} forEach _strArray;
}] call CBA_fnc_addEventHandler;
missionNamespace setVariable ["milsim_complete", true];
diag_log text "[MILSIM] (initServer) milsim_complete: version 2.3";

View File

@@ -1,26 +1,228 @@
/*
Function: milsim_fnc_logPlayerInventory
Description:
Checks a player's inventory for non-compliant items and logs results to all machines.
Author: Hizumi, EagleTrooper, IndigoFox
Parameters:
0: _player - <OBJECT> - Player to check inventory of.
Returns:
<ARRAY> - Array of strings to be logged.
*/
params [
["_player", objNull, [objNull]]
];
if (!isPlayer _player) exitWith { diag_log("exitWith logPlayerInventory")};
if (!isPlayer _player) exitWith {
["[MILSIM] (logPlayerInventory): ERROR :: _player is not a player"]
};
_items = [];
_ietms pushback headgear _player;
_items pushback uniform _player;
_items append uniformItems _player;
_items pushback vest _player;
_items append vestItems _player;
_items pushback backpack _player;
_items append backpackItems _player;
_items pushback hmd _player;
_items pushback binocular _player;
_items pushback primaryWeapon _player;
_items append primaryWeaponItems _player;
_items pushback secondaryWeapon _player;
_items append secondaryWeaponItems _player;
// DEFINITIONS
_blackListItems = [ // Items that NO member is allowed to use.
"17BN_ANPVS14", // NVG AN/PVS-14
"USP_PVS_14", // NVG AN/PVS-14
"USP_PVS_15", // NVG AN/PVS-15
"rhsusf_ANPVS_14", // NVG AN/PVS-14
"ej_VPS15", // NVG AN/PVS-15
"rhsusf_ANPVS_15", // NVG AN/PVS-15
"ej_PVS15D", // NVG AN/PVS-15
"UK3CB_M16_Carbine", // M16 Series
"UK3CB_M16A1", // M16 Series
"UK3CB_M16A1_LSW", // M16 Series
"UK3CB_M16A2", // M16 Series
"UK3CB_M16A2_UGL", // M16 Series
"UK3CB_M16A3", // M16 Series
"rhs_weap_m16a4", // M16 Series
"rhs_weap_m16a4_carryhandle", // M16 Series
"rhs_weap_m16a4_carryhandle_M203", // M16 Series
"rhs_weap_m16a4_imod", // M16 Series
"rhs_weap_m16a4_imod_M203", // M16 Series
"rhs_weap_m27iar", // M27 Series
"rhs_weap_m27iar_grip", // M27 Series
"UK3CB_G36_MLIC", // G36 Series
"UK3CB_G36_MLIC_K", // G36 Series
"UK3CB_G36_MLIC_C", // G36 Series
"UK3CB_G36_KSK_K", // G36 Series
"UK3CB_G36_KSK", // G36 Series
"UK3CB_G36A1", // G36 Series
"UK3CB_AG36A1", // G36 Series
"UK3CB_G36A1_K", // G36 Series
"UK3CB_G36A1_C", // G36 Series
"UK3CB_G36E1", // G36 Series
"UK3CB_AG36E1", // G36 Series
"UK3CB_G36E1_K", // G36 Series
"UK3CB_G36E1_C", // G36 Series
"UK3CB_AG36_MLIC", // G36 Series
"UK3CB_G36V", // G36 Series
"UK3CB_AG36V", // G36 Series
"UK3CB_G36_TAC", // G36 Series
"UK3CB_G36V_K", // G36 Series
"UK3CB_AG36_TAC_K", // G36 Series
"UK3CB_G36V_C", // G36 Series
"UK3CB_G36_TAC_C", // G36 Series
"UK3CB_G36_LSW", // G36 Series
"rhs_weap_g36kv", // G36 Series
"rhs_weap_g36kv_ag36", // G36 Series
"rhs_weap_g36c", // G36 Series
"Tier1_SIG_CMX_115_Virtus_300BLK", // MCX 300 Blackout
"Tier1_SIG_CMX_115_Virtus_300BLK_Black", // MCX 300 Blackout
"Tier1_SIG_CMX_115_Virtus_300BLK_Desert", // MCX 300 Blackout
"Tier1_SIG_CMX_115_Virtus_300BLK_FDE", // MCX 300 Blackout
"UK3CB_M14", // M14 Series
"UK3CB_M14_Railed", // M14 Series
"UK3CB_M14DMR", // M14 Series
"UK3CB_M14DMR_BLK", // M14 Series
"UK3CB_M14DMR_Railed", // M14 Series
"UK3CB_M14DMR_Railed_BLK", // M14 Series
"srifle_DMR_06_hunter_F", // M14 Series
"srifle_DMR_06_camo_F", // M14 Series
"srifle_DMR_06_olive_F", // M14 Series
"rhs_weap_m14", // M14 Series
"rhs_weap_m14_d", // M14 Series
"rhs_weap_m14_fiberglass", // M14 Series
"rhs_weap_m14_rail", // M14 Series
"rhs_weap_m14_rail_d", // M14 Series
"rhs_weap_m14_rail_fiberglass", // M14 Series
"rhs_weap_m14_rail_wd", // M14 Series
"rhs_weap_m14_ris", // M14 Series
"rhs_weap_m14_ris_d", // M14 Series
"rhs_weap_m14_ris_fiberglass", // M14 Series
"rhs_weap_m14_ris_wd", // M14 Series
"rhs_weap_m14_wd", // M14 Series
"rhs_weap_m14_weap_m14ebrri", // M14 Series
"rhs_weap_m14_socom", // M14 Series
"rhs_weap_m14_socom_rail", // M14 Series
"srifle_EBR_F", // Mk14 Series
"UK3CB_FNFAL_OSW", // FN_FAL Series
"UK3CB_FNFAL_OSW_GL", // FN_FAL Series
"UK3CB_FNFAL_FULL", // FN_FAL Series
"UK3CB_FNFAL_FULL_RAILS", // FN_FAL Series
"UK3CB_FNFAL_FOREGRIP", // FN_FAL Series
"UK3CB_FNFAL_PARA", // FN_FAL Series
"UK3CB_FNFAL_PARA_RAILS", // FN_FAL Series
"UK3CB_FNFAL_STG58", // FN_FAL Series
"SMA_ACRREM", //Remington ACR 556+6.5
"SMA_ACRREMAFGCQB", //Remington ACR 556+6.5
"SMA_ACRREMAFG", //Remington ACR 556+6.5
"SMA_ACRREMMOECQB", //Remington ACR 556+6.5
"SMA_ACRREMMOE", //Remington ACR 556+6.5
"SMA_ACRREMblk", //Remington ACR 556+6.5
"SMA_ACRREMAFGCQBblk", //Remington ACR 556+6.5
"SMA_ACRREMAFGblk", //Remington ACR 556+6.5
"SMA_ACRREMMOECQBblk", //Remington ACR 556+6.5
"SMA_ACRREMMOEblk", //Remington ACR 556+6.5
"SMA_ACRREMGL_B", //Remington ACR 556+6.5
"SMA_ACRREMCQBGL", //Remington ACR 556+6.5
"SMA_ACRREMGL", //Remington ACR 556+6.5
"LMG_Mk200_F", //Mk200 Series
"LMG_Mk200_black_F" //Mk200 Series
];
_restrictedItems = [ // Items that are allowed for Specific USE Case (RRC / Marksman / etc.)
"A3_GPNVG18b_REC_TI", // Thermal Quad
"A3_GPNVG18_REC_TI", // Thermal Quad
"A3_GPNVG18b_TI", // Thermal Quad
"A3_GPNVG18_TI", // Thermal Quad
"A3_GPNVG18b_REC_BLK_TI", // Thermal Quad
"A3_GPNVG18_REC_BLK_TI", // Thermal Quad
"A3_GPNVG18b_BLK_TI", // Thermal Quad
"A3_GPNVG18_BLK_TI", // Thermal Quad
"NVGogglesB_gry_F", // ENVG
"NVGogglesB_grn_F", // ENVG
"NVGogglesB_blk_F", // ENVG
"optic_Nightstalker", // Thermal Optic
"rhsusf_acc_anpas13gv1", // Thermal Optic
"Tier1_ANPVS10_Tan", // Thermal Optic
"rhsusf_acc_anpvs27", // Thermal Optic
"optic_tws_mg", // Thermal Optic
"optic_tws", // Thermal Optic
"Tier1_ATACR18_ADM_Black", //Nightforce Series Optic
"Tier1_ATACR18_ADM_Desert", //Nightforce Series Optic
"Tier1_ATACR18_ADM_Desert_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_ADM_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Black", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Desert", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Desert_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Black", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Desert", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Desert_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Black", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Desert", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Desert_Vanilla", //Nightforce Series Optic
"optic_lrps", //Nightforce Series Optic
"optic_lrps_ghex_F", //Nightforce Series Optic
"optic_lrps_tna_F", //Nightforce Series Optic
"ACE_optic_LRPS_2D", //Nightforce Series Optic
"ACE_optic_LRPS_PIP" //Nightforce Series Optic
];
_tabbedItems = [ // Items that are allowed for individuals with Ranger Tab
"arifle_SPAR_03_snd_F", // HK417 Series
"arifle_SPAR_03_blk_F", // HK417 Series
"arifle_SPAR_03_khk_F", // HK417 Series
"SMA_HK417", // HK417 Series
"SMA_HK417vfg", // HK417 Series
"SMA_HK417_16in", // HK417 Series
"rhs_weap_SCARH_CQC", // Scar H Series
"rhs_weap_SCARH_FDE_CQC", // Scar H Series
"rhs_weap_SCARH_FDE_LB", // Scar H Series
"rhs_weap_SCARH_LB", // Scar H Series
"rhs_weap_SCARH_FDE_STD", // Scar H Series
"rhs_weap_SCARH_STD", // Scar H Series
"rhs_weap_SCARH_USA_CQC", // Scar H Series
"rhs_weap_SCARH_USA_LB", // Scar H Series
"rhs_weap_SCARH_USA_STD", // Scar H Series
"SMA_Mk17", // Scar H Series
"SMA_Mk17_black", // Scar H Series
"SMA_Mk17_green", // Scar H Series
"SMA_Mk17_EGML", // Scar H Series
"SMA_Mk17_EGML_black", // Scar H Series
"SMA_Mk17_EGML_green", // Scar H Series
"SMA_Mk17_16", // Scar H Series
"SMA_Mk17_16_black", // Scar H Series
"SMA_Mk17_16_green", // Scar H Series
"Tier1_SR25", // SR-25 Series
"Tier1_SR25_tan", // SR-25 Series
"Tier1_SR25_ec", // SR-25 Series
"Tier1_SR25_ec_tan", // SR-25 Series
"arifle_MXC_F", // MXC Series
"arifle_MXC_black_F", // MXC Series
"arifle_MXC_khk_F", // MXC Series
"arifle_MXM_F", // MXM Series
"arifle_MXM_black_F", // MXM Series
"arifle_MXM_khk_F", // MXM Series
"arifle_MX_F", // MX Series
"arifle_MX_black_F", // MX Series
"arifle_MX_khk_F", // MX Series
"arifle_MX_GL_F", // MX 3GL Series
"arifle_MX_GL_black_F", // MX 3GL Series
"arifle_MX_GL_khk_F", // MX 3GL Series
"arifle_MX_SW_F", // MX LSW Series
"arifle_MX_SW_black_F", // MX LSW Series
"arifle_MX_SW_khk_F", // MX LSW Series
"Tier1_MK48_Mod0", // Mk48 Series
"Tier1_MK48_Mod0_Desert", // Mk48 Series
"Tier1_MK48_Mod0_Para", // Mk48 Series
"Tier1_MK48_Mod0_Para_Desert", // Mk48 Series
"Tier1_MK48_Mod1", // Mk48 Series
"Tier1_MK48_Mod1_Desert" // Mk48 Series
];
_memeItems = [ // Items that serve no purpose other than to MEME
"UK3CB_Cocaine_Brick",
"ACE_Banana"
];
// INSTANTIATE VARS
private _returnLines = [];
_unlisted = [];
@@ -29,273 +231,136 @@ _blacklist = [];
_tabbed = [];
_meme = [];
diag_log text format["[MILSIM] (logPlayerInventory): Checking %1 inventory.", name _player];
private _nonCompliantItemsCount = 0;
// PRIVATE FUNCTIONS
private _logItem = {
params ["_playerObj", "_categoryText", "_itemClassName"];
private _cfg = _itemClassName call CBA_fnc_getItemConfig;
_returnLines pushBack (format[
"[MILSIM] (logPlayerInventory): %1 :: className=""%2"" displayName=""%3"" %4",
_categoryText,
_itemClassName,
[_cfg] call BIS_fnc_displayName,
[_playerObj] call _playerInfoString
]);
};
private _playerInfoString = {
params ["_playerObj"];
format["playerName=""%1"" playerUID=""%2"" playerGroup=""%3""", name _playerObj, getPlayerUID _playerObj, groupId (group _playerObj)];
};
// GATHER INVENTORY
// _items = [];
// _items pushback headgear _player;
// _items pushback uniform _player;
// _items append uniformItems _player;
// _items pushback vest _player;
// _items append vestItems _player;
// _items pushback backpack _player;
// _items append backpackItems _player;
// _items pushback hmd _player;
// _items pushback binocular _player;
// _items pushback primaryWeapon _player;
// _items append primaryWeaponItems _player;
// _items pushback secondaryWeapon _player;
// _items append secondaryWeaponItems _player;
_items = [
_player, // Unit
true, // Include weapons, attachments, loaded magazines
true, // Include items in backpack
true, // Include items in vest
true, // Include items in uniform
true, // Include assigned items
true // Include not loaded magazines
] call CBA_fnc_uniqueUnitItems;
_items pushBack (headgear _player);
_items pushBack (uniform _player);
// CHECK INVENTORY
_returnLines pushBack (format[
"[MILSIM] (logPlayerInventory): CHECKING :: %1",
[_player] call _playerInfoString
]);
{
_item = _x;
_modes = getArray(configfile >> "CfgWeapons" >> _item >> "visionMode");
_blackListItems = [ // Items that NO member is allowed to use.
"17BN_ANPVS14", // NVG AN/PVS-14
"USP_PVS_14", // NVG AN/PVS-14
"USP_PVS_15", // NVG AN/PVS-15
"rhsusf_ANPVS_14", // NVG AN/PVS-14
"ej_VPS15", // NVG AN/PVS-15
"rhsusf_ANPVS_15", // NVG AN/PVS-15
"ej_PVS15D", // NVG AN/PVS-15
"UK3CB_M16_Carbine", // M16 Series
"UK3CB_M16A1", // M16 Series
"UK3CB_M16A1_LSW", // M16 Series
"UK3CB_M16A2", // M16 Series
"UK3CB_M16A2_UGL", // M16 Series
"UK3CB_M16A3", // M16 Series
"rhs_weap_m16a4", // M16 Series
"rhs_weap_m16a4_carryhandle", // M16 Series
"rhs_weap_m16a4_carryhandle_M203", // M16 Series
"rhs_weap_m16a4_imod", // M16 Series
"rhs_weap_m16a4_imod_M203", // M16 Series
"rhs_weap_m27iar", // M27 Series
"rhs_weap_m27iar_grip", // M27 Series
"UK3CB_G36_MLIC", // G36 Series
"UK3CB_G36_MLIC_K", // G36 Series
"UK3CB_G36_MLIC_C", // G36 Series
"UK3CB_G36_KSK_K", // G36 Series
"UK3CB_G36_KSK", // G36 Series
"UK3CB_G36A1", // G36 Series
"UK3CB_AG36A1", // G36 Series
"UK3CB_G36A1_K", // G36 Series
"UK3CB_G36A1_C", // G36 Series
"UK3CB_G36E1", // G36 Series
"UK3CB_AG36E1", // G36 Series
"UK3CB_G36E1_K", // G36 Series
"UK3CB_G36E1_C", // G36 Series
"UK3CB_AG36_MLIC", // G36 Series
"UK3CB_G36V", // G36 Series
"UK3CB_AG36V", // G36 Series
"UK3CB_G36_TAC", // G36 Series
"UK3CB_G36V_K", // G36 Series
"UK3CB_AG36_TAC_K", // G36 Series
"UK3CB_G36V_C", // G36 Series
"UK3CB_G36_TAC_C", // G36 Series
"UK3CB_G36_LSW", // G36 Series
"rhs_weap_g36kv", // G36 Series
"rhs_weap_g36kv_ag36", // G36 Series
"rhs_weap_g36c", // G36 Series
"Tier1_SIG_CMX_115_Virtus_300BLK", // MCX 300 Blackout
"Tier1_SIG_CMX_115_Virtus_300BLK_Black", // MCX 300 Blackout
"Tier1_SIG_CMX_115_Virtus_300BLK_Desert", // MCX 300 Blackout
"Tier1_SIG_CMX_115_Virtus_300BLK_FDE", // MCX 300 Blackout
"UK3CB_M14", // M14 Series
"UK3CB_M14_Railed", // M14 Series
"UK3CB_M14DMR", // M14 Series
"UK3CB_M14DMR_BLK", // M14 Series
"UK3CB_M14DMR_Railed", // M14 Series
"UK3CB_M14DMR_Railed_BLK", // M14 Series
"srifle_DMR_06_hunter_F", // M14 Series
"srifle_DMR_06_camo_F", // M14 Series
"srifle_DMR_06_olive_F", // M14 Series
"rhs_weap_m14", // M14 Series
"rhs_weap_m14_d", // M14 Series
"rhs_weap_m14_fiberglass", // M14 Series
"rhs_weap_m14_rail", // M14 Series
"rhs_weap_m14_rail_d", // M14 Series
"rhs_weap_m14_rail_fiberglass", // M14 Series
"rhs_weap_m14_rail_wd", // M14 Series
"rhs_weap_m14_ris", // M14 Series
"rhs_weap_m14_ris_d", // M14 Series
"rhs_weap_m14_ris_fiberglass", // M14 Series
"rhs_weap_m14_ris_wd", // M14 Series
"rhs_weap_m14_wd", // M14 Series
"rhs_weap_m14_weap_m14ebrri", // M14 Series
"rhs_weap_m14_socom", // M14 Series
"rhs_weap_m14_socom_rail", // M14 Series
"srifle_EBR_F", // Mk14 Series
"UK3CB_FNFAL_OSW", // FN_FAL Series
"UK3CB_FNFAL_OSW_GL", // FN_FAL Series
"UK3CB_FNFAL_FULL", // FN_FAL Series
"UK3CB_FNFAL_FULL_RAILS", // FN_FAL Series
"UK3CB_FNFAL_FOREGRIP", // FN_FAL Series
"UK3CB_FNFAL_PARA", // FN_FAL Series
"UK3CB_FNFAL_PARA_RAILS", // FN_FAL Series
"UK3CB_FNFAL_STG58", // FN_FAL Series
"SMA_ACRREM", //Remington ACR 556+6.5
"SMA_ACRREMAFGCQB", //Remington ACR 556+6.5
"SMA_ACRREMAFG", //Remington ACR 556+6.5
"SMA_ACRREMMOECQB", //Remington ACR 556+6.5
"SMA_ACRREMMOE", //Remington ACR 556+6.5
"SMA_ACRREMblk", //Remington ACR 556+6.5
"SMA_ACRREMAFGCQBblk", //Remington ACR 556+6.5
"SMA_ACRREMAFGblk", //Remington ACR 556+6.5
"SMA_ACRREMMOECQBblk", //Remington ACR 556+6.5
"SMA_ACRREMMOEblk", //Remington ACR 556+6.5
"SMA_ACRREMGL_B", //Remington ACR 556+6.5
"SMA_ACRREMCQBGL", //Remington ACR 556+6.5
"SMA_ACRREMGL", //Remington ACR 556+6.5
"LMG_Mk200_F", //Mk200 Series
"LMG_Mk200_black_F" //Mk200 Series
]
_subModes = [configfile >> "CfgWeapons" >> _item >> "ItemInfo" >> "OpticsModes", 1] call BIS_fnc_returnChildren;
_restrictedItems = [ // Items that are allowed for Specific USE Case (RRC / Marksman / etc.)
"A3_GPNVG18b_REC_TI", // Thermal Quad
"A3_GPNVG18_REC_TI", // Thermal Quad
"A3_GPNVG18b_TI", // Thermal Quad
"A3_GPNVG18_TI", // Thermal Quad
"A3_GPNVG18b_REC_BLK_TI", // Thermal Quad
"A3_GPNVG18_REC_BLK_TI", // Thermal Quad
"A3_GPNVG18b_BLK_TI", // Thermal Quad
"A3_GPNVG18_BLK_TI", // Thermal Quad
"NVGogglesB_gry_F", // ENVG
"NVGogglesB_grn_F", // ENVG
"NVGogglesB_blk_F", // ENVG
"optic_Nightstalker", // Thermal Optic
"rhsusf_acc_anpas13gv1", // Thermal Optic
"Tier1_ANPVS10_Tan", // Thermal Optic
"rhsusf_acc_anpvs27", // Thermal Optic
"optic_tws_mg", // Thermal Optic
"optic_tws", // Thermal Optic
"Tier1_ATACR18_ADM_Black", //Nightforce Series Optic
"Tier1_ATACR18_ADM_Desert", //Nightforce Series Optic
"Tier1_ATACR18_ADM_Desert_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_ADM_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Black", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Desert", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_ADM_T1_Desert_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Black", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Desert", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Desert_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Black", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Desert", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Black_Vanilla", //Nightforce Series Optic
"Tier1_ATACR18_Geissele_Docter_Desert_Vanilla", //Nightforce Series Optic
"optic_lrps", //Nightforce Series Optic
"optic_lrps_ghex_F", //Nightforce Series Optic
"optic_lrps_tna_F", //Nightforce Series Optic
"ACE_optic_LRPS_2D", //Nightforce Series Optic
"ACE_optic_LRPS_PIP" //Nightforce Series Optic
];
_tabbedItems = [ // Items that are allowed for individuals with Ranger Tab
"arifle_SPAR_03_snd_F", // HK417 Series
"arifle_SPAR_03_blk_F", // HK417 Series
"arifle_SPAR_03_khk_F", // HK417 Series
"SMA_HK417", // HK417 Series
"SMA_HK417vfg", // HK417 Series
"SMA_HK417_16in", // HK417 Series
"rhs_weap_SCARH_CQC", // Scar H Series
"rhs_weap_SCARH_FDE_CQC", // Scar H Series
"rhs_weap_SCARH_FDE_LB", // Scar H Series
"rhs_weap_SCARH_LB", // Scar H Series
"rhs_weap_SCARH_FDE_STD", // Scar H Series
"rhs_weap_SCARH_STD", // Scar H Series
"rhs_weap_SCARH_USA_CQC", // Scar H Series
"rhs_weap_SCARH_USA_LB", // Scar H Series
"rhs_weap_SCARH_USA_STD", // Scar H Series
"SMA_Mk17", // Scar H Series
"SMA_Mk17_black", // Scar H Series
"SMA_Mk17_green", // Scar H Series
"SMA_Mk17_EGML", // Scar H Series
"SMA_Mk17_EGML_black", // Scar H Series
"SMA_Mk17_EGML_green", // Scar H Series
"SMA_Mk17_16", // Scar H Series
"SMA_Mk17_16_black", // Scar H Series
"SMA_Mk17_16_green", // Scar H Series
"Tier1_SR25", // SR-25 Series
"Tier1_SR25_tan", // SR-25 Series
"Tier1_SR25_ec", // SR-25 Series
"Tier1_SR25_ec_tan", // SR-25 Series
"arifle_MXC_F", // MXC Series
"arifle_MXC_black_F", // MXC Series
"arifle_MXC_khk_F", // MXC Series
"arifle_MXM_F", // MXM Series
"arifle_MXM_black_F", // MXM Series
"arifle_MXM_khk_F", // MXM Series
"arifle_MX_F", // MX Series
"arifle_MX_black_F", // MX Series
"arifle_MX_khk_F", // MX Series
"arifle_MX_GL_F", // MX 3GL Series
"arifle_MX_GL_black_F", // MX 3GL Series
"arifle_MX_GL_khk_F", // MX 3GL Series
"arifle_MX_SW_F", // MX LSW Series
"arifle_MX_SW_black_F", // MX LSW Series
"arifle_MX_SW_khk_F", // MX LSW Series
"Tier1_MK48_Mod0", // Mk48 Series
"Tier1_MK48_Mod0_Desert", // Mk48 Series
"Tier1_MK48_Mod0_Para", // Mk48 Series
"Tier1_MK48_Mod0_Para_Desert", // Mk48 Series
"Tier1_MK48_Mod1", // Mk48 Series
"Tier1_MK48_Mod1_Desert" // Mk48 Series
]
_memeItems = [ // Items that serve no purpose other than to MEME
"UK3CB_Cocaine_Brick",
"ACE_Banana"
]
{
_modes append getArray( _x >> "visionMode" );
} forEach _subModes;
if ( _item in _blackListItems ) then {
_blacklist pushBackUnique _item;
};
if ( _item in _restrictedItems ) then {
_restricted pushBackUnique _item;
};
if ( _item in _tabbedItems ) then {
_tabbed pushBackUnique _item;
};
if ( _item in _memeItems ) then {
_meme pushBackUnique _item;
};
_item = _x;
_modes = getArray(configfile >> "CfgWeapons" >> _item >> "visionMode");
_subModes = [configfile >> "CfgWeapons" >> _item >> "ItemInfo" >> "OpticsModes", 1] call BIS_fnc_returnChildren;
{
_modes append getArray( _x >> "visionMode" );
} forEach _subModes;
if ( _item in _blackListItems ) then {
_blacklist pushBackUnique _item;
};
if ( _item in _restrictedItems ) then {
_restrcited pushBackUnique _item;
};
if ( _item in _tabbedItems ) then {
_tabbed pushBackUnique _item;
};
if ( _item in _memeItems ) then {
_meme pushBackUnique _item;
};
if ((count _modes) isNotEqualTo 0) then {
_modes = _modes apply { toLower _x };
if ( "ti" in _modes ) then {
_unlisted pushBackUnique _item;
};
};
if ((count _modes) isNotEqualTo 0) then {
_modes = _modes apply { toLower _x };
if ( "ti" in _modes ) then {
_unlisted pushBackUnique _item;
};
};
} forEach _items;
{
diag_log text format["[MILSIM] (logPlayerInventory): %1 has a blacklisted inventory item: %2", name _player, getText( configfile >> "CfgWeapons" >> _x >> "displayName" )];
} forEach _blacklist;
{
diag_log text format["[MILSIM] (logPlayerInventory): %1 has a restricted inventory item: %2", name _player, getText( configfile >> "CfgWeapons" >> _x >> "displayName" )];
} forEach _restrcited;
{
diag_log text format["[MILSIM] (logPlayerInventory): %1 has a tabbed inventory item: %2", name _player, getText( configfile >> "CfgWeapons" >> _x >> "displayName" )];
} forEach _tabbed;
{
diag_log text format["[MILSIM] (logPlayerInventory): %1 has a meme inventory item: %2", name _player, getText( configfile >> "CfgWeapons" >> _x >> "displayName" )];
} forEach _meme;
{
_nonCompliantItemsCount = _nonCompliantItemsCount + 1;
[_player, "BLACKLISTED", _x] call _logItem;
} forEach _blacklist;
{
diag_log text format["[MILSIM] (logPlayerInventory): %1 has an unlisted thermal item: %2", name _player, getText( configfile >> "CfgWeapons" >> _x >> "displayName" )];
} forEach _unlisted;
{
_nonCompliantItemsCount = _nonCompliantItemsCount + 1;
[_player, "RESTRICTED", _x] call _logItem;
} forEach _restricted;
if (((count _blacklist) isEqualTo 0) && ((count _restrcited) isEqualTo 0) && ((count _tabbed) isEqualTo 0) && ((count _meme) isEqualTo 0) && ((count _unlisted) isEqualTo 0)) then {
diag_log text format["[MILSIM] (logPlayerInventory): %1 inventory in fully base inventory compliant.", name _player];
}
{
_nonCompliantItemsCount = _nonCompliantItemsCount + 1;
[_player, "TABBED", _x] call _logItem;
} forEach _tabbed;
nil
{
_nonCompliantItemsCount = _nonCompliantItemsCount + 1;
[_player, "MEME", _x] call _logItem;
} forEach _meme;
{
if (
_x in _blackListItems ||
_x in _restrictedItems
) then {continue}; // Skip items that are already checked
_nonCompliantItemsCount = _nonCompliantItemsCount + 1;
[_player, "UNLISTED THERMAL", _x] call _logItem;
} forEach _unlisted;
if (_nonCompliantItemsCount isEqualTo 0) then {
_returnLines pushBack (format[
"[MILSIM] (logPlayerInventory): COMPLIANT :: %1",
[_player] call _playerInfoString
]);
};
// returns array of strings
_returnLines;