forked from bigardone/phoenix-battleship
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 7d61b77
Showing
39 changed files
with
965 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# App artifacts | ||
/_build | ||
/db | ||
/deps | ||
/*.ez | ||
|
||
# Generate on crash by the VM | ||
erl_crash.dump | ||
|
||
# Static artifacts | ||
/node_modules | ||
|
||
# Since we are building assets from web/static, | ||
# we ignore priv/static. You may want to comment | ||
# this depending on your deployment strategy. | ||
/priv/static/ | ||
|
||
# The config/prod.secret.exs file by default contains sensitive | ||
# data and you should not commit it into version control. | ||
# | ||
# Alternatively, you may comment the line below and commit the | ||
# secrets file as long as you replace its contents by environment | ||
# variables. | ||
/config/prod.secret.exs |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
use ExGuard.Config | ||
|
||
guard("unit-test") | ||
|> command("mix test --color") | ||
|> watch(~r{\.(erl|ex|exs|eex|xrl|yrl)\z}i) | ||
|> ignore(~r/priv/) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
# Battleship | ||
|
||
To start your Phoenix app: | ||
|
||
* Install dependencies with `mix deps.get` | ||
* Install Node.js dependencies with `npm install` | ||
* Start Phoenix endpoint with `mix phoenix.server` | ||
|
||
Now you can visit [`localhost:4000`](http://localhost:4000) from your browser. | ||
|
||
Ready to run in production? Please [check our deployment guides](http://www.phoenixframework.org/docs/deployment). | ||
|
||
## Learn more | ||
|
||
* Official website: http://www.phoenixframework.org/ | ||
* Guides: http://phoenixframework.org/docs/overview | ||
* Docs: http://hexdocs.pm/phoenix | ||
* Mailing list: http://groups.google.com/group/phoenix-talk | ||
* Source: https://github.com/phoenixframework/phoenix |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
exports.config = { | ||
// See http://brunch.io/#documentation for docs. | ||
files: { | ||
javascripts: { | ||
joinTo: "js/app.js" | ||
|
||
// To use a separate vendor.js bundle, specify two files path | ||
// https://github.com/brunch/brunch/blob/stable/docs/config.md#files | ||
// joinTo: { | ||
// "js/app.js": /^(web\/static\/js)/, | ||
// "js/vendor.js": /^(web\/static\/vendor)|(deps)/ | ||
// } | ||
// | ||
// To change the order of concatenation of files, explicitly mention here | ||
// https://github.com/brunch/brunch/tree/master/docs#concatenation | ||
// order: { | ||
// before: [ | ||
// "web/static/vendor/js/jquery-2.1.1.js", | ||
// "web/static/vendor/js/bootstrap.min.js" | ||
// ] | ||
// } | ||
}, | ||
stylesheets: { | ||
joinTo: "css/app.css" | ||
}, | ||
templates: { | ||
joinTo: "js/app.js" | ||
} | ||
}, | ||
|
||
conventions: { | ||
// This option sets where we should place non-css and non-js assets in. | ||
// By default, we set this to "/web/static/assets". Files in this directory | ||
// will be copied to `paths.public`, which is "priv/static" by default. | ||
assets: /^(web\/static\/assets)/ | ||
}, | ||
|
||
// Phoenix paths configuration | ||
paths: { | ||
// Dependencies and current project directories to watch | ||
watched: [ | ||
"web/static", | ||
"test/static" | ||
], | ||
|
||
// Where to compile files to | ||
public: "priv/static" | ||
}, | ||
|
||
// Configure your plugins | ||
plugins: { | ||
babel: { | ||
// Do not use ES6 compiler in vendor code | ||
ignore: [/web\/static\/vendor/] | ||
} | ||
}, | ||
|
||
modules: { | ||
autoRequire: { | ||
"js/app.js": ["web/static/js/app"] | ||
} | ||
}, | ||
|
||
npm: { | ||
enabled: true, | ||
// Whitelist the npm deps to be pulled in as front-end assets. | ||
// All other deps in package.json will be excluded from the bundle. | ||
whitelist: ["phoenix", "phoenix_html"] | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# This file is responsible for configuring your application | ||
# and its dependencies with the aid of the Mix.Config module. | ||
# | ||
# This configuration file is loaded before any dependency and | ||
# is restricted to this project. | ||
use Mix.Config | ||
|
||
# Configures the endpoint | ||
config :battleship, Battleship.Endpoint, | ||
url: [host: "localhost"], | ||
root: Path.dirname(__DIR__), | ||
secret_key_base: "9vBUPPF+U6OIacuWP6B8OalXx+dXsWmE+GrSP0mO4WEVyUp1Q8QS/RNAOkrM3YTu", | ||
render_errors: [accepts: ~w(html json)], | ||
pubsub: [name: Battleship.PubSub, | ||
adapter: Phoenix.PubSub.PG2] | ||
|
||
# Configures Elixir's Logger | ||
config :logger, :console, | ||
format: "$time $metadata[$level] $message\n", | ||
metadata: [:request_id] | ||
|
||
# Import environment specific config. This must remain at the bottom | ||
# of this file so it overrides the configuration defined above. | ||
import_config "#{Mix.env}.exs" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
use Mix.Config | ||
|
||
# For development, we disable any cache and enable | ||
# debugging and code reloading. | ||
# | ||
# The watchers configuration can be used to run external | ||
# watchers to your application. For example, we use it | ||
# with brunch.io to recompile .js and .css sources. | ||
config :battleship, Battleship.Endpoint, | ||
http: [port: 4000], | ||
debug_errors: true, | ||
code_reloader: true, | ||
check_origin: false, | ||
watchers: [node: ["node_modules/brunch/bin/brunch", "watch", "--stdin"]] | ||
|
||
# Watch static and templates for browser reloading. | ||
config :battleship, Battleship.Endpoint, | ||
live_reload: [ | ||
patterns: [ | ||
~r{priv/static/.*(js|css|png|jpeg|jpg|gif|svg)$}, | ||
~r{priv/gettext/.*(po)$}, | ||
~r{web/views/.*(ex)$}, | ||
~r{web/templates/.*(eex)$} | ||
] | ||
] | ||
|
||
# Do not include metadata nor timestamps in development logs | ||
config :logger, :console, format: "[$level] $message\n" | ||
|
||
# Set a higher stacktrace during development. | ||
# Do not configure such in production as keeping | ||
# and calculating stacktraces is usually expensive. | ||
config :phoenix, :stacktrace_depth, 20 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
use Mix.Config | ||
|
||
# For production, we configure the host to read the PORT | ||
# from the system environment. Therefore, you will need | ||
# to set PORT=80 before running your server. | ||
# | ||
# You should also configure the url host to something | ||
# meaningful, we use this information when generating URLs. | ||
# | ||
# Finally, we also include the path to a manifest | ||
# containing the digested version of static files. This | ||
# manifest is generated by the mix phoenix.digest task | ||
# which you typically run after static files are built. | ||
config :battleship, Battleship.Endpoint, | ||
http: [port: {:system, "PORT"}], | ||
url: [host: "example.com", port: 80], | ||
cache_static_manifest: "priv/static/manifest.json" | ||
|
||
# Do not print debug messages in production | ||
config :logger, level: :info | ||
|
||
# ## SSL Support | ||
# | ||
# To get SSL working, you will need to add the `https` key | ||
# to the previous section and set your `:url` port to 443: | ||
# | ||
# config :battleship, Battleship.Endpoint, | ||
# ... | ||
# url: [host: "example.com", port: 443], | ||
# https: [port: 443, | ||
# keyfile: System.get_env("SOME_APP_SSL_KEY_PATH"), | ||
# certfile: System.get_env("SOME_APP_SSL_CERT_PATH")] | ||
# | ||
# Where those two env variables return an absolute path to | ||
# the key and cert in disk or a relative path inside priv, | ||
# for example "priv/ssl/server.key". | ||
# | ||
# We also recommend setting `force_ssl`, ensuring no data is | ||
# ever sent via http, always redirecting to https: | ||
# | ||
# config :battleship, Battleship.Endpoint, | ||
# force_ssl: [hsts: true] | ||
# | ||
# Check `Plug.SSL` for all available options in `force_ssl`. | ||
|
||
# ## Using releases | ||
# | ||
# If you are doing OTP releases, you need to instruct Phoenix | ||
# to start the server for all endpoints: | ||
# | ||
# config :phoenix, :serve_endpoints, true | ||
# | ||
# Alternatively, you can configure exactly which server to | ||
# start per endpoint: | ||
# | ||
# config :battleship, Battleship.Endpoint, server: true | ||
# | ||
# You will also need to set the application root to `.` in order | ||
# for the new static assets to be served after a hot upgrade: | ||
# | ||
# config :battleship, Battleship.Endpoint, root: "." | ||
|
||
# Finally import the config/prod.secret.exs | ||
# which should be versioned separately. | ||
import_config "prod.secret.exs" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
use Mix.Config | ||
|
||
# We don't run a server during test. If one is required, | ||
# you can enable the server option below. | ||
config :battleship, Battleship.Endpoint, | ||
http: [port: 4001], | ||
server: false | ||
|
||
# Print only warnings and errors during test | ||
config :logger, level: :warn |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
defmodule Battleship do | ||
use Application | ||
|
||
# See http://elixir-lang.org/docs/stable/elixir/Application.html | ||
# for more information on OTP Applications | ||
def start(_type, _args) do | ||
import Supervisor.Spec, warn: false | ||
|
||
children = [ | ||
# Start the endpoint when the application starts | ||
supervisor(Battleship.Endpoint, []), | ||
# Here you could define other workers and supervisors as children | ||
# worker(Battleship.Worker, [arg1, arg2, arg3]), | ||
supervisor(Battleship.Game.Supervisor, []) | ||
] | ||
|
||
# See http://elixir-lang.org/docs/stable/elixir/Supervisor.html | ||
# for other strategies and supported options | ||
opts = [strategy: :one_for_one, name: Battleship.Supervisor] | ||
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 | ||
Battleship.Endpoint.config_change(changed, removed) | ||
:ok | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
defmodule Battleship.Endpoint do | ||
use Phoenix.Endpoint, otp_app: :battleship | ||
|
||
socket "/socket", Battleship.PlayerSocket | ||
|
||
# Serve at "/" the static files from "priv/static" directory. | ||
# | ||
# You should set gzip to true if you are running phoenix.digest | ||
# when deploying your static files in production. | ||
plug Plug.Static, | ||
at: "/", from: :battleship, gzip: false, | ||
only: ~w(css fonts images js favicon.ico robots.txt) | ||
|
||
# Code reloading can be explicitly enabled under the | ||
# :code_reloader configuration of your endpoint. | ||
if code_reloading? do | ||
socket "/phoenix/live_reload/socket", Phoenix.LiveReloader.Socket | ||
plug Phoenix.LiveReloader | ||
plug Phoenix.CodeReloader | ||
end | ||
|
||
plug Plug.RequestId | ||
plug Plug.Logger | ||
|
||
plug Plug.Parsers, | ||
parsers: [:urlencoded, :multipart, :json], | ||
pass: ["*/*"], | ||
json_decoder: Poison | ||
|
||
plug Plug.MethodOverride | ||
plug Plug.Head | ||
|
||
plug Plug.Session, | ||
store: :cookie, | ||
key: "_battleship_key", | ||
signing_salt: "oqp7Nk/u" | ||
|
||
plug Battleship.Router | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
defmodule Battleship.Mixfile do | ||
use Mix.Project | ||
|
||
def project do | ||
[app: :battleship, | ||
version: "0.0.1", | ||
elixir: "~> 1.0", | ||
elixirc_paths: elixirc_paths(Mix.env), | ||
compilers: [:phoenix, :gettext] ++ Mix.compilers, | ||
build_embedded: Mix.env == :prod, | ||
start_permanent: Mix.env == :prod, | ||
deps: deps] | ||
end | ||
|
||
# Configuration for the OTP application. | ||
# | ||
# Type `mix help compile.app` for more information. | ||
def application do | ||
[mod: {Battleship, []}, | ||
applications: [:phoenix, :phoenix_html, :cowboy, :logger, :gettext]] | ||
end | ||
|
||
# Specifies which paths to compile per environment. | ||
defp elixirc_paths(:test), do: ["lib", "web", "test/support"] | ||
defp elixirc_paths(_), do: ["lib", "web"] | ||
|
||
# Specifies your project dependencies. | ||
# | ||
# Type `mix help deps` for examples and options. | ||
defp deps do | ||
[ | ||
{:phoenix, "~> 1.1.4"}, | ||
{:phoenix_html, "~> 2.4"}, | ||
{:phoenix_live_reload, "~> 1.0", only: :dev}, | ||
{:gettext, "~> 0.9"}, | ||
{:cowboy, "~> 1.0"}, | ||
{:ex_guard, "~> 0.10.0", only: :dev}, | ||
{:credo, "~> 0.3", only: [:dev, :test]} | ||
] | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
%{"bunt": {:hex, :bunt, "0.1.5"}, | ||
"cowboy": {:hex, :cowboy, "1.0.4"}, | ||
"cowlib": {:hex, :cowlib, "1.0.2"}, | ||
"credo": {:hex, :credo, "0.3.10"}, | ||
"ex_guard": {:hex, :ex_guard, "0.10.0"}, | ||
"fs": {:hex, :fs, "0.9.2"}, | ||
"gettext": {:hex, :gettext, "0.10.0"}, | ||
"phoenix": {:hex, :phoenix, "1.1.4"}, | ||
"phoenix_html": {:hex, :phoenix_html, "2.5.1"}, | ||
"phoenix_live_reload": {:hex, :phoenix_live_reload, "1.0.3"}, | ||
"plug": {:hex, :plug, "1.1.3"}, | ||
"poison": {:hex, :poison, "2.1.0"}, | ||
"ranch": {:hex, :ranch, "1.2.1"}} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
{ | ||
"repository": { | ||
}, | ||
"dependencies": { | ||
"babel-brunch": "~6.0.0", | ||
"brunch": "~2.1.3", | ||
"clean-css-brunch": "~1.8.0", | ||
"css-brunch": "~1.7.0", | ||
"javascript-brunch": "~1.8.0", | ||
"uglify-js-brunch": "~1.7.0", | ||
"phoenix": "file:deps/phoenix", | ||
"phoenix_html": "file:deps/phoenix_html" | ||
} | ||
} |
Oops, something went wrong.