Jump to content
Search In
  • More options...
Find results that contain...
Find results in...
  • Need help?

    Create a topic in the appropriate section
    Don't write everything in the chat!
  • Take a look at the marketplace

    There you can buy
    everything related to game servers
  • Don't want a ban?

    Please read our rules
    Don't disturb the order!
  • Sell or buy?

    Use services of the guarantor
    We will make your deal safe
DrTauren

[Single Currency & Banking v1.1] - Единая система банков

Recommended Posts

Собственно это способ изменить систему валюты в DayZ Epoch. Наверняка многие знают скрипт от Maca с банками, монетами и прочим. В принципе это тоже самое, только от другого автора, некоего Zupa (тоже, между прочим, известный парень на форуме Эпохи).


P.S. лично я не проверял скрипт, только перевёл, но всё должно работать.
P.S.S. Данный скрипт устарел. Лучше использовать гайды на версии 2.0 и 3.0  :good: 
 

Что нам понадобится:

Архив

fn_selfActions (на случай если банки не работают при установленном скрипте на самозалив крови и т.д.) - спасибо пользователю  Alex39

 

 

Надо сказать что автор скрипта "красаучик внатури"  :kiss:, т.к. о всех позаботился и сделал 2 вида репок:

  • Готовые файлы миссии и pbo - это для тех, кто ставит "банки" на пустой сервер Epoch. (папка метода А в архиве)
  • Файлы для изменения файлов и добавления "банков" на вашу сборку сервера Epoch. (папка метода В в архиве)

Пожалуйста, Войдите или Зарегистрируйтесь, чтобы увидеть это: Вложение.


 

Способ 1

Метод "папки А"
1) Заходим в папку A.Installation_Method_#1_Add_to_a_new_Epoch_server_quickly

2) Содержимое папки A.Pack_these_into_______dayz_server.pbo (папка dayz_server) закидываем в папку @DayZ_EPOCH_SERVER и запаковываем в формат .pbo предварительно удалив стандартный .pbo файл

3) Содержимым папки B.Mission_File (папка DayZ_Epoch_11.Chernarus) заменяем стандартную папку с миссией
4) Выполнить пункты 15 и 16 из способа 2

 

Способ 2
Метод "папки В"

1) Делаем кастомные variables.sqf, compiles.sqf и изменяем пути к ним в init.sqf так (ясен-красен вам и сами файлы надо расположить соответственно этим путям):

call compile preprocessFileLineNumbers "init\variables.sqf";
call compile preprocessFileLineNumbers "init\compiles.sqf";

2) Делаем кастомный fn_selfactions.sqf и изменяем путь к нему в нашем новом кастомном compiles.sqf на этот:

fnc_usec_selfActions =    compile preprocessFileLineNumbers "compile\fn_selfActions.sqf";

3) Так же в нашем новом кастомном compiles.sqf меняем путь параметра call compile preprocessFileLineNumbers так, что бы всё выглядело как тут:

call compile preprocessFileLineNumbers "gold\player_traderMenu.sqf";
initialized = true;

4) В compiles.sqf заменяем строку с параметром player_wearClothes на это:

player_wearClothes =        compile preprocessFileLineNumbers "compile\player_wearClothes.sqf";

5) В description.ext в самый вех добавляем это:

#include "CfgServerTrader\cfgServerTrader.hpp"

6) В этом же файле ищем эти строки:

aiKills = 1;
diagRadio = 1;
diagHit = 1;

и после них добавляем это:

#include "addons\playerhud\commonhud.hpp"
#include "hw.hpp"

И в самый низ этого же файла добавляем эти строки:

class RscTitles
{
#include "addons\playerhud\hud.hpp"
};

#include "defines.hpp"
#include "gold\common.hpp"
#include "gold\bank_dialog.hpp"
#include "gold\give_player_dialog.hpp"

7) В самый верх variables.sqf добавляем строки что бы выглядело примерно так:

disableSerialization;

DZE_ATM = ["Laptop_EP1"];

где Laptop_EP1 - класснейм объекта у которого можно торговать

8) В init.sqf после этих строк:

//Load in compiled functions
call compile preprocessFileLineNumbers "init\variables.sqf";                //Initilize the Variables (IMPORTANT: Must happen very early)
progressLoadingScreen 0.1;
call compile preprocessFileLineNumbers "\z\addons\dayz_code\init\publicEH.sqf";                //Initilize the publicVariable event handlers
progressLoadingScreen 0.2;
call compile preprocessFileLineNumbers "\z\addons\dayz_code\medical\setup_functions_med.sqf";    //Functions used by CLIENT for medical
progressLoadingScreen 0.4;
call compile preprocessFileLineNumbers "init\compiles.sqf";                //Compile regular functions
progressLoadingScreen 0.5;
call compile preprocessFileLineNumbers "server_traders.sqf";                //Compile trader configs
progressLoadingScreen 1.0;

добавляем эти: 

DZE_ConfigTrader = true;
DZE_AsReMix_PLAYER_HUD = true; //Open Custom     AsReMix Player HUD

а в самом конце init.sqf добавляем это:

execVM "gold\init.sqf";
execVM "gold\addbankmarkers.sqf";

теперь всё в том же init.sqf ищем эту строку:

if (!isDedicated) then {

и под ней добавляем это:

if (DZE_AsReMix_PLAYER_HUD) then {
execVM "addons\playerhud\playerHud.sqf"//AsReMix Player HUD
};

9) В файле fn_selfactions.sqf под этими строками:

player removeAction s_player_fuelauto;
    s_player_fuelauto = -1;
    player removeAction s_player_fuelauto2;
    s_player_fuelauto2 = -1;

добавляем эти:

player removeAction s_givemoney_dialog;
    s_givemoney_dialog = -1;
    player removeAction s_bank_dialog;
    s_bank_dialog = -1;
    player removeAction s_bank_dialog2;
    s_bank_dialog2 = -1;

а так же ищем строку //Allow owner to pack vault и добавляем перед ней:

//banking FROM HERE

    if(_typeOfCursorTarget in DZE_UnLockedStorage and (player distance _cursorTarget < 3)) then {
        if (s_bank_dialog < 0) then {
                s_bank_dialog = player addAction ["Online Banking", "gold\bank_dialog.sqf",_cursorTarget, 3, true, true, "", ""];
        };
    } else {
    player removeAction s_bank_dialog;
        s_bank_dialog = -1;
    };

    // banking atm

    if(_typeOfCursorTarget in DZE_ATM and (player distance _cursorTarget < 3)) then {
        if (s_bank_dialog2 < 0) then {
            s_bank_dialog2 = player addAction ["Bank ATM", "gold\bank_dialog.sqf",_cursorTarget, 3, true, true, "", ""];
        };
    } else {
        player removeAction s_bank_dialog2;
        s_bank_dialog2 = -1;
    };

// TO HERE
 

10) В этом же файле ищем строку // Study Body и заменяем весь блок на это:

// Study Body
    if (_player_studybody) then {
        if (s_player_studybody < 0) then {
         // --------ZUPA - Check Wallet --------
                s_player_studybody = player addAction [("<t color=""#FF0000"">"+("Check Wallet") + "</t>"), "gold\check_wallet.sqf",_cursorTarget, 0, false, true, "",""];
            // ---- ZUPA END ---
        };
    } else {
        player removeAction s_player_studybody;
        s_player_studybody = -1;
    };

11) Перед этой строкой: //Fuel Pump добавляем это:

if (_isMan and _isAlive and !_isZombie and !_isAnimal and !(_traderType in serverTraders)) then {
if (s_givemoney_dialog < 0) then {
s_givemoney_dialog = player addAction [format["Give Money to %1", (name _cursorTarget)], "gold\give_player_dialog.sqf",_cursorTarget, 3, true, true, "", ""];
};
} else {
player removeAction s_givemoney_dialog;
s_givemoney_dialog = -1;
};

P.S. Лимит счёта можно изменить в конфиге. По дефолту лимита нет.
12) Копируем файл player_setup.sqf и player_sync.sqf из папки dayz_server (использовать файлы "метода А") в вашу папку compile что в dayz_server.pbo

13) таким же методом копируем себе папку bankzones

14) в файле server_functions.sqf под строкой server_maintainArea добавить это:

execVM "\z\addons\dayz_server\bankzones\banks.sqf";

15) Файлы из папки Z.Both_methods_need_these_DLLs\Root Dll закинуть с заменой в корневую папку Армы
16) Файлы из папки Z.Both_methods_need_these_DLLs\ServerDll закинуть с заменой в папку @DayZ_EPOCH

 


:happy: Ребят, писал и переводил всё это поздно ночью, так что надеюсь на ваше понимание  :happy: 
Ниже находятся всякие полезности для этого скрипта, что я откопал на зарубежных сайтах. Гляньте, пригодится  :yes:

Share this post


Link to post
Share on other sites



Добавление ботам DZMS новой валюты в инвентарь:
Ссылка на гайд

Сейфзоны для банков:

 


Если вам нужны таковые, то измените раздел Sensors в вашем mission.sqm на эти:

class Item8
        {
            position[]={6772.35,0.103,2494.58};
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank1";
            expCond="(player distance zonebank1) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };

        class Item9
        {
            position[]={10005.678, 0.61099607,1861.6836, };
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank2";
            expCond="(player distance zonebank2) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };

        class Item10
        {
            position[]={12214.157, 0.61100769,9731.7646 };
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank3";
            expCond="(player distance zonebank3) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };
        class Item11
        {
            position[]={13343.663, 0.61099243,5488.4917 };
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank4";
            expCond="(player distance zonebank4) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };
        class Item12
        {
            position[]={1008.7841, 0.60786343,2218.9775 };
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank5";
            expCond="(player distance zonebank5) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };

            class Item13
        {
            position[]={8666.5801, 0.73773193,6517.2212};
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank6";
            expCond="(player distance zonebank6) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };

        class Item14
        {
            position[]={3649.0173, 0.73773193,8532.2158};
            activationBy="WEST";
            repeating=1;
            interruptable=1;
            age="UNKNOWN";
            name="zonebank25";
            expCond="(player distance zonebank25) < 15;";
            expActiv="TitleText[""Now entering Banking area"",""PLAIN DOWN""]; canbuild = false;insafezone = true;";
            expDesactiv="TitleText[""Now leaving Banking area"",""PLAIN DOWN""]; canbuild = true;insafezone = false;";
            class Effects
            {
            };
        };

Только не забывайте следить за порядковым числом классов и параметра item

 


Перепроверка кол-ва денег при дисконнекте:


1) Находим в variables.sqf эти строки:

if(isNil "DZE_maintainRange") then {
    DZE_maintainRange = ((DZE_PlotPole select 0)+35);
};

добавляем ниже:

if(isNil "DZE_fUpdateMoney") then {
    DZE_fUpdateMoney = false;
};

p.s. тут вам нужно использовать параметр true для включения фуекции
2) Находим в файле Server_OnPlayerDisconnect.sqf:

[_playerObj,_magazines,true,true,_isplayernearby] call server_playerSync;

и заменяем этим:

[_playerObj,_magazines,true,true,_isplayernearby,DZE_fUpdateMoney] call server_playerSync;

3) В файле server_playerSync.sqf находим:

if( isNil "_headShotsZupa") then{
    _headShotsZupa = 0;
};

и ниже добавляем:

_fUpdateMoney = false;
if ((count _this) > 5) then {
    _fUpdateMoney = _this select 5;
};

Ищем эти строки:

if(_isChanged > 0)then{        
_key = format["CHILD:999:UPDATE `character_data` SET `HeadshotsZ` = %1 WHERE `CharacterID` = %2:[0]:",_headShotsZupa,_characterID];            
_result = _key call server_hiveReadWrite;        
_character setVariable ["moneychanged",0,true];            
};

и заменяем этими:

if((_isChanged > 0) || _fUpdateMoney)then{    
_key = format["CHILD:999:UPDATE `character_data` SET `HeadshotsZ` = %1 WHERE `CharacterID` = %2:[0]:",_headShotsZupa,_characterID];            
_result = _key call server_hiveReadWrite;        
_character setVariable ["moneychanged",0,true];            
};

 

 


Добавление денег админом игроку:

только при наличии infistar

 


1) В AH.sqf где-то в районе секции adminadd (примерно 4038 строка) вставить эти строки(автор фикса вставлял их после функции добавления Humanity):

adminadd = adminadd + [" Give 1000 Coins",admingivecoins,"0","0","0","1",[0,0.8,1,1]];
adminadd = adminadd + [" Take 1000 Coins",admintakecoins,"0","0","0","1",[0,0.8,1,1]];

2) Теперь листаем где-то на строку 7402 где выдаётся Humanity и добавляем это:

admingivecoins =
    {
        private ["_wealth","_removecoins"];
        {
            if (name _x == _this select 0) then
            {
                _wealth = _x getVariable["headShots",0];
                _x setVariable["headShots",_wealth + 1000, true];
                PVDZE_plr_Save = [_x,(magazines _x),true,true] ;
                publicVariableServer "PVDZE_plr_Save";
                _x setVariable ["moneychanged",1,true];    
                hint format ["Gave %1 1000 Coins!",_this select 0];
                
                _sl = format["%1 gave 1000 coins to %2",name player,_this select 0];
                PVAH_WriteLogReq = [player,_sl];
                publicVariableServer "PVAH_WriteLogReq";
            };
        } forEach playableUnits;
    };
    admintakecoins =
    {
        private ["_wealth","_removecoins","_newwealth"];
        {
            if (name _x == _this select 0) then
            {
                _wealth = _x getVariable["headShots",0];
                _removecoins = 1000;
                if (_wealth <= 1000) then {
                    _removecoins = _wealth;
                } else {
                    _removecoins = 1000;
                };
                _newwealth = _wealth-_removecoins;
                if (_newwealth <= 0) then { _newwealth = 0; };
                _x setVariable["headShots",_newwealth, true];
                PVDZE_plr_Save = [_x,(magazines _x),true,true] ;
                publicVariableServer "PVDZE_plr_Save";
                _x setVariable ["moneychanged",1,true];    
                hint format ["Take %1 coins from %2!",_removecoins, _this select 0];
                
                _sl = format["%1 took %2 coins from %3",name player,_removecoins,_this select 0];
                PVAH_WriteLogReq = [player,_sl];
                publicVariableServer "PVAH_WriteLogReq";
            };
        } forEach playableUnits;
    };

 

 

 

Кастомный дебаг монитор с кол-вом валюты в банке:

Пожалуйста, Войдите или Зарегистрируйтесь, чтобы увидеть это: Вложение.


Просто замените ваш playerHud в папке addons на этот 
Если у вас установлены numberDigits.sqf и numberText.sqf, то используйте эту ссылку


Продажа брифкейса при нажатии на него ПКМ

 

 

Стандартная цена 50.000$, можно изменить в конфиге.
1) Качаем файл
2) Заменяем путь вашего ui_selectslot.sqf в файле compiles.sqf на тот что из архива, предварительно закинув новый файл в нужное вам место в папке миссии (обычно папка custom.
3) В конец description.ext добавляем это:

#include "custom\extra_rc.hpp"

4) Кидаем файл extra_rc.hpp в папку custom в вашей папке миссии.

5) Кидаем файл SellBrief.sqf в папку custom в вашей папке миссии, а затем этот файл настраиваем как вам нужно.

 

 

 

Просмотр кол-ва денег у игрока через Infistar

 

 

1) Открываем AH.sqf и ищем эти строки:

_log2 = format['Blood: %1    Humanity: %2',(_unit getVariable['USEC_BloodQty',12000]),(_unit getVariable['humanity',0])];

Заменяем их этими:

_log2 = format['Blood: %1 Humanity: %2 Money: %3 Bank: %4',(_unit getVariable['USEC_BloodQty',12000]),(_unit getVariable['humanity',0]),(_unit getVariable["headShots",0]),(_unit getVariable["bank",0])];

2) Или если что-то не будет работать после добавления тех строк, то попробуйте эти:

_log2 = format['Blood: %1 Humanity: %2 Money: %3 Bank: %4',(_unit getVariable['USEC_BloodQty',12000]),(_unit getVariable['humanity',0]),(_unit getVariable["CashMoney",0]),(_unit getVariable["bankMoney",0])];

 

 

 

Банки + маркеры для карты NAPF

 


Позже добавлю, у меня уже глаза закрываются  :laugh: 

 

Share this post


Link to post
Share on other sites

Засняли бы видос с полным описанием, особо непонятно что это дает.

Добавляются банки и все деньги хранятся там. ПОявляется новая валюта - нормальные деньги вместо слитков металла.  Ну и между собой оба вида валюты менять можно, торговать.

Share this post


Link to post
Share on other sites

успользую эти скрипты уже неделю как дюпается хуманити у игроков(по 500к) и непашет обновление плота 

Share this post


Link to post
Share on other sites

т.е. Поле - "Убито в голову", в БД(ХедШотЗ) используется для хранения бабла.

Share this post


Link to post
Share on other sites

Привет, поставил, все супер, но все же две вещи не понятно, как подходишь к ноуту то плохо отображается банк, надо искать под определенным углом, и при добавлении денег юзеру из инфистара то кикает по фильтру с 0 строкой

Share this post


Link to post
Share on other sites

Привет, поставил, все супер, но все же две вещи не понятно, как подходишь к ноуту то плохо отображается банк, надо искать под определенным углом, и при добавлении денег юзеру из инфистара то кикает по фильтру с 0 строкой

Скидывай лог и что у тебя в PV фильтре написано?

Share this post


Link to post
Share on other sites
 1:44:39 "get: STRING (1747076), sent: STRING (1747076)"

 1:44:39 "DISCONNECT: Alex39 (1747076) Object: B 1-1-B:1 (Alex39) REMOTE, _characterID: 1 at loc [5702.22,2010.19,0.00147152]"

Share this post


Link to post
Share on other sites

 

 1:44:39 "get: STRING (1747076), sent: STRING (1747076)"
 1:44:39 "DISCONNECT: Alex39 (1747076) Object: B 1-1-B:1 (Alex39) REMOTE, _characterID: 1 at loc [5702.22,2010.19,0.00147152]"

Эм, я так понимаю это лог из сервера, а мне надо что написано в логе PV.

Пример:

10.08.2014 15:29:00: TheFirstNoob (109.202.165.153:2316) 1e15aa96df04e0b2df423f77d4055ad7 - #9 "PVAH_AdminReq" = [1234,<NULL-object>,"8296713"]

Share this post


Link to post
Share on other sites

А вот при добавлении человеку из админки денег

 

24.08.2014 02:08:42: Alex39 (127.0.0.1:2304) 7d8a6468e009b7bec130836879e8e17b - #11 "RGTA_WriteLogReq" = [<NULL-object>,"Alex39 AdminHeal Brat904"]

и кикает

Share this post


Link to post
Share on other sites

Ссылку на оригинал пожалуйста дайте и на тему тоже.

Edited by sanek327 (see edit history)

Share this post


Link to post
Share on other sites

А вот при добавлении человеку из админки денег

 

24.08.2014 02:08:42: Alex39 (127.0.0.1:2304) 7d8a6468e009b7bec130836879e8e17b - #11 "RGTA_WriteLogReq" = [<NULL-object>,"Alex39 AdminHeal Brat904"]

и кикает

Хм. Странно конечно. Кикает по команде лечения.

 

Попробуй добавить в фильтр вот это:

 !="RGTA_WriteLogReq"

Просто продолжи эту строчку:

//new
5 "" !"PVDZE_" !"norrn" !"usec" !="remExField" !="remExFP" !="drn_AskServerDynamicWeatherEventArgs" !="norrinRAlie" !="BIS_effects_gepv" !="dayzPlayerLogin" !="dayzPlayerLogin2" !"PVAHR_" !="PVAH_AdminReq" !="PVAH_WriteLogReq"

Share this post


Link to post
Share on other sites

Прописал, потестим, и еще, в Черногорске банк на ступеньках в здании стоит, не хочет отображать банк меню, видно из за здания

Share this post


Link to post
Share on other sites

Прописал, потестим, и еще, в Черногорске банк на ступеньках в здании стоит, не хочет отображать банк меню, видно из за здания

Если не поможет, то

 

//new
5 "" !"PVDZE_" !"norrn" !"usec" !="remExField" !="remExFP" !="drn_AskServerDynamicWeatherEventArgs" !="norrinRAlie" !="BIS_effects_gepv" !="dayzPlayerLogin" !="dayzPlayerLogin2" !"PVAHR_" !="PVAH_AdminReq" !="PVAH_WriteLogReq"
5 "norrn" !="norrnRACarUp" !="norrnRAPicUp" !="norrnRaDrag" !="norrnR180" !="norrnRalie" !="norrnRLact" !="norrnRALW" !="norrnRDead"
5 "usec" !="usecMorphine" !="usecBandage" !="usecBleed"
5 "PVDZE_" !"PVDZE_player" !="PVDZE_send" !="PVDZE_log_lockUnlock" !="PVDZE_Server_Simulation" !="PVDZE_veh_Update" !="PVDZE_plr_GutBody" !="PVDZE_plr_GutBodyZ" !="PVDZE_veh_Lock" !="PVDZE_plr_DeathB" !="PVDZE_maintainArea" !="PVDZE_obj_Publish" !="PVDZE_obj_Swap" !="PVDZE_plr_Save" !="PVDZE_obj_Delete" !="PVDZE_obj_Trade" !="PVDZE_veh_Publish2" !="PVDZE_zed_Spawn" !="PVDZE_plr_Died" !="PVDZE_plr_TradeMenu" !="PVDZE_veh_Upgrade" !="PVDZE_atp" !="PVDZE_plr_Login" !="PVDZE_plr_Login2" !="PVDZE_plr_LoginRecord" !="PVDZE_plr_DeathBResult" !="PVDZE_veh_SFix" !="PVDZE_plr_Hit" !="PVDZE_plr_HitV" !="PVDZE_veh_SFuel" !="PVDZE_plr_HideBody" !="PVDZE_plr_Morph" !="PVDZE_veh_Publish" !="PVDZE_plr_Characters" !="PVDZE_lockVault" !="PVDZE_obj_setlocalVars" !="PVDZE_obj_getlocalVars"
5 "PVAHR_" !"PVAHR_0_"
5 "remExFP" !="\"remExFP\" = \[,,\"per\",\"execVM\",\"ca\\Modules\\Functions\\init.sqf\"\]" !"\[,,\"per\",\"execVM\",\"ca\\Modules\\Functions\\init.sqf\"\]"
5="player"
5="server"
5 "fnc_plyrHit"
1="PVAH_AdminReq"
1="PVAH_WriteLogReq"
1="RGTA_WriteLogReq"
1 "PVAHR_0_"

RGTA_WriteLogReq внизу написан.

Share this post


Link to post
Share on other sites

Ни чего не помогает, и вверху и в низу

 

24.08.2014 11:09:49: Alex39 (127.0.0.1:2304) 7d8a6468e009b7bec130836879e8e17b - #0 "PVAH_WriteLogReq" = [<NULL-object>,"Alex39 gave 1000 coins to PollKillo"]

кикает и все

Edited by Alex39 (see edit history)

Share this post


Link to post
Share on other sites

Ни чего не помогает, и вверху и в низу

 

24.08.2014 11:09:49: Alex39 (127.0.0.1:2304) 7d8a6468e009b7bec130836879e8e17b - #0 "PVAH_WriteLogReq" = [<NULL-object>,"Alex39 gave 1000 coins to PollKillo"]

кикает и все

Так, ну тут уже АнтиХак фильтр реагирует, а не система банка. Счас придумаем.

Share this post


Link to post
Share on other sites

 

Так, ну тут уже АнтиХак фильтр реагирует, а не система банка. Счас придумаем.

 

Потом в гайде найди где добавлять строку в инфи с добавлением мелочи игрокам и подпиши как пофиксить фильтры плиз.

Share this post


Link to post
Share on other sites

Поставил себе на сервер. Проблем не имею с киком. Все нормально.

Единственное что кнопки сами в другое место перенес.

А теперь по поводу установленного у тебя инфи. Отпиши в ЛС PV фильтр.

Share this post


Link to post
Share on other sites
 

задействовали зачем то хуманити и хедшоты... бред полнейший, можно было использовать просто доп запись в полях. с сейфа чужие коинты взять нельзя. вообщем все сыро и криво.

Share this post


Link to post
Share on other sites

 

 

задействовали зачем то хуманити и хедшоты... бред полнейший, можно было использовать просто доп запись в полях. с сейфа чужие коинты взять нельзя. вообщем все сыро и криво.

По этой теме, как я правильно понял, так пофиксили дюпы, но мой Английский далеко не идеален. Может не так что прочел.

Share this post


Link to post
Share on other sites

Собственно кому нужны фильтры под этот скрипт.
Запись в логи, кик система и прочее.

Оригинальный фильтр от инфи:

//new
5 "" !"PVDZE_" !"norrn" !"usec" !="remExField" !="remExFP" !="drn_AskServerDynamicWeatherEventArgs" !="norrinRAlie" !="BIS_effects_gepv" !="dayzPlayerLogin" !="dayzPlayerLogin2" !"PVAHR_" !="PVAH_AdminReq" !="PVAH_WriteLogReq"
5 "norrn" !="norrnRACarUp" !="norrnRAPicUp" !="norrnRaDrag" !="norrnR180" !="norrnRalie" !="norrnRLact" !="norrnRALW" !="norrnRDead"
5 "usec" !="usecMorphine" !="usecBandage" !="usecBleed"
5 "PVDZE_" !"PVDZE_player" !="PVDZE_send" !="PVDZE_log_lockUnlock" !="PVDZE_Server_Simulation" !="PVDZE_veh_Update" !="PVDZE_plr_GutBody" !="PVDZE_plr_GutBodyZ" !="PVDZE_veh_Lock" !="PVDZE_plr_DeathB" !="PVDZE_maintainArea" !="PVDZE_obj_Publish" !="PVDZE_obj_Swap" !="PVDZE_plr_Save" !="PVDZE_obj_Delete" !="PVDZE_obj_Trade" !="PVDZE_veh_Publish2" !="PVDZE_zed_Spawn" !="PVDZE_plr_Died" !="PVDZE_plr_TradeMenu" !="PVDZE_veh_Upgrade" !="PVDZE_atp" !="PVDZE_plr_Login" !="PVDZE_plr_Login2" !="PVDZE_plr_LoginRecord" !="PVDZE_plr_DeathBResult" !="PVDZE_veh_SFix" !="PVDZE_plr_Hit" !="PVDZE_plr_HitV" !="PVDZE_veh_SFuel" !="PVDZE_plr_HideBody" !="PVDZE_plr_Morph" !="PVDZE_veh_Publish" !="PVDZE_plr_Characters" !="PVDZE_lockVault" !="PVDZE_obj_setlocalVars" !="PVDZE_obj_getlocalVars"
5 "PVAHR_" !"PVAHR_0_"
5 "remExFP" !="\"remExFP\" = \[,,\"per\",\"execVM\",\"ca\\Modules\\Functions\\init.sqf\"\]" !"\[,,\"per\",\"execVM\",\"ca\\Modules\\Functions\\init.sqf\"\]"
5="player"
5="server"
5 "fnc_plyrHit"
1="PVAH_AdminReq"
1="PVAH_WriteLogReq"
1 "PVAHR_0_"

Заменяем на это: 

//new
5 "" !"PVDZE_" !"norrn" !"usec" !="remExField" !="remExFP" !="drn_AskServerDynamicWeatherEventArgs" !="norrinRAlie" !="BIS_effects_gepv" !="dayzPlayerLogin" !="dayzPlayerLogin2" !"PVAHR_" !="PVAH_AdminReq" !="PVAH_WriteLogReq" !"RGTAR_" !="RGTA_AdminReq" !="RGTA_WriteLogReq"
5 "norrn" !="norrnRACarUp" !="norrnRAPicUp" !="norrnRaDrag" !="norrnR180" !="norrnRalie" !="norrnRLact" !="norrnRALW" !="norrnRDead"
5 "usec" !="usecMorphine" !="usecBandage" !="usecBleed"
5 "PVDZE_" !"PVDZE_player" !="PVDZE_send" !="PVDZE_log_lockUnlock" !="PVDZE_Server_Simulation" !="PVDZE_veh_Update" !="PVDZE_plr_GutBody" !="PVDZE_plr_GutBodyZ" !="PVDZE_veh_Lock" !="PVDZE_plr_DeathB" !="PVDZE_maintainArea" !="PVDZE_obj_Publish" !="PVDZE_obj_Swap" !="PVDZE_plr_Save" !="PVDZE_obj_Delete" !="PVDZE_obj_Trade" !="PVDZE_veh_Publish2" !="PVDZE_zed_Spawn" !="PVDZE_plr_Died" !="PVDZE_plr_TradeMenu" !="PVDZE_veh_Upgrade" !="PVDZE_atp" !="PVDZE_plr_Login" !="PVDZE_plr_Login2" !="PVDZE_plr_LoginRecord" !="PVDZE_plr_DeathBResult" !="PVDZE_veh_SFix" !="PVDZE_plr_Hit" !="PVDZE_plr_HitV" !="PVDZE_veh_SFuel" !="PVDZE_plr_HideBody" !="PVDZE_plr_Morph" !="PVDZE_veh_Publish" !="PVDZE_plr_Characters" !="PVDZE_lockVault" !="PVDZE_obj_setlocalVars" !="PVDZE_obj_getlocalVars"
5 "PVAHR_" !"PVAHR_0_"
5 "remExFP" !="\"remExFP\" = \[,,\"per\",\"execVM\",\"ca\\Modules\\Functions\\init.sqf\"\]" !"\[,,\"per\",\"execVM\",\"ca\\Modules\\Functions\\init.sqf\"\]"
5="player"
5="server"
5 "fnc_plyrHit"
1 "RGTAR_"
1="RGTA_AdminReq"
1="RGTA_WriteLogReq"
1="PVAH_AdminReq"
1="PVAH_WriteLogReq"
1 "PVAHR_0_"

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By BorizzK
      В эксперементалке 1.08 если сбросить предмет находясь на машине (крыше, багажнике, капоте в кузове) предмет проваливается сквозь машину на землю или оказывается в ее текстурах
       
      Тикет
      https://feedback.bistudio.com/T152071
       
      ответ богемии поразителен - сейчас нет простого решения
       
      А ниже что? Проще не бывает...
       
      Собственно код фикса (Автор Я)
       
      Code ``` modded class ItemBase extends InventoryItem { override void EEItemLocationChanged(notnull InventoryLocation oldLoc, notnull InventoryLocation newLoc) { super.EEItemLocationChanged(oldLoc,newLoc); if (newLoc.GetType() == InventoryLocationType.GROUND) { if (oldLoc.GetParent()) { PlayerBase player = PlayerBase.Cast(oldLoc.GetParent()); if (player) { FixPositionIfDropOnCar(player); } } } } void FixPositionIfDropOnCar(PlayerBase player) { vector m_RayStart; vector m_RayEnd; m_RayStart = player.GetPosition(); m_RayStart[1] = m_RayStart[1] + 0.5; m_RayEnd = m_RayStart; m_RayEnd[1] = m_RayEnd[1] - 1; RaycastRVParams m_RayCastInput = new RaycastRVParams(m_RayStart, m_RayEnd, this, 0.05); array<ref RaycastRVResult> m_RayCastResults = new array<ref RaycastRVResult>; m_RayCastInput.with = player; m_RayCastInput.flags = CollisionFlags.FIRSTCONTACT; if (DayZPhysics.RaycastRVProxy(m_RayCastInput, m_RayCastResults)) { if (m_RayCastResults.Count() > 0) { Car car; if (Class.CastTo(car, m_RayCastResults[0].obj) || Class.CastTo(car, m_RayCastResults[0].parent)) { this.SetPosition(m_RayCastResults[0].pos + (player.GetDirection() * 0.1)); } } } } } ``` Наверное имеет смысл чуть приподнять предмет над поверхностью, но необходимость этого зависит от типа предмета, потому не стал этого делать
       
      чуть откорректировал код
    • By BorizzK
      Довольно тупое охлаждение жратвы и кастрюли если они оказались на земле
      Прикрутить охлаждение содержимого кастрюли как 2 байта сами знаете что
      Сделать охлаждение после снятия с костра и тп вобщем то же не проблема
       
      Просто код и ничего лишнего
       
      Комментарии к коду добавлю позже
      Логгирование в коде закомментировано - раскомментируйте, что бы наблюдать за процессом
       
      Для жратвы убавление температуры раз в 10 сек на 1 градус
      Для кастрюли на 2 градуса
       
      Охлаждается до дневной температуры воздуха далее охлаждение прекращается
      У бгемотов есть 2 температуры воздуха - дневная и ночная
      Идиотизм? Однозначно
      Я пытался в погоде сделать ее плавное изменение в зависимости от Overcast, Rain и тп, но забил - потом как-нибудь
       
      Есть вопросы, задавайте, отвечу если будет время.
       
      Вобщем как-то так:
       
      //08.05.2020 modded class ItemBase extends InventoryItem { ref Timer m_TemperatureDecrease; private float m_InitTemperature; private float m_DecreaseTempTime = 10; private float m_TempDecreaseCoef = -1; void ItemBase() { m_InitTemperature = 12; //g_Game.GetMission().GetWorldData().GetDayTemperature(); // Не работает ((( какого художника - я хз if ( IsInherited(Pot) /* GetInventory().GetCargo() */ ) { m_TempDecreaseCoef = -2; } } override void AfterStoreLoad() { super.AfterStoreLoad(); if (!IsInherited(FireplaceBase)) TryToStartTempDecrease(); } private void TryToStartTempDecrease() { if (GetTemperature() > GetInitTemperature()) { if (!GetHierarchyParent()) { if (!m_TemperatureDecrease) { Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: Init: TryToStartTempDecrease: this: " + this + ": GetHierarchyParent(): " + GetHierarchyParent() + ": GetTemperature(): " + GetTemperature()); StartTemperatureDecrease(); } } } } override void EEItemLocationChanged(notnull InventoryLocation oldLoc, notnull InventoryLocation newLoc) { super.EEItemLocationChanged(oldLoc,newLoc); //Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: EEItemLocationChanged: this: " + this + ": newLoc.GetType(): " + newLoc.GetType() + ": newLoc.GetParent(): " + newLoc.GetParent() + ": GetTemperature(): " + GetTemperature()); if (GetTemperature() > GetInitTemperature()) { if (!newLoc.GetParent() || newLoc.GetType() == InventoryLocationType.GROUND) { if (!m_TemperatureDecrease) { Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: EEItemLocationChanged: this: " + this + ": Begin decrease temperature: GetTemperature(): " + GetTemperature()); StartTemperatureDecrease(); } } } else { if (m_TemperatureDecrease) { Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: EEItemLocationChanged: this: " + this + ": End decrease temperature: GetTemperature(): " + GetTemperature()); StopTemperatureDecrease(); } } } private void StartTemperatureDecrease() { m_TemperatureDecrease = new Timer( CALL_CATEGORY_SYSTEM ); m_TemperatureDecrease.Run(m_DecreaseTempTime, this, "DecreaseTemperature", NULL, true); } private void StopTemperatureDecrease() { m_TemperatureDecrease.Stop(); m_TemperatureDecrease = NULL; } void DecreaseTemperature() { if (GetTemperature() > GetInitTemperature()) { AddTemperature(GetTempDecreaseCoef()); if ( IsInherited(Pot) /* GetInventory().GetCargo() */) { DecreaseCargoTemperature(); } Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: DecreaseTemperature: this: " + this + ": Decrease: GetTemperature(): " + GetTemperature()); } else { SetTemperature(GetInitTemperature()); StopTemperatureDecrease(); Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: DecreaseTemperature: this: " + this + ": Stop decrease: GetTemperature(): " + GetTemperature()); } } void DecreaseCargoTemperature() { ItemBase item; int item_count = GetInventory().GetCargo().GetItemCount(); for (int i = 0; i < item_count; i++) { item = ItemBase.Cast(GetInventory().GetCargo().GetItem(i)); if (item) { if (item.GetTemperature() > item.GetInitTemperature()) { item.AddTemperature(item.GetTempDecreaseCoef()); Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: DecreaseCargoTemperature: this: " + this + ": Decrease: item: " + item + ": item.GetTemperature(): " + item.GetTemperature()); } else { item.SetTemperature(item.GetInitTemperature()); Print("::: SERVER: [ItemBase extends InventoryItem: Decreasetemp]: DecreaseCargoTemperature: this: " + this + ": Stop decrease: item: " + item + ": item.GetTemperature(): " + item.GetTemperature()); } } } } float GetInitTemperature() { return m_InitTemperature; } float GetTempDecreaseCoef() { return m_TempDecreaseCoef; } } Немного переделал код
      Теперь охлаждается все если оно имеет Т выше 12, а если это кастрюля с содержимым, то и ее содержимое
      Получить Т воздуха в конструкторе не выходит потому указал руками
       
    • By DrTauren
      Что нам понадобится:
      1) Архив
      2) Notepad


      Инструкция:
      1) Качаем архив и копируем из него папку custom в вашу папку с миссией
      2) Открываем init.sqf и ищем такие строки:
      if (!isDedicated) then { 0 fadeSound 0; waitUntil {!isNil "dayz_loadScreenMsg"}; dayz_loadScreenMsg = (localize "STR_AUTHENTICATING"); _id = player addEventHandler ["Respawn", {_id = [] spawn player_death;}]; }; 3) Перед закрывающей скобкой }; прописываем это:
      _nil = [] execVM "custom\JAEM\EvacChopper_init.sqf"; 4) Выбираем одно из двух, выполняем действия указанные ниже:
      Если у вас нет своего variables.sqf в папке с миссией:  
       
      Если у вас есть свой variables.sqf в папке с миссией:  

      5) Копируем файлы remoteexec.txt, waypointcondition.txt, waypointstatement.txt в вашу папку с фильтрами BattlEye (\instance_11_Chernarus\BattlEye)

      Настройка параметров:
      Открываем файл EvacChopper_init.sqf (custom\JAEM\EvacChopper_init.sqf), находим нужную строку, редактируем по своему усмотрению:
      evac_chopperPrice = 3; Цена вашего спасения евреями. По умолчанию 3 Брифкейса
       
      evac_needRadio = 0; Обязательно ли радио для того, что бы вызвать хапуг? (0-не нужно, 1-таки извольте)
       
      evac_zoneMarker = 0; Дымовая граната на месте эвакуации (0-не надо, 1-таки не увидим мы без дыма)
       
      evac_minDistance = 500; Дословно: минимальное расстояние, что бы вызвать евреев. Меньше 500 не ставить!
    • By Serdce
      Ссылка на первоисточник - https://github.com/BrettNordin/Exile
      Я всего лишь перевёл
      Собственно переходим по ссылке, и скачиваем архив.
      Для тех, кто не знает как качать с хаба скрин 
      И так, едем дальше
      Скачанный архив распаковываем в удобное место для работы,
      Идём в ваш @ExileServer, там нас интересуют файлы - extDB2.dll , extDB2.so , extDB2-conf.ini , XM8.dll , XM8.so Удаляем эти файлы
      Далее идём в @ExileServer которую мы скачали, всё её содержимое копируем в аналогичную папку на сервере.
      Теперь идём в вашу MPmissions и там распаковываем вашу миссию "Exile.название карты",
      Туда мы копируем содержимое папки Exile.MapName из архива,
      Далее открываем ваш config.cpp и ищем там class CfgExileCustomCode 
      В него мы добавляем - #include "CfgExileCustomCode.cpp"
      Должно получится так
      Запаковываем обратно)
      Ну и теперь из архива мы копируем tbbmalloc.dll, tbbmalloc_x64.dll в папку расположения вашего Arma3_server.exe
      Не забываем поменять в вашем файле запуска сервера с arma3server.exe на arma3server_x64.exe 
      Ну и финишная прямая, открываем вашу базу данных ( желательно с название exile ) и добавляем файл Exile_Database_Update_64x.sql
      Далее настройте под себя ваш extdb3-conf.ini
       
    • By Astrahrom
      Столкнулся с цикличной проблемой в лаунчере, при установке ботов A3EAI:
      Script @epochhive\A3EAI_config.sqf not found Оказалось, что все дело в том, что в открытом доступе лежат старые версии этого скрипта, и все кто пытается воткнуть в Epochhive, как я, данный скрипт - делают это по старой схеме, не актуальной для последних версий.
       
      Решение
       
      Скачиваем - https://yadi.sk/d/HfXeB1pEAGoRtw
       
      Устанавливаем:
      1. Взять из папки архива "1. Installation Package" папку "@A3EAI" и вложить её в папку с вашим сервером;
      2. Прописать скрипт в вашем запускаторе, примерно так:
      -servermod=@EpochHive;@A3EAI; Пример моего запускатора:
      @echo off start "arma3" "arma3server.exe" -servermod=@EpochHive;@A3EAI; -mod=@Epoch; -config=C:\Arma3Server\sc\server.cfg -port=2307 -profiles=sc -cfg=C:\Arma3Server\sc\basic.cfg -name=sc -autoINIT Варианты настройки, которые хранятся в самой папке @A3EAI\addons\a3eai_config в файле config.cpp.
  • Our picks

×
×
  • Create New...

Important Information

By using this site, you automaticly agree to our Guidelines and Privacy Policy.
We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.