defmodule Statusphere.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 = [ StatusphereWeb.Telemetry, Statusphere.Repo, {Ecto.Migrator, repos: Application.fetch_env!(:statusphere, :ecto_repos), skip: skip_migrations?()}, {DNSCluster, query: Application.get_env(:statusphere, :dns_cluster_query) || :ignore}, {Phoenix.PubSub, name: Statusphere.PubSub}, {Drinkup, %{consumer: Statusphere.Consumer}}, # Start a worker by calling: Statusphere.Worker.start_link(arg) # {Statusphere.Worker, arg}, # Start to serve requests, typically the last entry StatusphereWeb.Endpoint ] # See https://hexdocs.pm/elixir/Supervisor.html # for other strategies and supported options opts = [strategy: :one_for_one, name: Statusphere.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 StatusphereWeb.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