2017-02-23 13:28:28 +00:00
|
|
|
/**
|
|
|
|
* ExileServer_system_database_connect
|
|
|
|
*
|
|
|
|
* Exile Mod
|
|
|
|
* www.exilemod.com
|
|
|
|
* © 2015 Exile Mod Team
|
|
|
|
*
|
|
|
|
* This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License.
|
|
|
|
* To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
private["_isConnected","_error","_result"];
|
|
|
|
_isConnected = false;
|
|
|
|
_error_locked = false;
|
|
|
|
ExileServerDatabaseSessionId = "";
|
|
|
|
ExileServerRconSessionID = "";
|
|
|
|
try
|
|
|
|
{
|
|
|
|
_result = "extDB3" callExtension "9:VERSION";
|
2017-03-09 22:03:27 +00:00
|
|
|
format ["Installed extDB3 version: %1", _result] call ExileServer_util_log;
|
|
|
|
if ((parseNumber _result) < 1.027) then
|
|
|
|
{
|
|
|
|
throw format ["Error Required extDB3 Version 1.027 or higher: %1", _result];
|
|
|
|
};
|
2017-02-23 13:28:28 +00:00
|
|
|
_result = call compile ("extDB3" callExtension "9:ADD_DATABASE:exile");
|
|
|
|
if (_result select 0 isEqualTo 0) then
|
|
|
|
{
|
|
|
|
throw format ["Could not add database: %1", _result];
|
|
|
|
};
|
|
|
|
"Connected to database!" call ExileServer_util_log;
|
2017-03-06 21:30:28 +00:00
|
|
|
ExileServerDatabaseSessionId = "SQL"; //str(round(random(999999)));
|
2017-02-23 13:28:28 +00:00
|
|
|
_result = call compile ("extDB3" callExtension "9:ADD_DATABASE_PROTOCOL:exile:SQL_CUSTOM:SQL:exile.ini");
|
|
|
|
if ((_result select 0) isEqualTo 0) then
|
|
|
|
{
|
|
|
|
throw format ["Failed to initialize database protocol: %1", _result];
|
|
|
|
};
|
|
|
|
ExileServerStartTime = (call compile ("extDB3" callExtension "9:LOCAL_TIME")) select 1;
|
|
|
|
"Database protocol initialized!" call ExileServer_util_log;
|
|
|
|
"extDB3" callExtension "9:ADD_PROTOCOL:LOG:TRADING:Exile_TradingLog";
|
|
|
|
"extDB3" callExtension "9:ADD_PROTOCOL:LOG:DEATH:Exile_DeathLog";
|
|
|
|
"extDB3" callExtension "9:ADD_PROTOCOL:LOG:TERRITORY:Exile_TerritoryLog";
|
|
|
|
"extDB3" callExtension "9:LOCK";
|
|
|
|
_isConnected = true;
|
|
|
|
}
|
|
|
|
catch
|
|
|
|
{
|
|
|
|
if (!_error_locked) then
|
|
|
|
{
|
|
|
|
"MySQL connection error!" call ExileServer_util_log;
|
2017-03-03 20:45:30 +00:00
|
|
|
"Please have a look at @extDB3/logs/ to find out what went wrong." call ExileServer_util_log;
|
2017-02-23 13:28:28 +00:00
|
|
|
format ["MySQL Error: %1", _exception] call ExileServer_util_log;
|
|
|
|
"Server will shutdown now :(" call ExileServer_util_log;
|
|
|
|
//"extDB3" callExtension "9:SHUTDOWN"; Not implemented in extDB3
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
format ["extDB3: %1", _exception] call ExileServer_util_log;
|
|
|
|
"Check your server rpt for errors, your mission might be stuck a loop restarting" call ExileServer_util_log;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
_isConnected
|