2022-01-18 16:44:22 -05:00
|
|
|
using System.IO;
|
2021-07-12 01:32:10 -07:00
|
|
|
using Content.Server.Administration.Managers;
|
2021-07-22 23:19:41 +02:00
|
|
|
using Content.Server.Afk;
|
2021-02-20 17:37:17 +11:00
|
|
|
using Content.Server.AI.Utility;
|
2020-10-30 16:06:48 +01:00
|
|
|
using Content.Server.AI.Utility.Considerations;
|
2020-08-13 14:40:27 +02:00
|
|
|
using Content.Server.AI.WorldState;
|
2021-06-09 22:19:39 +02:00
|
|
|
using Content.Server.Chat.Managers;
|
|
|
|
|
using Content.Server.Connection;
|
2020-09-29 14:26:00 +02:00
|
|
|
using Content.Server.Database;
|
2021-06-09 22:19:39 +02:00
|
|
|
using Content.Server.EUI;
|
|
|
|
|
using Content.Server.GameTicking;
|
2022-01-18 16:44:22 -05:00
|
|
|
using Content.Server.GuideGenerator;
|
2021-12-28 23:31:18 -08:00
|
|
|
using Content.Server.Info;
|
2021-06-09 22:19:39 +02:00
|
|
|
using Content.Server.IoC;
|
2021-11-20 12:32:07 -06:00
|
|
|
using Content.Server.Maps;
|
2021-06-09 22:19:39 +02:00
|
|
|
using Content.Server.NodeContainer.NodeGroups;
|
|
|
|
|
using Content.Server.Preferences.Managers;
|
2019-10-02 10:45:06 +02:00
|
|
|
using Content.Server.Sandbox;
|
2021-06-09 22:19:39 +02:00
|
|
|
using Content.Server.Voting.Managers;
|
2020-12-13 14:28:20 -08:00
|
|
|
using Content.Shared.Actions;
|
2021-12-11 17:28:16 -06:00
|
|
|
using Content.Shared.Administration;
|
2020-11-09 20:22:19 -08:00
|
|
|
using Content.Shared.Alert;
|
2022-01-18 16:44:22 -05:00
|
|
|
using Content.Shared.CCVar;
|
2021-03-16 15:50:20 +01:00
|
|
|
using Content.Shared.Kitchen;
|
2022-01-18 16:44:22 -05:00
|
|
|
using Robust.Server;
|
2021-10-31 15:14:44 -05:00
|
|
|
using Robust.Server.Bql;
|
2021-02-11 01:13:03 -08:00
|
|
|
using Robust.Server.Player;
|
2022-01-18 16:44:22 -05:00
|
|
|
using Robust.Shared.Configuration;
|
2021-12-29 20:28:17 +01:00
|
|
|
using Robust.Server.ServerStatus;
|
2019-04-15 21:11:38 -06:00
|
|
|
using Robust.Shared.ContentPack;
|
2021-02-11 01:13:03 -08:00
|
|
|
using Robust.Shared.GameObjects;
|
2019-04-15 21:11:38 -06:00
|
|
|
using Robust.Shared.IoC;
|
|
|
|
|
using Robust.Shared.Log;
|
|
|
|
|
using Robust.Shared.Timing;
|
2022-01-18 16:44:22 -05:00
|
|
|
using Robust.Shared.Utility;
|
2017-08-04 14:24:01 +02:00
|
|
|
|
2021-06-13 14:52:40 +02:00
|
|
|
namespace Content.Server.Entry
|
2017-08-04 14:24:01 +02:00
|
|
|
{
|
2022-02-16 00:23:23 -07:00
|
|
|
public sealed class EntryPoint : GameServer
|
2017-08-04 14:24:01 +02:00
|
|
|
{
|
2021-03-16 15:50:20 +01:00
|
|
|
private EuiManager _euiManager = default!;
|
|
|
|
|
private IVoteManager _voteManager = default!;
|
2018-08-21 00:59:04 +02:00
|
|
|
|
2018-01-18 13:00:35 -06:00
|
|
|
/// <inheritdoc />
|
2017-08-04 14:24:01 +02:00
|
|
|
public override void Init()
|
|
|
|
|
{
|
2018-01-18 13:00:35 -06:00
|
|
|
base.Init();
|
|
|
|
|
|
2021-12-29 20:28:17 +01:00
|
|
|
IoCManager.Resolve<IStatusHost>().SetAczInfo("Content.Client",
|
|
|
|
|
new[] { "Content.Client", "Content.Shared", "Content.Shared.Database" });
|
|
|
|
|
|
2017-09-24 23:19:47 +02:00
|
|
|
var factory = IoCManager.Resolve<IComponentFactory>();
|
|
|
|
|
|
2019-07-31 15:02:36 +02:00
|
|
|
factory.DoAutoRegistrations();
|
2018-08-02 08:29:55 +02:00
|
|
|
|
2020-07-02 09:50:45 -04:00
|
|
|
foreach (var ignoreName in IgnoredComponents.List)
|
2019-07-31 15:02:36 +02:00
|
|
|
{
|
|
|
|
|
factory.RegisterIgnore(ignoreName);
|
|
|
|
|
}
|
2019-07-19 10:45:04 +02:00
|
|
|
|
2019-11-23 15:55:31 -05:00
|
|
|
ServerContentIoC.Register();
|
|
|
|
|
|
2020-10-29 17:50:25 +01:00
|
|
|
foreach (var callback in TestingCallbacks)
|
2019-06-29 01:58:16 +02:00
|
|
|
{
|
2020-10-29 17:50:25 +01:00
|
|
|
var cast = (ServerModuleTestingCallbacks) callback;
|
2019-06-29 01:58:16 +02:00
|
|
|
cast.ServerBeforeIoC?.Invoke();
|
|
|
|
|
}
|
2019-12-06 02:08:17 +01:00
|
|
|
|
2018-11-21 21:11:30 +01:00
|
|
|
IoCManager.BuildGraph();
|
2021-07-12 01:32:10 -07:00
|
|
|
factory.GenerateNetIds();
|
2022-01-18 16:44:22 -05:00
|
|
|
var configManager = IoCManager.Resolve<IConfigurationManager>();
|
|
|
|
|
var dest = configManager.GetCVar(CCVars.DestinationFile);
|
|
|
|
|
if (string.IsNullOrEmpty(dest)) //hacky but it keeps load times for the generator down.
|
|
|
|
|
{
|
|
|
|
|
_euiManager = IoCManager.Resolve<EuiManager>();
|
|
|
|
|
_voteManager = IoCManager.Resolve<IVoteManager>();
|
2018-11-21 21:11:30 +01:00
|
|
|
|
2022-01-18 16:44:22 -05:00
|
|
|
var playerManager = IoCManager.Resolve<IPlayerManager>();
|
2020-01-25 16:16:34 +01:00
|
|
|
|
2022-01-18 16:44:22 -05:00
|
|
|
var logManager = IoCManager.Resolve<ILogManager>();
|
|
|
|
|
logManager.GetSawmill("Storage").Level = LogLevel.Info;
|
|
|
|
|
logManager.GetSawmill("db.ef").Level = LogLevel.Info;
|
2022-01-17 16:06:19 -06:00
|
|
|
|
2022-01-18 16:44:22 -05:00
|
|
|
IoCManager.Resolve<IConnectionManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<IServerDbManager>().Init();
|
|
|
|
|
IoCManager.Resolve<IServerPreferencesManager>().Init();
|
|
|
|
|
IoCManager.Resolve<INodeGroupFactory>().Initialize();
|
|
|
|
|
IoCManager.Resolve<IGamePrototypeLoadManager>().Initialize();
|
|
|
|
|
_voteManager.Initialize();
|
|
|
|
|
}
|
2018-01-18 13:00:35 -06:00
|
|
|
}
|
|
|
|
|
|
2018-11-21 21:21:29 +01:00
|
|
|
public override void PostInit()
|
|
|
|
|
{
|
|
|
|
|
base.PostInit();
|
|
|
|
|
|
2022-01-19 13:35:31 +11:00
|
|
|
IoCManager.Resolve<IChatSanitizationManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<IChatManager>().Initialize();
|
2022-01-18 16:44:22 -05:00
|
|
|
var configManager = IoCManager.Resolve<IConfigurationManager>();
|
|
|
|
|
var resourceManager = IoCManager.Resolve<IResourceManager>();
|
|
|
|
|
var dest = configManager.GetCVar(CCVars.DestinationFile);
|
|
|
|
|
if (!string.IsNullOrEmpty(dest))
|
|
|
|
|
{
|
|
|
|
|
var resPath = new ResourcePath(dest).ToRootedPath();
|
|
|
|
|
var file = resourceManager.UserData.OpenWriteText(resPath.WithName("chem_" + dest));
|
|
|
|
|
ChemistryJsonGenerator.PublishJson(file);
|
|
|
|
|
file.Flush();
|
|
|
|
|
file = resourceManager.UserData.OpenWriteText(resPath.WithName("react_" + dest));
|
|
|
|
|
ReactionJsonGenerator.PublishJson(file);
|
|
|
|
|
file.Flush();
|
|
|
|
|
IoCManager.Resolve<IBaseServer>().Shutdown("Data generation done");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
IoCManager.Resolve<RecipeManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<BlackboardManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<ConsiderationsManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<IAdminManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<INpcBehaviorManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<IAfkManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<RulesManager>().Initialize();
|
|
|
|
|
_euiManager.Initialize();
|
|
|
|
|
|
|
|
|
|
IoCManager.Resolve<IGameMapManager>().Initialize();
|
|
|
|
|
IoCManager.Resolve<IEntitySystemManager>().GetEntitySystem<GameTicker>().PostInitialize();
|
|
|
|
|
IoCManager.Resolve<IBqlQueryManager>().DoAutoRegistrations();
|
2022-02-21 14:11:39 -08:00
|
|
|
IoCManager.Resolve<RoleBanManager>().Initialize();
|
2022-01-18 16:44:22 -05:00
|
|
|
}
|
2018-11-21 21:21:29 +01:00
|
|
|
}
|
|
|
|
|
|
2019-08-04 01:08:55 +02:00
|
|
|
public override void Update(ModUpdateLevel level, FrameEventArgs frameEventArgs)
|
2018-11-22 10:37:58 +01:00
|
|
|
{
|
2019-08-04 01:08:55 +02:00
|
|
|
base.Update(level, frameEventArgs);
|
2018-11-22 10:37:58 +01:00
|
|
|
|
2019-11-21 16:37:15 -08:00
|
|
|
switch (level)
|
|
|
|
|
{
|
2020-11-10 16:50:28 +01:00
|
|
|
case ModUpdateLevel.PostEngine:
|
2022-01-17 16:06:19 -06:00
|
|
|
{
|
|
|
|
|
_euiManager.SendUpdates();
|
|
|
|
|
_voteManager.Update();
|
|
|
|
|
break;
|
|
|
|
|
}
|
2019-11-21 16:37:15 -08:00
|
|
|
}
|
2018-11-22 10:37:58 +01:00
|
|
|
}
|
2017-08-04 14:24:01 +02:00
|
|
|
}
|
|
|
|
|
}
|