PalacePal/Pal.Client/DependencyInjection/DependencyInjectionContext.cs

140 lines
5.5 KiB
C#
Raw Normal View History

2023-02-15 22:17:19 +00:00
using System.Globalization;
using Dalamud.Data;
2023-02-15 13:35:11 +00:00
using Dalamud.Game;
using Dalamud.Game.ClientState;
using Dalamud.Game.ClientState.Conditions;
using Dalamud.Game.ClientState.Objects;
using Dalamud.Game.Command;
using Dalamud.Game.Gui;
2023-02-15 22:17:19 +00:00
using Dalamud.Interface.Windowing;
2023-02-15 13:35:11 +00:00
using Dalamud.Plugin;
using Microsoft.Extensions.DependencyInjection;
2023-02-15 22:17:19 +00:00
using Pal.Client.Commands;
using Pal.Client.Configuration;
using Pal.Client.Net;
2023-02-15 13:35:11 +00:00
using Pal.Client.Properties;
2023-02-15 22:17:19 +00:00
using Pal.Client.Rendering;
using Pal.Client.Scheduled;
using Pal.Client.Windows;
2023-02-15 13:35:11 +00:00
namespace Pal.Client.DependencyInjection
{
/// <summary>
/// DI-aware Plugin.
/// </summary>
2023-02-15 22:51:35 +00:00
// ReSharper disable once UnusedType.Global
internal sealed class DependencyInjectionContext : IDalamudPlugin
2023-02-15 13:35:11 +00:00
{
private ServiceProvider? _serviceProvider;
public string Name => Localization.Palace_Pal;
2023-02-15 22:51:35 +00:00
public DependencyInjectionContext(DalamudPluginInterface pluginInterface,
2023-02-15 13:35:11 +00:00
ClientState clientState,
GameGui gameGui,
ChatGui chatGui,
ObjectTable objectTable,
Framework framework,
Condition condition,
CommandManager commandManager,
DataManager dataManager)
{
IServiceCollection services = new ServiceCollection();
// dalamud
services.AddSingleton<IDalamudPlugin>(this);
services.AddSingleton(pluginInterface);
2023-02-15 22:17:19 +00:00
services.AddSingleton(clientState);
2023-02-15 13:35:11 +00:00
services.AddSingleton(gameGui);
services.AddSingleton(chatGui);
services.AddSingleton(objectTable);
services.AddSingleton(framework);
services.AddSingleton(condition);
services.AddSingleton(commandManager);
services.AddSingleton(dataManager);
2023-02-15 22:51:35 +00:00
services.AddSingleton(new WindowSystem(typeof(DependencyInjectionContext).AssemblyQualifiedName));
2023-02-15 13:35:11 +00:00
2023-02-15 22:17:19 +00:00
// plugin-specific
2023-02-15 13:35:11 +00:00
services.AddSingleton<Plugin>();
2023-02-15 22:17:19 +00:00
services.AddSingleton<DebugState>();
services.AddSingleton<Hooks>();
services.AddSingleton<RemoteApi>();
services.AddSingleton<ConfigurationManager>();
services.AddSingleton<IPalacePalConfiguration>(sp => sp.GetRequiredService<ConfigurationManager>().Load());
services.AddTransient<RepoVerification>();
services.AddSingleton<PalCommand>();
// territory handling
services.AddSingleton<TerritoryState>();
services.AddSingleton<FrameworkService>();
services.AddSingleton<ChatService>();
services.AddSingleton<FloorService>();
// windows & related services
services.AddSingleton<AgreementWindow>();
services.AddSingleton<ConfigWindow>();
services.AddTransient<StatisticsService>();
services.AddSingleton<StatisticsWindow>();
// these should maybe be scoped
services.AddSingleton<SimpleRenderer>();
services.AddSingleton<SplatoonRenderer>();
services.AddSingleton<RenderAdapter>();
// queue handling
services.AddTransient<IQueueOnFrameworkThread.Handler<QueuedImport>, QueuedImport.Handler>();
services.AddTransient<IQueueOnFrameworkThread.Handler<QueuedUndoImport>, QueuedUndoImport.Handler>();
services.AddTransient<IQueueOnFrameworkThread.Handler<QueuedConfigUpdate>, QueuedConfigUpdate.Handler>();
services.AddTransient<IQueueOnFrameworkThread.Handler<QueuedSyncResponse>, QueuedSyncResponse.Handler>();
2023-02-15 22:17:19 +00:00
// set up the current UI language before creating anything
Localization.Culture = new CultureInfo(pluginInterface.UiLanguage);
2023-02-15 13:35:11 +00:00
// build
_serviceProvider = services.BuildServiceProvider(new ServiceProviderOptions
{
ValidateOnBuild = true,
ValidateScopes = true,
});
// initialize plugin
2023-02-15 22:17:19 +00:00
#if RELEASE
// You're welcome to remove this code in your fork, but please make sure that:
// - none of the links accessible within FFXIV open the original repo (e.g. in the plugin installer), and
// - you host your own server instance
//
// This is mainly to avoid this plugin being included in 'mega-repos' that, for whatever reason, decide
// that collecting all plugins is a good idea (and break half in the process).
_serviceProvider.GetService<RepoVerification>();
#endif
2023-02-16 12:17:55 +00:00
// set up legacy services
LocalState.PluginInterface = pluginInterface;
LocalState.Mode = _serviceProvider.GetRequiredService<IPalacePalConfiguration>().Mode;
// windows that have logic to open on startup
2023-02-15 22:17:19 +00:00
_serviceProvider.GetRequiredService<AgreementWindow>();
2023-02-16 12:17:55 +00:00
// initialize components that are mostly self-contained/self-registered
_serviceProvider.GetRequiredService<Hooks>();
2023-02-15 22:17:19 +00:00
_serviceProvider.GetRequiredService<PalCommand>();
_serviceProvider.GetRequiredService<FrameworkService>();
_serviceProvider.GetRequiredService<ChatService>();
2023-02-15 13:35:11 +00:00
_serviceProvider.GetRequiredService<Plugin>();
}
public void Dispose()
{
// ensure we're not calling dispose recursively on ourselves
if (_serviceProvider != null)
{
ServiceProvider serviceProvider = _serviceProvider;
_serviceProvider = null;
serviceProvider.Dispose();
}
}
}
}