45 lines
1.3 KiB
Elixir
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
|