mirror of
https://github.com/wanderer-industries/wanderer
synced 2025-12-12 02:35:42 +00:00
191 lines
5.8 KiB
Elixir
191 lines
5.8 KiB
Elixir
defmodule WandererApp.Application do
|
|
@moduledoc false
|
|
|
|
use Application
|
|
|
|
require Logger
|
|
|
|
@impl true
|
|
def start(_type, _args) do
|
|
# Skip test mocks setup - handled in test helper if needed
|
|
|
|
# Core children that must always start
|
|
core_children = [
|
|
WandererApp.PromEx,
|
|
WandererAppWeb.Telemetry,
|
|
WandererApp.Vault,
|
|
WandererApp.Repo,
|
|
{Phoenix.PubSub, name: WandererApp.PubSub, adapter_name: Phoenix.PubSub.PG2},
|
|
{
|
|
Finch,
|
|
name: WandererApp.Finch,
|
|
pools: %{
|
|
default: [
|
|
# number of connections per pool
|
|
size: 50,
|
|
# number of pools (so total 50 connections)
|
|
count: 4
|
|
]
|
|
}
|
|
},
|
|
WandererApp.Cache,
|
|
Supervisor.child_spec({Cachex, name: :api_cache, default_ttl: :timer.hours(1)},
|
|
id: :api_cache_worker
|
|
),
|
|
Supervisor.child_spec({Cachex, name: :esi_auth_cache}, id: :esi_auth_cache_worker),
|
|
Supervisor.child_spec({Cachex, name: :system_static_info_cache},
|
|
id: :system_static_info_cache_worker
|
|
),
|
|
Supervisor.child_spec({Cachex, name: :ship_types_cache}, id: :ship_types_cache_worker),
|
|
Supervisor.child_spec({Cachex, name: :character_cache}, id: :character_cache_worker),
|
|
Supervisor.child_spec({Cachex, name: :map_cache}, id: :map_cache_worker),
|
|
Supervisor.child_spec({Cachex, name: :character_state_cache},
|
|
id: :character_state_cache_worker
|
|
),
|
|
Supervisor.child_spec({Cachex, name: :tracked_characters},
|
|
id: :tracked_characters_cache_worker
|
|
),
|
|
Supervisor.child_spec({Cachex, name: :wanderer_app_cache},
|
|
id: :wanderer_app_cache_worker
|
|
),
|
|
{Registry, keys: :unique, name: WandererApp.MapRegistry},
|
|
{Registry, keys: :unique, name: WandererApp.Character.TrackerRegistry},
|
|
{PartitionSupervisor,
|
|
child_spec: DynamicSupervisor, name: WandererApp.Map.DynamicSupervisors},
|
|
{PartitionSupervisor,
|
|
child_spec: DynamicSupervisor, name: WandererApp.Character.DynamicSupervisors},
|
|
WandererAppWeb.PresenceGracePeriodManager,
|
|
WandererAppWeb.Presence,
|
|
WandererAppWeb.Endpoint
|
|
]
|
|
|
|
# Children that should only start in non-test environments
|
|
runtime_children =
|
|
if Application.get_env(:wanderer_app, :environment) == :test do
|
|
[]
|
|
else
|
|
security_audit_children =
|
|
if Application.get_env(:wanderer_app, WandererApp.SecurityAudit, [])
|
|
|> Keyword.get(:async, false) do
|
|
[WandererApp.SecurityAudit.AsyncProcessor]
|
|
else
|
|
[]
|
|
end
|
|
|
|
[
|
|
WandererApp.Esi.InitClientsTask,
|
|
WandererApp.Scheduler,
|
|
WandererApp.Server.ServerStatusTracker,
|
|
WandererApp.Server.TheraDataFetcher,
|
|
{WandererApp.Character.TrackerPoolSupervisor, []},
|
|
WandererApp.Character.TrackerManager,
|
|
WandererApp.Map.Manager
|
|
] ++ security_audit_children
|
|
end
|
|
|
|
children =
|
|
core_children ++
|
|
runtime_children ++
|
|
maybe_start_corp_wallet_tracker(WandererApp.Env.map_subscriptions_enabled?()) ++
|
|
maybe_start_kills_services() ++
|
|
maybe_start_external_events_services()
|
|
|
|
opts = [strategy: :one_for_one, name: WandererApp.Supervisor]
|
|
|
|
Supervisor.start_link(children, opts)
|
|
|> case do
|
|
{:ok, _pid} = ok ->
|
|
# Attach telemetry handler for database pool monitoring
|
|
# :telemetry.attach(
|
|
# "wanderer-db-pool-handler",
|
|
# [:wanderer_app, :repo, :query],
|
|
# &WandererApp.Tracker.handle_pool_query/4,
|
|
# nil
|
|
# )
|
|
|
|
ok
|
|
|
|
{:error, info} = e ->
|
|
Logger.error("Failed to start application: #{inspect(info)}")
|
|
e
|
|
end
|
|
end
|
|
|
|
@impl true
|
|
def config_change(changed, _new, removed) do
|
|
WandererAppWeb.Endpoint.config_change(changed, removed)
|
|
:ok
|
|
end
|
|
|
|
defp maybe_start_corp_wallet_tracker(true),
|
|
do: [
|
|
WandererApp.StartCorpWalletTrackerTask
|
|
]
|
|
|
|
defp maybe_start_corp_wallet_tracker(_),
|
|
do: []
|
|
|
|
defp maybe_start_kills_services do
|
|
# Don't start kills services in test environment
|
|
if Application.get_env(:wanderer_app, :environment) == :test do
|
|
[]
|
|
else
|
|
wanderer_kills_enabled =
|
|
Application.get_env(:wanderer_app, :wanderer_kills_service_enabled, false)
|
|
|
|
if wanderer_kills_enabled in [true, "true"] do
|
|
Logger.info("Starting WandererKills service integration...")
|
|
|
|
[
|
|
WandererApp.Kills.Supervisor,
|
|
WandererApp.Map.ZkbDataFetcher
|
|
]
|
|
else
|
|
[]
|
|
end
|
|
end
|
|
end
|
|
|
|
defp maybe_start_external_events_services do
|
|
# Don't start external events in test environment
|
|
if Application.get_env(:wanderer_app, :environment) == :test do
|
|
[]
|
|
else
|
|
external_events_config = Application.get_env(:wanderer_app, :external_events, [])
|
|
sse_enabled = WandererApp.Env.sse_enabled?()
|
|
webhooks_enabled = external_events_config[:webhooks_enabled] || false
|
|
|
|
services = []
|
|
|
|
# Always include MapEventRelay if any external events are enabled
|
|
services =
|
|
if sse_enabled || webhooks_enabled do
|
|
Logger.info("Starting external events system...")
|
|
[WandererApp.ExternalEvents.MapEventRelay | services]
|
|
else
|
|
services
|
|
end
|
|
|
|
# Add WebhookDispatcher if webhooks are enabled
|
|
services =
|
|
if webhooks_enabled do
|
|
Logger.info("Starting webhook dispatcher...")
|
|
[WandererApp.ExternalEvents.WebhookDispatcher | services]
|
|
else
|
|
services
|
|
end
|
|
|
|
# Add SseStreamManager if SSE is enabled
|
|
services =
|
|
if sse_enabled do
|
|
Logger.info("Starting SSE stream manager...")
|
|
[WandererApp.ExternalEvents.SseStreamManager | services]
|
|
else
|
|
services
|
|
end
|
|
|
|
Enum.reverse(services)
|
|
end
|
|
end
|
|
end
|