defmodule Shard.Application do @moduledoc """ Main Shard application. Shard is a prototype peer-to-peer comunication platform with data synchronization. """ use Application def start(_type, _args) do import Supervisor.Spec, warn: false # Define workers and child supervisors to be supervised children = [ { DynamicSupervisor, strategy: :one_for_one, name: Shard.DynamicSupervisor }, # Applications & data store Shard.Manager, # Keys & identities Shard.Keys, { Task, fn -> Shard.Keys.get_any_identity end }, # Networking SNet.TCPServer, ] # See http://elixir-lang.org/docs/stable/elixir/Supervisor.html # for other strategies and supported options opts = [strategy: :one_for_one, name: Shard.Supervisor] Supervisor.start_link(children, opts) end end