code-corps/code-corps-api

View on GitHub
lib/code_corps.ex

Summary

Maintainability
Test Coverage
defmodule CodeCorps do
  @moduledoc false

  use Application

  alias CodeCorpsWeb.Endpoint

  # See http://elixir-lang.org/docs/stable/elixir/Application.html
  # for more information on OTP Applications
  def start(_type, _args) do
    import Supervisor.Spec

    # Define workers and child supervisors to be supervised
    children = [
      # Start the Ecto repository
      supervisor(CodeCorps.Repo, []),
      # Start the endpoint when the application starts
      supervisor(CodeCorpsWeb.Endpoint, []),
      # Start supervisor for any background processing we do
      supervisor(Task.Supervisor, [[name: :background_processor, restart: :transient]]),
      # Start your own worker by calling: CodeCorps.Worker.start_link(arg1, arg2, arg3)
      # worker(CodeCorps.Worker, [arg1, arg2, arg3]),
      worker(Segment, [Application.get_env(:segment, :write_key)])
    ]

    # See http://elixir-lang.org/docs/stable/elixir/Supervisor.html
    # for other strategies and supported options
    opts = [strategy: :one_for_one, name: CodeCorps.Supervisor]

    if !(Sentry.Logger in :gen_event.which_handlers(:error_logger)) do
      :ok = :error_logger.add_report_handler(Sentry.Logger)
    end

    Supervisor.start_link(children, opts)
  end

  # Tell Phoenix to update the endpoint configuration
  # whenever the application is updated.
  def config_change(changed, _new, removed) do
    Endpoint.config_change(changed, removed)
    :ok
  end
end