repo_server/lib/rl_repo/application.ex
2025-02-20 04:27:41 -06:00

45 lines
1.3 KiB
Elixir

defmodule RlRepo.Application do
# See https://hexdocs.pm/elixir/Application.html
# for more information on OTP Applications
@moduledoc false
use Application
@impl true
def start(_type, _args) do
children = [
RlRepoWeb.Telemetry,
RlRepo.Repo,
{Ecto.Migrator,
repos: Application.fetch_env!(:rl_repo, :ecto_repos),
skip: skip_migrations?()},
{DNSCluster, query: Application.get_env(:rl_repo, :dns_cluster_query) || :ignore},
{Phoenix.PubSub, name: RlRepo.PubSub},
# Start the Finch HTTP client for sending emails
{Finch, name: RlRepo.Finch},
# Start a worker by calling: RlRepo.Worker.start_link(arg)
# {RlRepo.Worker, arg},
# Start to serve requests, typically the last entry
RlRepoWeb.Endpoint
]
# See https://hexdocs.pm/elixir/Supervisor.html
# for other strategies and supported options
opts = [strategy: :one_for_one, name: RlRepo.Supervisor]
Supervisor.start_link(children, opts)
end
# Tell Phoenix to update the endpoint configuration
# whenever the application is updated.
@impl true
def config_change(changed, _new, removed) do
RlRepoWeb.Endpoint.config_change(changed, removed)
:ok
end
defp skip_migrations?() do
# By default, sqlite migrations are run when using a release
System.get_env("RELEASE_NAME") != nil
end
end