/
remote_retro.ex
42 lines (33 loc) · 1.32 KB
/
remote_retro.ex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
defmodule RemoteRetro do
use Application
require Logger
# 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(RemoteRetro.Repo, []),
# Start the endpoint when the application starts
supervisor(RemoteRetro.Endpoint, []),
supervisor(RemoteRetro.Presence, []),
# Start your own worker by calling: RemoteRetro.Worker.start_link(arg1, arg2, arg3)
# worker(RemoteRetro.Worker, [arg1, arg2, arg3]),
]
# See http://elixir-lang.org/docs/stable/elixir/Supervisor.html
# for other strategies and supported options
opts = [strategy: :one_for_one, name: RemoteRetro.Supervisor]
result = Supervisor.start_link(children, opts)
path_to_migrations = Path.join([:code.priv_dir(:remote_retro), "repo/migrations"])
Logger.info "Running migrations..."
Ecto.Migrator.run(RemoteRetro.Repo, path_to_migrations, :up, all: true)
result
end
# Tell Phoenix to update the endpoint configuration
# whenever the application is updated.
def config_change(changed, _new, removed) do
RemoteRetro.Endpoint.config_change(changed, removed)
:ok
end
end