├── test
├── test_helper.exs
├── hello_web
│ ├── views
│ │ ├── page_view_test.exs
│ │ ├── layout_view_test.exs
│ │ └── error_view_test.exs
│ └── controllers
│ │ └── page_controller_test.exs
└── support
│ ├── channel_case.ex
│ └── conn_case.ex
├── rel
├── vm.args
└── config.exs
├── lib
├── hello_web
│ ├── templates
│ │ ├── page
│ │ │ └── index.html.eex
│ │ └── layout
│ │ │ └── app.html.eex
│ ├── views
│ │ ├── layout_view.ex
│ │ ├── page_view.ex
│ │ ├── error_view.ex
│ │ └── error_helpers.ex
│ ├── controllers
│ │ └── page_controller.ex
│ ├── router.ex
│ ├── channels
│ │ ├── demo_channel.ex
│ │ └── user_socket.ex
│ ├── gettext.ex
│ └── endpoint.ex
├── hello.ex
├── hello
│ ├── cards.ex
│ └── application.ex
└── hello_web.ex
├── assets
├── static
│ ├── favicon.ico
│ ├── images
│ │ └── phoenix.png
│ └── robots.txt
├── package.json
├── brunch-config.js
├── css
│ └── app.css
├── js
│ └── app.js
└── package-lock.json
├── apply-hello
├── config
├── test.exs
├── config.exs
├── dev.exs
└── prod.exs
├── .dockerignore
├── priv
└── gettext
│ ├── en
│ └── LC_MESSAGES
│ │ └── errors.po
│ └── errors.pot
├── .gitignore
├── deploy
├── cloudbuild.yml
└── k8s_template.yml
├── k8s
└── hello.yaml
├── mix.exs
├── Dockerfile
├── mix.lock
└── README.md
/test/test_helper.exs:
--------------------------------------------------------------------------------
1 | ExUnit.start()
2 |
3 |
--------------------------------------------------------------------------------
/rel/vm.args:
--------------------------------------------------------------------------------
1 | -name hello@${MY_POD_IP}
2 | -setcookie hellocookie
3 |
--------------------------------------------------------------------------------
/lib/hello_web/templates/page/index.html.eex:
--------------------------------------------------------------------------------
1 |
2 |
3 |
--------------------------------------------------------------------------------
/lib/hello_web/views/layout_view.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.LayoutView do
2 | use HelloWeb, :view
3 | end
4 |
--------------------------------------------------------------------------------
/lib/hello_web/views/page_view.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.PageView do
2 | use HelloWeb, :view
3 |
4 | end
5 |
--------------------------------------------------------------------------------
/assets/static/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/liamgriffiths/distributed-elixir-demo/HEAD/assets/static/favicon.ico
--------------------------------------------------------------------------------
/test/hello_web/views/page_view_test.exs:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.PageViewTest do
2 | use HelloWeb.ConnCase, async: true
3 | end
4 |
--------------------------------------------------------------------------------
/apply-hello:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | # apply all the kubernetes configs for the hello app
4 |
5 | kubectl apply -f ./k8s/hello.yaml
6 |
--------------------------------------------------------------------------------
/test/hello_web/views/layout_view_test.exs:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.LayoutViewTest do
2 | use HelloWeb.ConnCase, async: true
3 | end
4 |
--------------------------------------------------------------------------------
/assets/static/images/phoenix.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/liamgriffiths/distributed-elixir-demo/HEAD/assets/static/images/phoenix.png
--------------------------------------------------------------------------------
/lib/hello_web/controllers/page_controller.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.PageController do
2 | use HelloWeb, :controller
3 |
4 | def index(conn, _params) do
5 | render conn, "index.html"
6 | end
7 | end
8 |
--------------------------------------------------------------------------------
/assets/static/robots.txt:
--------------------------------------------------------------------------------
1 | # See http://www.robotstxt.org/robotstxt.html for documentation on how to use the robots.txt file
2 | #
3 | # To ban all spiders from the entire site uncomment the next two lines:
4 | # User-agent: *
5 | # Disallow: /
6 |
--------------------------------------------------------------------------------
/test/hello_web/controllers/page_controller_test.exs:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.PageControllerTest do
2 | use HelloWeb.ConnCase
3 |
4 | test "GET /", %{conn: conn} do
5 | conn = get conn, "/"
6 | assert html_response(conn, 200) =~ "Welcome to Phoenix!"
7 | end
8 | end
9 |
--------------------------------------------------------------------------------
/lib/hello.ex:
--------------------------------------------------------------------------------
1 | defmodule Hello do
2 | @moduledoc """
3 | Hello keeps the contexts that define your domain
4 | and business logic.
5 |
6 | Contexts are also responsible for managing your data, regardless
7 | if it comes from the database, an external API or others.
8 | """
9 | end
10 |
--------------------------------------------------------------------------------
/config/test.exs:
--------------------------------------------------------------------------------
1 | use Mix.Config
2 |
3 | # We don't run a server during test. If one is required,
4 | # you can enable the server option below.
5 | config :hello, HelloWeb.Endpoint,
6 | http: [port: 4001],
7 | server: false
8 |
9 | # Print only warnings and errors during test
10 | config :logger, level: :warn
11 |
--------------------------------------------------------------------------------
/.dockerignore:
--------------------------------------------------------------------------------
1 | # Ignore the following directories when doing a Docker build.
2 | # These directories will contain artifacts for local (not-in-Docker) builds,
3 | # and it is best to omit them to ensure a clean build in Docker.
4 |
5 | # Note: If you are using an umbrella app, you might need to add more
6 | # directories to this list.
7 |
8 | _build
9 | deps
10 | test
11 | assets/node_modules
12 |
--------------------------------------------------------------------------------
/priv/gettext/en/LC_MESSAGES/errors.po:
--------------------------------------------------------------------------------
1 | ## `msgid`s in this file come from POT (.pot) files.
2 | ##
3 | ## Do not add, change, or remove `msgid`s manually here as
4 | ## they're tied to the ones in the corresponding POT file
5 | ## (with the same domain).
6 | ##
7 | ## Use `mix gettext.extract --merge` or `mix gettext.merge`
8 | ## to merge POT files into PO files.
9 | msgid ""
10 | msgstr ""
11 | "Language: en\n"
12 |
--------------------------------------------------------------------------------
/priv/gettext/errors.pot:
--------------------------------------------------------------------------------
1 | ## This file is a PO Template file.
2 | ##
3 | ## `msgid`s here are often extracted from source code.
4 | ## Add new translations manually only if they're dynamic
5 | ## translations that can't be statically extracted.
6 | ##
7 | ## Run `mix gettext.extract` to bring this file up to
8 | ## date. Leave `msgstr`s empty as changing them here as no
9 | ## effect: edit them in PO (`.po`) files instead.
10 |
11 |
--------------------------------------------------------------------------------
/test/hello_web/views/error_view_test.exs:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.ErrorViewTest do
2 | use HelloWeb.ConnCase, async: true
3 |
4 | # Bring render/3 and render_to_string/3 for testing custom views
5 | import Phoenix.View
6 |
7 | test "renders 404.html" do
8 | assert render_to_string(HelloWeb.ErrorView, "404.html", []) ==
9 | "Not Found"
10 | end
11 |
12 | test "renders 500.html" do
13 | assert render_to_string(HelloWeb.ErrorView, "500.html", []) ==
14 | "Internal Server Error"
15 | end
16 | end
17 |
--------------------------------------------------------------------------------
/lib/hello_web/views/error_view.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.ErrorView do
2 | use HelloWeb, :view
3 |
4 | # If you want to customize a particular status code
5 | # for a certain format, you may uncomment below.
6 | # def render("500.html", _assigns) do
7 | # "Internal Server Error"
8 | # end
9 |
10 | # By default, Phoenix returns the status message from
11 | # the template name. For example, "404.html" becomes
12 | # "Not Found".
13 | def template_not_found(template, _assigns) do
14 | Phoenix.Controller.status_message_from_template(template)
15 | end
16 | end
17 |
--------------------------------------------------------------------------------
/lib/hello_web/router.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.Router do
2 | use HelloWeb, :router
3 |
4 | pipeline :browser do
5 | plug :accepts, ["html"]
6 | plug :fetch_session
7 | plug :fetch_flash
8 | plug :protect_from_forgery
9 | plug :put_secure_browser_headers
10 | end
11 |
12 | pipeline :api do
13 | plug :accepts, ["json"]
14 | end
15 |
16 | scope "/", HelloWeb do
17 | pipe_through :browser # Use the default browser stack
18 |
19 | get "/", PageController, :index
20 | end
21 |
22 | # Other scopes may use custom stacks.
23 | # scope "/api", HelloWeb do
24 | # pipe_through :api
25 | # end
26 | end
27 |
--------------------------------------------------------------------------------
/assets/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "repository": {},
3 | "license": "MIT",
4 | "scripts": {
5 | "deploy": "brunch build --production",
6 | "watch": "brunch watch --stdin"
7 | },
8 | "dependencies": {
9 | "phoenix": "file:../deps/phoenix",
10 | "phoenix_html": "file:../deps/phoenix_html",
11 | "react": "^16.2.0",
12 | "react-dom": "^16.2.0"
13 | },
14 | "devDependencies": {
15 | "babel": "^6.23.0",
16 | "babel-brunch": "6.1.1",
17 | "babel-preset-es2015": "^6.24.1",
18 | "babel-preset-react": "^6.24.1",
19 | "brunch": "2.10.9",
20 | "clean-css-brunch": "2.10.0",
21 | "uglify-js-brunch": "2.10.0"
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/lib/hello/cards.ex:
--------------------------------------------------------------------------------
1 | defmodule Hello.Cards do
2 |
3 | @size 5 * 5
4 |
5 | def initial do
6 | List.duplicate("222222", @size)
7 | end
8 |
9 | def start_link(state) do
10 | case Agent.start_link(fn -> state end, name: {:global, __MODULE__}) do
11 | {:ok, pid} ->
12 | {:ok, pid}
13 | {:error, {:already_started, pid}} ->
14 | {:ok, pid}
15 | end
16 | end
17 |
18 | def get do
19 | Agent.get({:global, __MODULE__}, fn state -> state end)
20 | end
21 |
22 | def update(index, next) do
23 | Agent.update({:global, __MODULE__}, fn state ->
24 | List.replace_at(state, index, next)
25 | end)
26 | end
27 | end
28 |
--------------------------------------------------------------------------------
/lib/hello_web/channels/demo_channel.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.DemoChannel do
2 | use Phoenix.Channel
3 | require Logger
4 |
5 | def join("demo:hello", _message, socket) do
6 | send(self(), {:new_connection, %{}})
7 | {:ok, socket}
8 | end
9 |
10 | def handle_info({:new_connection, _msg}, socket) do
11 | cards = Hello.Cards.get()
12 | push(socket, "cards:state", %{data: cards})
13 | {:noreply, socket}
14 | end
15 |
16 | def handle_in("cards:change", %{"index" => index, "color" => color}, socket) do
17 | Hello.Cards.update(index, color)
18 | broadcast!(socket, "cards:change", %{ index: index, color: color })
19 | {:noreply, socket}
20 | end
21 | end
22 |
--------------------------------------------------------------------------------
/lib/hello_web/templates/layout/app.html.eex:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 | hello hello
11 | ">
12 |
13 |
14 |
15 |
16 | <%= render @view_module, @view_template, assigns %>
17 |
18 |
19 |
20 |
21 |
22 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # App artifacts
2 | /_build
3 | /db
4 | /deps
5 | /*.ez
6 |
7 | # Generated on crash by the VM
8 | erl_crash.dump
9 |
10 | # Generated on crash by NPM
11 | npm-debug.log
12 |
13 | # Static artifacts
14 | /assets/node_modules
15 |
16 | # Since we are building assets from assets/,
17 | # we ignore priv/static. You may want to comment
18 | # this depending on your deployment strategy.
19 | /priv/static/
20 |
21 | # Files matching config/*.secret.exs pattern contain sensitive
22 | # data and you should not commit them into version control.
23 | #
24 | # Alternatively, you may comment the line below and commit the
25 | # secrets files as long as you replace their contents by environment
26 | # variables.
27 | /config/*.secret.exs
--------------------------------------------------------------------------------
/deploy/cloudbuild.yml:
--------------------------------------------------------------------------------
1 | steps:
2 | - name: 'gcr.io/cloud-builders/docker'
3 | args: ["build", "-t", "gcr.io/distributed-elixir-demo/hello:$REVISION_ID", "."]
4 |
5 | - name: 'gcr.io/cloud-builders/docker'
6 | args: ["push", "gcr.io/distributed-elixir-demo/hello:$REVISION_ID"]
7 |
8 | - name: 'alpine'
9 | entrypoint: 'sh'
10 | args:
11 | - '-c'
12 | - |
13 | (echo "cat < k8s.yml
14 |
15 | - name: 'gcr.io/cloud-builders/kubectl'
16 | args: ["apply", "-f", "k8s.yml"]
17 | env:
18 | - 'CLOUDSDK_COMPUTE_ZONE=us-central1-a'
19 | - 'CLOUDSDK_CONTAINER_CLUSTER=hello-cluster'
20 |
--------------------------------------------------------------------------------
/lib/hello_web/gettext.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.Gettext do
2 | @moduledoc """
3 | A module providing Internationalization with a gettext-based API.
4 |
5 | By using [Gettext](https://hexdocs.pm/gettext),
6 | your module gains a set of macros for translations, for example:
7 |
8 | import HelloWeb.Gettext
9 |
10 | # Simple translation
11 | gettext "Here is the string to translate"
12 |
13 | # Plural translation
14 | ngettext "Here is the string to translate",
15 | "Here are the strings to translate",
16 | 3
17 |
18 | # Domain-based translation
19 | dgettext "errors", "Here is the error message to translate"
20 |
21 | See the [Gettext Docs](https://hexdocs.pm/gettext) for detailed usage.
22 | """
23 | use Gettext, otp_app: :hello
24 | end
25 |
--------------------------------------------------------------------------------
/test/support/channel_case.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.ChannelCase do
2 | @moduledoc """
3 | This module defines the test case to be used by
4 | channel tests.
5 |
6 | Such tests rely on `Phoenix.ChannelTest` and also
7 | import other functionality to make it easier
8 | to build common datastructures and query the data layer.
9 |
10 | Finally, if the test case interacts with the database,
11 | it cannot be async. For this reason, every test runs
12 | inside a transaction which is reset at the beginning
13 | of the test unless the test case is marked as async.
14 | """
15 |
16 | use ExUnit.CaseTemplate
17 |
18 | using do
19 | quote do
20 | # Import conveniences for testing with channels
21 | use Phoenix.ChannelTest
22 |
23 | # The default endpoint for testing
24 | @endpoint HelloWeb.Endpoint
25 | end
26 | end
27 |
28 |
29 | setup _tags do
30 | :ok
31 | end
32 |
33 | end
34 |
--------------------------------------------------------------------------------
/config/config.exs:
--------------------------------------------------------------------------------
1 | # This file is responsible for configuring your application
2 | # and its dependencies with the aid of the Mix.Config module.
3 | #
4 | # This configuration file is loaded before any dependency and
5 | # is restricted to this project.
6 | use Mix.Config
7 |
8 | # Configures the endpoint
9 | config :hello, HelloWeb.Endpoint,
10 | url: [host: "localhost"],
11 | secret_key_base: "ADCarnF2URllg1IvUf5P/DROZlAvoX/nfx394TmC9qXqurS8J116sUtpSrTikmU7",
12 | render_errors: [view: HelloWeb.ErrorView, accepts: ~w(html json)],
13 | pubsub: [name: Hello.PubSub,
14 | adapter: Phoenix.PubSub.PG2]
15 |
16 | # Configures Elixir's Logger
17 | config :logger, :console,
18 | format: "$time $metadata[$level] $message\n",
19 | metadata: [:user_id]
20 |
21 | # Import environment specific config. This must remain at the bottom
22 | # of this file so it overrides the configuration defined above.
23 | import_config "#{Mix.env}.exs"
24 |
--------------------------------------------------------------------------------
/test/support/conn_case.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.ConnCase do
2 | @moduledoc """
3 | This module defines the test case to be used by
4 | tests that require setting up a connection.
5 |
6 | Such tests rely on `Phoenix.ConnTest` and also
7 | import other functionality to make it easier
8 | to build common datastructures and query the data layer.
9 |
10 | Finally, if the test case interacts with the database,
11 | it cannot be async. For this reason, every test runs
12 | inside a transaction which is reset at the beginning
13 | of the test unless the test case is marked as async.
14 | """
15 |
16 | use ExUnit.CaseTemplate
17 |
18 | using do
19 | quote do
20 | # Import conveniences for testing with connections
21 | use Phoenix.ConnTest
22 | import HelloWeb.Router.Helpers
23 |
24 | # The default endpoint for testing
25 | @endpoint HelloWeb.Endpoint
26 | end
27 | end
28 |
29 |
30 | setup _tags do
31 | {:ok, conn: Phoenix.ConnTest.build_conn()}
32 | end
33 |
34 | end
35 |
--------------------------------------------------------------------------------
/deploy/k8s_template.yml:
--------------------------------------------------------------------------------
1 | apiVersion: v1
2 | kind: Namespace
3 | metadata:
4 | name: hello
5 | ---
6 | apiVersion: extensions/v1beta1
7 | kind: Deployment
8 | metadata:
9 | name: app
10 | namespace: hello
11 | spec:
12 | replicas: 2
13 | template:
14 | metadata:
15 | labels:
16 | app: hello
17 | spec:
18 | containers:
19 | - name: hello
20 | image: $IMAGE
21 | ports:
22 | - containerPort: 8080
23 | env:
24 | - name: MY_POD_IP
25 | valueFrom:
26 | fieldRef:
27 | fieldPath: status.podIP
28 | ---
29 | apiVersion: v1
30 | kind: Service
31 | metadata:
32 | name: web
33 | namespace: hello
34 | spec:
35 | ports:
36 | - port: 80
37 | targetPort: 8080
38 | protocol: TCP
39 | name: http
40 | selector:
41 | app: hello
42 | type: LoadBalancer
43 | ---
44 | apiVersion: v1
45 | kind: Service
46 | metadata:
47 | name: headless-service
48 | namespace: hello
49 | spec:
50 | ports:
51 | - port: 7777
52 | selector:
53 | app: hello
54 | clusterIP: None
55 |
--------------------------------------------------------------------------------
/lib/hello/application.ex:
--------------------------------------------------------------------------------
1 | defmodule Hello.Application do
2 | use Application
3 |
4 | # See https://hexdocs.pm/elixir/Application.html
5 | # for more information on OTP Applications
6 | def start(_type, _args) do
7 | import Supervisor.Spec
8 |
9 | # Define workers and child supervisors to be supervised
10 | children = [
11 | # Start the endpoint when the application starts
12 | supervisor(HelloWeb.Endpoint, []),
13 | # Start your own worker by calling: Hello.Worker.start_link(arg0, arg2, arg3)
14 | # worker(Hello.Worker, [arg1, arg2, arg3]),
15 | worker(Hello.Cards, [Hello.Cards.initial()])
16 | ]
17 |
18 | # See https://hexdocs.pm/elixir/Supervisor.html
19 | # for other strategies and supported options
20 | opts = [strategy: :one_for_one, name: Hello.Supervisor]
21 | Supervisor.start_link(children, opts)
22 | end
23 |
24 | # Tell Phoenix to update the endpoint configuration
25 | # whenever the application is updated.
26 | def config_change(changed, _new, removed) do
27 | HelloWeb.Endpoint.config_change(changed, removed)
28 | :ok
29 | end
30 | end
31 |
--------------------------------------------------------------------------------
/k8s/hello.yaml:
--------------------------------------------------------------------------------
1 | apiVersion: v1
2 | kind: Namespace
3 | metadata:
4 | name: hello
5 | ---
6 | apiVersion: extensions/v1beta1
7 | kind: Deployment
8 | metadata:
9 | name: app
10 | namespace: hello
11 | spec:
12 | replicas: 2
13 | template:
14 | metadata:
15 | labels:
16 | app: hello
17 | spec:
18 | containers:
19 | - name: hello
20 | image: liamgriffiths/hello:18
21 | ports:
22 | - containerPort: 8080
23 | env:
24 | - name: MY_POD_IP
25 | valueFrom:
26 | fieldRef:
27 | fieldPath: status.podIP
28 | ---
29 | apiVersion: v1
30 | kind: Service
31 | metadata:
32 | name: web
33 | namespace: hello
34 | spec:
35 | ports:
36 | - port: 6000
37 | targetPort: 8080
38 | protocol: TCP
39 | name: http
40 | selector:
41 | app: hello
42 | type: LoadBalancer
43 | ---
44 | apiVersion: v1
45 | kind: Service
46 | metadata:
47 | name: headless-service
48 | namespace: hello
49 | spec:
50 | ports:
51 | - port: 7777
52 | selector:
53 | app: hello
54 | clusterIP: None
55 |
--------------------------------------------------------------------------------
/mix.exs:
--------------------------------------------------------------------------------
1 | defmodule Hello.Mixfile do
2 | use Mix.Project
3 |
4 | def project do
5 | [
6 | app: :hello,
7 | version: "0.0.1",
8 | elixir: "~> 1.4",
9 | elixirc_paths: elixirc_paths(Mix.env()),
10 | compilers: [:phoenix, :gettext] ++ Mix.compilers(),
11 | start_permanent: Mix.env() == :prod,
12 | deps: deps()
13 | ]
14 | end
15 |
16 | # Configuration for the OTP application.
17 | #
18 | # Type `mix help compile.app` for more information.
19 | def application do
20 | [
21 | mod: {Hello.Application, []},
22 | extra_applications: [:logger, :runtime_tools, :peerage]
23 | ]
24 | end
25 |
26 | # Specifies which paths to compile per environment.
27 | defp elixirc_paths(:test), do: ["lib", "test/support"]
28 | defp elixirc_paths(_), do: ["lib"]
29 |
30 | # Specifies your project dependencies.
31 | #
32 | # Type `mix help deps` for examples and options.
33 | defp deps do
34 | [
35 | {:phoenix, "~> 1.3.2"},
36 | {:phoenix_pubsub, "~> 1.0"},
37 | {:phoenix_html, "~> 2.10"},
38 | {:phoenix_live_reload, "~> 1.0", only: :dev},
39 | {:gettext, "~> 0.11"},
40 | {:cowboy, "~> 1.0"},
41 | {:distillery, "~> 1.5"},
42 | {:peerage, "~> 1.0.2"}
43 | ]
44 | end
45 | end
46 |
--------------------------------------------------------------------------------
/lib/hello_web/channels/user_socket.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.UserSocket do
2 | use Phoenix.Socket
3 |
4 | ## Channels
5 | channel "demo:*", HelloWeb.DemoChannel
6 |
7 | ## Transports
8 | transport :websocket, Phoenix.Transports.WebSocket
9 | # transport :longpoll, Phoenix.Transports.LongPoll
10 |
11 | # Socket params are passed from the client and can
12 | # be used to verify and authenticate a user. After
13 | # verification, you can put default assigns into
14 | # the socket that will be set for all channels, ie
15 | #
16 | # {:ok, assign(socket, :user_id, verified_user_id)}
17 | #
18 | # To deny connection, return `:error`.
19 | #
20 | # See `Phoenix.Token` documentation for examples in
21 | # performing token verification on connect.
22 | def connect(_params, socket) do
23 | {:ok, socket}
24 | end
25 |
26 | # Socket id's are topics that allow you to identify all sockets for a given user:
27 | #
28 | # def id(socket), do: "user_socket:#{socket.assigns.user_id}"
29 | #
30 | # Would allow you to broadcast a "disconnect" event and terminate
31 | # all active sockets and channels for a given user:
32 | #
33 | # HelloWeb.Endpoint.broadcast("user_socket:#{user.id}", "disconnect", %{})
34 | #
35 | # Returning `nil` makes this socket anonymous.
36 | def id(_socket), do: nil
37 | end
38 |
--------------------------------------------------------------------------------
/lib/hello_web/views/error_helpers.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.ErrorHelpers do
2 | @moduledoc """
3 | Conveniences for translating and building error messages.
4 | """
5 |
6 | use Phoenix.HTML
7 |
8 | @doc """
9 | Generates tag for inlined form input errors.
10 | """
11 | def error_tag(form, field) do
12 | Enum.map(Keyword.get_values(form.errors, field), fn (error) ->
13 | content_tag :span, translate_error(error), class: "help-block"
14 | end)
15 | end
16 |
17 | @doc """
18 | Translates an error message using gettext.
19 | """
20 | def translate_error({msg, opts}) do
21 | # When using gettext, we typically pass the strings we want
22 | # to translate as a static argument:
23 | #
24 | # # Translate "is invalid" in the "errors" domain
25 | # dgettext "errors", "is invalid"
26 | #
27 | # # Translate the number of files with plural rules
28 | # dngettext "errors", "1 file", "%{count} files", count
29 | #
30 | # Because the error messages we show in our forms and APIs
31 | # are defined inside Ecto, we need to translate them dynamically.
32 | # This requires us to call the Gettext module passing our gettext
33 | # backend as first argument.
34 | #
35 | # Note we use the "errors" domain, which means translations
36 | # should be written to the errors.po file. The :count option is
37 | # set by Ecto and indicates we should also apply plural rules.
38 | if count = opts[:count] do
39 | Gettext.dngettext(HelloWeb.Gettext, "errors", msg, msg, count, opts)
40 | else
41 | Gettext.dgettext(HelloWeb.Gettext, "errors", msg, opts)
42 | end
43 | end
44 | end
45 |
--------------------------------------------------------------------------------
/assets/brunch-config.js:
--------------------------------------------------------------------------------
1 | exports.config = {
2 | // See http://brunch.io/#documentation for docs.
3 | files: {
4 | javascripts: {
5 | joinTo: "js/app.js"
6 |
7 | // To use a separate vendor.js bundle, specify two files path
8 | // http://brunch.io/docs/config#-files-
9 | // joinTo: {
10 | // "js/app.js": /^js/,
11 | // "js/vendor.js": /^(?!js)/
12 | // }
13 | //
14 | // To change the order of concatenation of files, explicitly mention here
15 | // order: {
16 | // before: [
17 | // "vendor/js/jquery-2.1.1.js",
18 | // "vendor/js/bootstrap.min.js"
19 | // ]
20 | // }
21 | },
22 | stylesheets: {
23 | joinTo: "css/app.css"
24 | },
25 | templates: {
26 | joinTo: "js/app.js"
27 | }
28 | },
29 |
30 | conventions: {
31 | // This option sets where we should place non-css and non-js assets in.
32 | // By default, we set this to "/assets/static". Files in this directory
33 | // will be copied to `paths.public`, which is "priv/static" by default.
34 | assets: /^(static)/
35 | },
36 |
37 | // Phoenix paths configuration
38 | paths: {
39 | // Dependencies and current project directories to watch
40 | watched: ["static", "css", "js", "vendor"],
41 | // Where to compile files to
42 | public: "../priv/static"
43 | },
44 |
45 | // Configure your plugins
46 | plugins: {
47 | babel: {
48 | // Do not use ES6 compiler in vendor code
49 | ignore: [/vendor/],
50 | presets: [ "es2015", "react" ]
51 | }
52 | },
53 |
54 | modules: {
55 | autoRequire: {
56 | "js/app.js": ["js/app"]
57 | }
58 | },
59 |
60 | npm: {
61 | enabled: true,
62 | whitelist: ["phoenix", "phoenix_html", "react", "react-dom", "redux", "react-redux"]
63 | }
64 | };
65 |
--------------------------------------------------------------------------------
/lib/hello_web.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb do
2 | @moduledoc """
3 | The entrypoint for defining your web interface, such
4 | as controllers, views, channels and so on.
5 |
6 | This can be used in your application as:
7 |
8 | use HelloWeb, :controller
9 | use HelloWeb, :view
10 |
11 | The definitions below will be executed for every view,
12 | controller, etc, so keep them short and clean, focused
13 | on imports, uses and aliases.
14 |
15 | Do NOT define functions inside the quoted expressions
16 | below. Instead, define any helper function in modules
17 | and import those modules here.
18 | """
19 |
20 | def controller do
21 | quote do
22 | use Phoenix.Controller, namespace: HelloWeb
23 | import Plug.Conn
24 | import HelloWeb.Router.Helpers
25 | import HelloWeb.Gettext
26 | end
27 | end
28 |
29 | def view do
30 | quote do
31 | use Phoenix.View, root: "lib/hello_web/templates",
32 | namespace: HelloWeb
33 |
34 | # Import convenience functions from controllers
35 | import Phoenix.Controller, only: [get_flash: 2, view_module: 1]
36 |
37 | # Use all HTML functionality (forms, tags, etc)
38 | use Phoenix.HTML
39 |
40 | import HelloWeb.Router.Helpers
41 | import HelloWeb.ErrorHelpers
42 | import HelloWeb.Gettext
43 | end
44 | end
45 |
46 | def router do
47 | quote do
48 | use Phoenix.Router
49 | import Plug.Conn
50 | import Phoenix.Controller
51 | end
52 | end
53 |
54 | def channel do
55 | quote do
56 | use Phoenix.Channel
57 | import HelloWeb.Gettext
58 | end
59 | end
60 |
61 | @doc """
62 | When used, dispatch to the appropriate controller/view/etc.
63 | """
64 | defmacro __using__(which) when is_atom(which) do
65 | apply(__MODULE__, which, [])
66 | end
67 | end
68 |
--------------------------------------------------------------------------------
/lib/hello_web/endpoint.ex:
--------------------------------------------------------------------------------
1 | defmodule HelloWeb.Endpoint do
2 | use Phoenix.Endpoint, otp_app: :hello
3 |
4 | socket "/socket", HelloWeb.UserSocket
5 |
6 | # Serve at "/" the static files from "priv/static" directory.
7 | #
8 | # You should set gzip to true if you are running phoenix.digest
9 | # when deploying your static files in production.
10 | plug Plug.Static,
11 | at: "/", from: :hello, gzip: false,
12 | only: ~w(css fonts images js favicon.ico robots.txt)
13 |
14 | # Code reloading can be explicitly enabled under the
15 | # :code_reloader configuration of your endpoint.
16 | if code_reloading? do
17 | socket "/phoenix/live_reload/socket", Phoenix.LiveReloader.Socket
18 | plug Phoenix.LiveReloader
19 | plug Phoenix.CodeReloader
20 | end
21 |
22 | plug Plug.Logger
23 |
24 | plug Plug.Parsers,
25 | parsers: [:urlencoded, :multipart, :json],
26 | pass: ["*/*"],
27 | json_decoder: Poison
28 |
29 | plug Plug.MethodOverride
30 | plug Plug.Head
31 |
32 | # The session will be stored in the cookie and signed,
33 | # this means its contents can be read but not tampered with.
34 | # Set :encryption_salt if you would also like to encrypt it.
35 | plug Plug.Session,
36 | store: :cookie,
37 | key: "_hello_key",
38 | signing_salt: "9MH8nX/2"
39 |
40 | plug HelloWeb.Router
41 |
42 | @doc """
43 | Callback invoked for dynamically configuring the endpoint.
44 |
45 | It receives the endpoint configuration and checks if
46 | configuration should be loaded from the system environment.
47 | """
48 | def init(_key, config) do
49 | if config[:load_from_system_env] do
50 | port = System.get_env("PORT") || raise "expected the PORT environment variable to be set"
51 | {:ok, Keyword.put(config, :http, [:inet6, port: port])}
52 | else
53 | {:ok, config}
54 | end
55 | end
56 | end
57 |
--------------------------------------------------------------------------------
/config/dev.exs:
--------------------------------------------------------------------------------
1 | use Mix.Config
2 |
3 | # For development, we disable any cache and enable
4 | # debugging and code reloading.
5 | #
6 | # The watchers configuration can be used to run external
7 | # watchers to your application. For example, we use it
8 | # with brunch.io to recompile .js and .css sources.
9 | config :hello, HelloWeb.Endpoint,
10 | http: [port: 4000],
11 | debug_errors: true,
12 | code_reloader: true,
13 | check_origin: false,
14 | watchers: [node: ["node_modules/brunch/bin/brunch", "watch", "--stdin",
15 | cd: Path.expand("../assets", __DIR__)]]
16 |
17 | config :peerage, via: Peerage.Via.Self
18 |
19 | # ## SSL Support
20 | #
21 | # In order to use HTTPS in development, a self-signed
22 | # certificate can be generated by running the following
23 | # command from your terminal:
24 | #
25 | # openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 -subj "/C=US/ST=Denial/L=Springfield/O=Dis/CN=www.example.com" -keyout priv/server.key -out priv/server.pem
26 | #
27 | # The `http:` config above can be replaced with:
28 | #
29 | # https: [port: 4000, keyfile: "priv/server.key", certfile: "priv/server.pem"],
30 | #
31 | # If desired, both `http:` and `https:` keys can be
32 | # configured to run both http and https servers on
33 | # different ports.
34 |
35 | # Watch static and templates for browser reloading.
36 | config :hello, HelloWeb.Endpoint,
37 | live_reload: [
38 | patterns: [
39 | ~r{priv/static/.*(js|css|png|jpeg|jpg|gif|svg)$},
40 | ~r{priv/gettext/.*(po)$},
41 | ~r{lib/hello_web/views/.*(ex)$},
42 | ~r{lib/hello_web/templates/.*(eex)$}
43 | ]
44 | ]
45 |
46 | # Do not include metadata nor timestamps in development logs
47 | config :logger, level: :info
48 |
49 | # Set a higher stacktrace during development. Avoid configuring such
50 | # in production as building large stacktraces may be expensive.
51 | config :phoenix, :stacktrace_depth, 20
52 |
--------------------------------------------------------------------------------
/assets/css/app.css:
--------------------------------------------------------------------------------
1 | /* This file is for your main application css. */
2 | body {
3 | background: papayawhip;
4 | padding: 0;
5 | margin: 0;
6 | font-family: "SF Mono", "Droid Sans Mono", "Source Code Pro", monospace;
7 | }
8 |
9 | input {
10 | display: none;
11 | }
12 |
13 | .App {
14 | position: relative;
15 | }
16 |
17 | .Info {
18 | position: absolute;
19 | top: 0;
20 | left: 0;
21 | padding: 10px;
22 | color: #fff;
23 | background: #222;
24 | opacity: 0.8;
25 | }
26 |
27 | .--cards {
28 | display: grid;
29 | grid-template-columns: repeat(5, 1fr);
30 | grid-gap: 1vw;
31 | grid-auto-rows: minmax(100px, auto);
32 |
33 | height: 50vw;
34 | width: 50vw;
35 |
36 | position: absolute;
37 | left: 0;
38 | top: 5vw;
39 | right: 0;
40 | margin: auto auto;
41 |
42 | }
43 |
44 | .Card {
45 | perspective: 1000px;
46 | transform-style: preserve-3d;
47 | cursor: pointer;
48 | }
49 |
50 | .Card .--sides {
51 | position: relative;
52 | height: 100%;
53 | width: 100%;
54 | transform-style: preserve-3d;
55 | transition: all 500ms;
56 | z-index: 20;
57 | /** figure out how to -not- display shadow at top when checked */
58 | box-shadow: 1px 3px 3px rgba(20,20,20,.2);
59 | }
60 |
61 | .Card .--sides div {
62 | position: absolute;
63 | height: 100%;
64 | width: 100%;
65 | /* backface-visibility: hidden; */
66 | border-radius: 2px;
67 | }
68 |
69 | .Card .--sides .--front {
70 | transform: rotateX(180deg);
71 | }
72 |
73 | .Card .--sides .--back {
74 | transform: rotateX(180deg);
75 | }
76 |
77 | .Card:hover .--sides,
78 | .Card:active .--sides,
79 | .Card:focus .--sides {
80 | transform: rotateX(20deg);
81 | box-shadow: 0 12px 12px rgba(20,20,20,.2);
82 | }
83 |
84 | :checked + .--sides {
85 | transform: rotateX(180deg);
86 | }
87 |
88 | .Card:hover :checked + .--sides,
89 | .Card:active :checked + .--sides,
90 | .Card:focus :checked + .--sides {
91 | transform: rotateX(160deg);
92 | }
93 |
94 | .Info {
95 | }
96 |
--------------------------------------------------------------------------------
/rel/config.exs:
--------------------------------------------------------------------------------
1 | # Import all plugins from `rel/plugins`
2 | # They can then be used by adding `plugin MyPlugin` to
3 | # either an environment, or release definition, where
4 | # `MyPlugin` is the name of the plugin module.
5 | Path.join(["rel", "plugins", "*.exs"])
6 | |> Path.wildcard()
7 | |> Enum.map(&Code.eval_file(&1))
8 |
9 | use Mix.Releases.Config,
10 | # This sets the default release built by `mix release`
11 | default_release: :default,
12 | # This sets the default environment used by `mix release`
13 | default_environment: Mix.env()
14 |
15 | # For a full list of config options for both releases
16 | # and environments, visit https://hexdocs.pm/distillery/configuration.html
17 |
18 |
19 | # You may define one or more environments in this file,
20 | # an environment's settings will override those of a release
21 | # when building in that environment, this combination of release
22 | # and environment configuration is called a profile
23 |
24 | environment :dev do
25 | # If you are running Phoenix, you should make sure that
26 | # server: true is set and the code reloader is disabled,
27 | # even in dev mode.
28 | # It is recommended that you build with MIX_ENV=prod and pass
29 | # the --env flag to Distillery explicitly if you want to use
30 | # dev mode.
31 | set dev_mode: true
32 | set include_erts: false
33 | set cookie: :"=1!B03$E/mWifd4]5(Y?RG79s4;,9UI:EL=r3xiTB{T@_>kv/0F(Po&41B53/HH]"
34 | end
35 |
36 | environment :prod do
37 | set include_erts: true
38 | set include_src: false
39 | set cookie: :"E%laaP/v.xb5EWpK(:GIt3|z/Fe)&StMks4KdBARt{tcV/UqAJ_nw=vlKO;)F%l7"
40 | set vm_args: "rel/vm.args"
41 | end
42 |
43 | # You may define one or more releases in this file.
44 | # If you have not set a default release, or selected one
45 | # when running `mix release`, the first release in the file
46 | # will be used by default
47 |
48 | release :hello do
49 | set version: current_version(:hello)
50 | set applications: [
51 | :runtime_tools
52 | ]
53 | end
54 |
--------------------------------------------------------------------------------
/config/prod.exs:
--------------------------------------------------------------------------------
1 | use Mix.Config
2 |
3 | # For production, we often load configuration from external
4 | # sources, such as your system environment. For this reason,
5 | # you won't find the :http configuration below, but set inside
6 | # HelloWeb.Endpoint.init/2 when load_from_system_env is
7 | # true. Any dynamic configuration should be done there.
8 | #
9 | # Don't forget to configure the url host to something meaningful,
10 | # Phoenix uses this information when generating URLs.
11 | #
12 | # Finally, we also include the path to a cache manifest
13 | # containing the digested version of static files. This
14 | # manifest is generated by the mix phx.digest task
15 | # which you typically run after static files are built.
16 | config :hello, HelloWeb.Endpoint,
17 | load_from_system_env: true,
18 | http: [port: "${PORT}"],
19 | check_origin: false,
20 | server: true,
21 | root: ".",
22 | cache_static_manifest: "priv/static/cache_manifest.json"
23 |
24 | # Do not print debug messages in production
25 | config :logger, level: :info
26 |
27 | config :peerage, via: Peerage.Via.Dns,
28 | dns_name: "headless-service.hello.svc.cluster.local",
29 | app_name: "hello",
30 | interval: 1
31 |
32 | # ## SSL Support
33 | #
34 | # To get SSL working, you will need to add the `https` key
35 | # to the previous section and set your `:url` port to 443:
36 | #
37 | # config :hello, HelloWeb.Endpoint,
38 | # ...
39 | # url: [host: "example.com", port: 443],
40 | # https: [:inet6,
41 | # port: 443,
42 | # keyfile: System.get_env("SOME_APP_SSL_KEY_PATH"),
43 | # certfile: System.get_env("SOME_APP_SSL_CERT_PATH")]
44 | #
45 | # Where those two env variables return an absolute path to
46 | # the key and cert in disk or a relative path inside priv,
47 | # for example "priv/ssl/server.key".
48 | #
49 | # We also recommend setting `force_ssl`, ensuring no data is
50 | # ever sent via http, always redirecting to https:
51 | #
52 | # config :hello, HelloWeb.Endpoint,
53 | # force_ssl: [hsts: true]
54 | #
55 | # Check `Plug.SSL` for all available options in `force_ssl`.
56 |
57 | # ## Using releases
58 | #
59 | # If you are doing OTP releases, you need to instruct Phoenix
60 | # to start the server for all endpoints:
61 | #
62 | # config :phoenix, :serve_endpoints, true
63 | #
64 | # Alternatively, you can configure exactly which server to
65 | # start per endpoint:
66 | #
67 | # config :hello, HelloWeb.Endpoint, server: true
68 | #
69 |
--------------------------------------------------------------------------------
/assets/js/app.js:
--------------------------------------------------------------------------------
1 | // @flow
2 | import "phoenix_html"
3 | import React from "react"
4 | import ReactDOM from "react-dom"
5 | import {Socket} from "phoenix"
6 |
7 | alert('hello')
8 |
9 | const COLORS = [
10 | 'c4e899',
11 | '95d7a4',
12 | '69b18f',
13 | '307e80',
14 | '034262',
15 | 'ff7575',
16 | 'ff8775',
17 | 'ffba79',
18 | 'ffcb71',
19 | '292e32',
20 | 'cccccc',
21 | '7aa0c4',
22 | '34568f',
23 | '2f425e',
24 | 'f0f7ce',
25 | 'bbeaaa',
26 | '9fdda5',
27 | 'f59ba5',
28 | 'f87d92',
29 | ]
30 |
31 | const randColor = () => COLORS[Math.floor(Math.random()*COLORS.length)]
32 | const randIndex = () => Math.floor(Math.random() * 25)
33 |
34 | type Props = {
35 | }
36 |
37 | type State = {
38 | image: Array
39 | }
40 |
41 | class App extends React.Component {
42 | constructor(props) {
43 | super(props)
44 |
45 | this.color = randColor()
46 | document.querySelector('body').style.background = '#' + this.color + 'ee'
47 |
48 | this.cardRefs = []
49 |
50 | this.state = {
51 | cards: []
52 | }
53 |
54 | }
55 |
56 | componentDidMount() {
57 | const socket = new Socket("/socket", {params: {}})
58 | socket.connect()
59 | this.channel = socket.channel("demo:hello", {})
60 |
61 | this.channel.join()
62 | .receive("ok", (res) => {
63 | console.log('joined!', res)
64 | })
65 | .receive("error", (res) => {
66 | console.log('error joining', res)
67 | })
68 |
69 | this.channel.on("cards:state", ({ data }) => {
70 | this.setState({ cards: data })
71 | })
72 |
73 | this.channel.on("cards:change", ({ index, color }) => {
74 | const cards = this.state.cards
75 | cards[index] = color
76 | this.setState({ cards })
77 |
78 | if (this.color !== color) {
79 | this.cardRefs[index].checked = !this.cardRefs[index].checked
80 | }
81 | })
82 | }
83 |
84 | handleClick(e, index) {
85 | if (e.target.type === 'checkbox') {
86 | this.channel.push("cards:change", { index, color: this.color })
87 | }
88 | }
89 |
90 | render() {
91 | const cards = this.state.cards.map((color, i) => {
92 | return (
93 | this.cardRefs[i] = c }
97 | onClick={(e) => this.handleClick(e, i)} />
98 | )
99 | })
100 |
101 | return (
102 |
103 |
104 | { cards }
105 |
106 |
107 | )
108 | }
109 | }
110 |
111 | const Card = (props: { reffn: *, colors: [string, string], onClick: * }) => {
112 | return (
113 |
120 | )
121 | };
122 |
123 | ReactDOM.render(, document.getElementById('root'))
124 |
125 | window.makeRobot = () => {
126 | const socket = new Socket("/socket", {params: {}})
127 | socket.connect()
128 | const channel = socket.channel("demo:hello", {})
129 | channel.join()
130 | const color = randColor()
131 | setInterval(() => {
132 | channel.push("cards:change", { index: randIndex(), color })
133 | }, 1000);
134 | }
135 |
--------------------------------------------------------------------------------
/Dockerfile:
--------------------------------------------------------------------------------
1 | # Copyright 2017 Google Inc.
2 | #
3 | # Licensed under the Apache License, Version 2.0 (the "License");
4 | # you may not use this file except in compliance with the License.
5 | # You may obtain a copy of the License at
6 | #
7 | # http://www.apache.org/licenses/LICENSE-2.0
8 | #
9 | # Unless required by applicable law or agreed to in writing, software
10 | # distributed under the License is distributed on an "AS IS" BASIS,
11 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 | # See the License for the specific language governing permissions and
13 | # limitations under the License.
14 |
15 |
16 | # This is a sample Dockerfile for packaging an Elixir Phoenix application
17 | # as a Docker image. It builds a Distillery release and installs it on
18 | # Alpine Linux. The final image launches the application on port 8080.
19 | #
20 | # This Dockerfile includes two stages and requires Docker 17.05 or later.
21 | #
22 | # To adapt this Dockerfile to your app, set the APP_NAME and PHOENIX_SUBDIR
23 | # build arguments, as outlined below.
24 |
25 |
26 | ################################################################################
27 | # BUILD STAGE
28 | #
29 | # Builds the app, does a Brunch build to build the assets, and creates a
30 | # release. This stage uses the official Alpine Linux - Elixir base image, and
31 | # installs a few additional build tools such as Node.js.
32 |
33 | FROM elixir:alpine
34 |
35 |
36 | ##############################################################################
37 | ## Build arguments. Modify these to adapt this Dockerfile to your app. ##
38 | ## Alternatively, you may specify --build-arg when running `docker build`. ##
39 |
40 | ## The name of your Phoenix application. ##
41 | ARG APP_NAME=hello
42 |
43 | ## The subdirectory of the Phoenix application within the toplevel project. ##
44 | ## If your project is an umbrella project, this should be the relative path ##
45 | ## to the Phoenix application, e.g. "apps/hello_web". If this is a simple ##
46 | ## project, this should be "." ##
47 | ARG PHOENIX_SUBDIR=.
48 |
49 | ## End build arguments. ##
50 | ##############################################################################
51 |
52 |
53 | # Set up build environment.
54 | ENV MIX_ENV=prod \
55 | REPLACE_OS_VARS=true \
56 | TERM=xterm
57 |
58 | # Set the build directory.
59 | WORKDIR /opt/app
60 |
61 | # Install build tools needed in addition to Elixir:
62 | # NodeJS is used for Brunch builds of Phoenix assets.
63 | # Hex and Rebar are needed to get and build dependencies.
64 | RUN apk update \
65 | && apk --no-cache --update add nodejs nodejs-npm \
66 | && mix local.rebar --force \
67 | && mix local.hex --force
68 |
69 | # Copy the application files into /opt/app.
70 | COPY . .
71 |
72 | # Build the application.
73 | RUN mix do deps.get, deps.compile, compile
74 |
75 | # Build assets by running a Brunch build and Phoenix digest.
76 | # If you are using a different mechanism for asset builds, you may need to
77 | # alter these commands.
78 | RUN cd ${PHOENIX_SUBDIR}/assets \
79 | && npm install \
80 | && ./node_modules/brunch/bin/brunch build -p \
81 | && cd .. \
82 | && mix phx.digest
83 |
84 | # Create the release, and move the artifacts to well-known paths so the
85 | # runtime image doesn't need to know the app name. Specifically, the binary
86 | # is renamed to "start_server", and the entire release is moved into
87 | # /opt/release.
88 | RUN mix release --env=prod --verbose \
89 | && mv _build/prod/rel/${APP_NAME} /opt/release \
90 | && mv /opt/release/bin/${APP_NAME} /opt/release/bin/start_server
91 |
92 |
93 | ################################################################################
94 | # RUNTIME STAGE
95 | #
96 | # Creates the actual runtime image. This is based on a the Alpine Linux base
97 | # image, with only the minimum dependencies for running ERTS.
98 |
99 | FROM alpine:latest
100 |
101 | # Install dependencies for ERTS.
102 | RUN apk update \
103 | && apk --no-cache --update add bash openssl-dev
104 |
105 | # This is the runtime environment for a Phoenix app.
106 | # It listens on port 8080, and runs in the prod environment.
107 | ENV PORT=8080 \
108 | MIX_ENV=prod \
109 | REPLACE_OS_VARS=true
110 |
111 | # Set the install directory. The app will run from here.
112 | WORKDIR /opt/app
113 |
114 | # Obtain the built application release from the build stage.
115 | COPY --from=0 /opt/release .
116 |
117 | # Start the server.
118 | EXPOSE ${PORT}
119 | CMD ["/opt/app/bin/start_server", "foreground"]
120 |
--------------------------------------------------------------------------------
/mix.lock:
--------------------------------------------------------------------------------
1 | %{
2 | certifi:
3 | {:hex, :certifi, "2.0.0", "a0c0e475107135f76b8c1d5bc7efb33cd3815cb3cf3dea7aefdd174dabead064",
4 | [:rebar3], [], "hexpm"},
5 | cowboy:
6 | {:hex, :cowboy, "1.1.2", "61ac29ea970389a88eca5a65601460162d370a70018afe6f949a29dca91f3bb0",
7 | [:rebar3],
8 | [
9 | {:cowlib, "~> 1.0.2", [hex: :cowlib, repo: "hexpm", optional: false]},
10 | {:ranch, "~> 1.3.2", [hex: :ranch, repo: "hexpm", optional: false]}
11 | ], "hexpm"},
12 | cowlib:
13 | {:hex, :cowlib, "1.0.2", "9d769a1d062c9c3ac753096f868ca121e2730b9a377de23dec0f7e08b1df84ee",
14 | [:make], [], "hexpm"},
15 | deferred_config:
16 | {:hex, :deferred_config, "0.1.1",
17 | "ec912e9ee3c99b90a8d4bdec8fbd15309f4bd6729f30789e0ff6f595d06bbce5", [:mix], [], "hexpm"},
18 | distillery:
19 | {:hex, :distillery, "1.5.2",
20 | "eec18b2d37b55b0bcb670cf2bcf64228ed38ce8b046bb30a9b636a6f5a4c0080", [:mix], [], "hexpm"},
21 | file_system:
22 | {:hex, :file_system, "0.2.4",
23 | "f0bdda195c0e46e987333e986452ec523aed21d784189144f647c43eaf307064", [:mix], [], "hexpm"},
24 | gettext:
25 | {:hex, :gettext, "0.15.0", "40a2b8ce33a80ced7727e36768499fc9286881c43ebafccae6bab731e2b2b8ce",
26 | [:mix], [], "hexpm"},
27 | hackney:
28 | {:hex, :hackney, "1.11.0", "4951ee019df102492dabba66a09e305f61919a8a183a7860236c0fde586134b6",
29 | [:rebar3],
30 | [
31 | {:certifi, "2.0.0", [hex: :certifi, repo: "hexpm", optional: false]},
32 | {:idna, "5.1.0", [hex: :idna, repo: "hexpm", optional: false]},
33 | {:metrics, "1.0.1", [hex: :metrics, repo: "hexpm", optional: false]},
34 | {:mimerl, "1.0.2", [hex: :mimerl, repo: "hexpm", optional: false]},
35 | {:ssl_verify_fun, "1.1.1", [hex: :ssl_verify_fun, repo: "hexpm", optional: false]}
36 | ], "hexpm"},
37 | httpoison:
38 | {:hex, :httpoison, "0.13.0",
39 | "bfaf44d9f133a6599886720f3937a7699466d23bb0cd7a88b6ba011f53c6f562", [:mix],
40 | [{:hackney, "~> 1.8", [hex: :hackney, repo: "hexpm", optional: false]}], "hexpm"},
41 | idna:
42 | {:hex, :idna, "5.1.0", "d72b4effeb324ad5da3cab1767cb16b17939004e789d8c0ad5b70f3cea20c89a",
43 | [:rebar3],
44 | [
45 | {:unicode_util_compat, "0.3.1",
46 | [hex: :unicode_util_compat, repo: "hexpm", optional: false]}
47 | ], "hexpm"},
48 | libcluster:
49 | {:hex, :libcluster, "2.3.0",
50 | "d2fb8e8b2054a4a0c7faf7ced7c41dd13f7b49cce689590d37ecf30098e1b344", [:mix],
51 | [{:poison, "~> 3.0", [hex: :poison, repo: "hexpm", optional: false]}], "hexpm"},
52 | metrics:
53 | {:hex, :metrics, "1.0.1", "25f094dea2cda98213cecc3aeff09e940299d950904393b2a29d191c346a8486",
54 | [:rebar3], [], "hexpm"},
55 | mime:
56 | {:hex, :mime, "1.2.0", "78adaa84832b3680de06f88f0997e3ead3b451a440d183d688085be2d709b534",
57 | [:mix], [], "hexpm"},
58 | mimerl:
59 | {:hex, :mimerl, "1.0.2", "993f9b0e084083405ed8252b99460c4f0563e41729ab42d9074fd5e52439be88",
60 | [:rebar3], [], "hexpm"},
61 | peerage:
62 | {:hex, :peerage, "1.0.2", "43417cae92ca93fa3065194f5c6cb0b3df2214b2009128e470482563402cc9e5",
63 | [:mix],
64 | [{:deferred_config, "~> 0.1.1", [hex: :deferred_config, repo: "hexpm", optional: false]}],
65 | "hexpm"},
66 | phoenix:
67 | {:hex, :phoenix, "1.3.2", "2a00d751f51670ea6bc3f2ba4e6eb27ecb8a2c71e7978d9cd3e5de5ccf7378bd",
68 | [:mix],
69 | [
70 | {:cowboy, "~> 1.0", [hex: :cowboy, repo: "hexpm", optional: true]},
71 | {:phoenix_pubsub, "~> 1.0", [hex: :phoenix_pubsub, repo: "hexpm", optional: false]},
72 | {:plug, "~> 1.3.3 or ~> 1.4", [hex: :plug, repo: "hexpm", optional: false]},
73 | {:poison, "~> 2.2 or ~> 3.0", [hex: :poison, repo: "hexpm", optional: false]}
74 | ], "hexpm"},
75 | phoenix_html:
76 | {:hex, :phoenix_html, "2.11.0",
77 | "ead10dd1e36d5b8b5cc55642ba337832ec62617efd5765cddaa1a36c8b3891ca", [:mix],
78 | [{:plug, "~> 1.5", [hex: :plug, repo: "hexpm", optional: false]}], "hexpm"},
79 | phoenix_live_reload:
80 | {:hex, :phoenix_live_reload, "1.1.3",
81 | "1d178429fc8950b12457d09c6afec247bfe1fcb6f36209e18fbb0221bdfe4d41", [:mix],
82 | [
83 | {:file_system, "~> 0.2.1 or ~> 0.3", [hex: :file_system, repo: "hexpm", optional: false]},
84 | {:phoenix, "~> 1.0 or ~> 1.2 or ~> 1.3", [hex: :phoenix, repo: "hexpm", optional: false]}
85 | ], "hexpm"},
86 | phoenix_pubsub:
87 | {:hex, :phoenix_pubsub, "1.0.2",
88 | "bfa7fd52788b5eaa09cb51ff9fcad1d9edfeb68251add458523f839392f034c1", [:mix], [], "hexpm"},
89 | plug:
90 | {:hex, :plug, "1.5.0", "224b25b4039bedc1eac149fb52ed456770b9678bbf0349cdd810460e1e09195b",
91 | [:mix],
92 | [
93 | {:cowboy, "~> 1.0.1 or ~> 1.1 or ~> 2.1", [hex: :cowboy, repo: "hexpm", optional: true]},
94 | {:mime, "~> 1.0", [hex: :mime, repo: "hexpm", optional: false]}
95 | ], "hexpm"},
96 | poison:
97 | {:hex, :poison, "3.1.0", "d9eb636610e096f86f25d9a46f35a9facac35609a7591b3be3326e99a0484665",
98 | [:mix], [], "hexpm"},
99 | ranch:
100 | {:hex, :ranch, "1.3.2", "e4965a144dc9fbe70e5c077c65e73c57165416a901bd02ea899cfd95aa890986",
101 | [:rebar3], [], "hexpm"},
102 | ssl_verify_fun:
103 | {:hex, :ssl_verify_fun, "1.1.1",
104 | "28a4d65b7f59893bc2c7de786dec1e1555bd742d336043fe644ae956c3497fbe", [:make, :rebar], [],
105 | "hexpm"},
106 | unicode_util_compat:
107 | {:hex, :unicode_util_compat, "0.3.1",
108 | "a1f612a7b512638634a603c8f401892afbf99b8ce93a45041f8aaca99cadb85e", [:rebar3], [], "hexpm"},
109 | websocket_client:
110 | {:hex, :websocket_client, "1.3.0",
111 | "2275d7daaa1cdacebf2068891c9844b15f4fdc3de3ec2602420c2fb486db59b6", [:rebar3], [], "hexpm"},
112 | wobserver:
113 | {:hex, :wobserver, "0.1.8",
114 | "3ed5ea55478627f0593800ab83919b71f41fd426ec344e71cf1d975e6d2065b8", [:mix],
115 | [
116 | {:cowboy, "~> 1.1", [hex: :cowboy, repo: "hexpm", optional: false]},
117 | {:httpoison, "~> 0.11 or ~> 0.12", [hex: :httpoison, repo: "hexpm", optional: false]},
118 | {:plug, "~> 1.3 or ~> 1.4", [hex: :plug, repo: "hexpm", optional: false]},
119 | {:poison, "~> 2.0 or ~> 3.1", [hex: :poison, repo: "hexpm", optional: false]},
120 | {:websocket_client, "~> 1.2", [hex: :websocket_client, repo: "hexpm", optional: false]}
121 | ], "hexpm"}
122 | }
123 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Distributed Elixir Demo 🔮
2 |
3 | Hi, I made this little demo to show an example of how to setup a distributed Elixir
4 | app that you can run on a local Kubernetes cluster.
5 |
6 | Some of the things in this demo:
7 | * Setting up a simple websocket-based Phoenix app
8 | * Creating releases with Distillery
9 | * Packaging a release inside a Docker container
10 | * Running containers inside a Kubernetes cluster in distributed mode
11 |
12 | ## How to run this thing
13 |
14 | ### Download this stuff first
15 |
16 | I'm using OSX, so the installation instructions are based on this.
17 |
18 | ```
19 | # Make sure you have Elixir installed
20 | $ brew install elixir
21 |
22 | # Install node and npm (needed for Phoenix app)
23 | $ brew install node
24 |
25 | # Install Docker
26 | # (download the installer from the website and run it)
27 |
28 | # Install VirtualBox
29 | # (download the installer from the website and run it)
30 |
31 | # Install Minikube (mini kubernetes that runs on VirtualBox)
32 | $ brew cask install minikube
33 |
34 | # Install kubectl (command line tool to interact with Kubernetes)
35 | $ brew install kubectl
36 |
37 | # Clone this repo
38 | $ git clone
39 | ```
40 |
41 | ### Get the Phoenix app up and running
42 |
43 | Make sure the app works by running it on your local host first.
44 |
45 | ```
46 | # Install Elixir && JS app dependencies
47 | $ mix deps.get
48 | $ (cd assets && npm i)
49 |
50 | # Run the app
51 | $ mix phx.server
52 |
53 | # See that it works in the browser
54 | $ open http://localhost:4000
55 | ```
56 |
57 | ### Creating a Distillery release
58 |
59 | For this project I'm using
60 | [distillery](https://github.com/bitwalker/distillery) to create an Elixir
61 | release. A release is a single, deployable binary that contains all the
62 | compiled app code as well as the Erlang runtime required to run it. Distillery
63 | automates this process and gives us a simple command line tool to do it.
64 |
65 | ```
66 | # Build all the frontend assets, then create a manifest file for them
67 | $ (cd assets && npm i && npm run deploy)
68 | $ mix phx.digest
69 |
70 | # Create a release with distillery
71 | $ MIX_ENV=prod REPLACE_OS_VARS=true TERM=xterm mix release --env=prod --verbose
72 |
73 | # Run the release it produced
74 | $ MIX_ENV=prod PORT=4000 REPLACE_OS_VARS=true _build/prod/rel/hello/bin/hello foreground
75 |
76 | # See that it works in the browser
77 | $ open http://localhost:4000
78 | ```
79 |
80 | ### Creating a Distillery release in a Docker container
81 |
82 | If we want to deploy this release to a Linux machine, we'll need to make sure that we
83 | also _create_ our release in the same enviornment. This is because the release is
84 | built using various system dependencies that may be wildly different on OSX than your
85 | deployment target. We can use a Docker container to help us here. The trick here is
86 | to use the Docker container to describe a environment that we will create
87 | our release in which will be the same environment we eventually run our code in.
88 |
89 | I used this
90 | [Dockerfile](https://github.com/GoogleCloudPlatform/community/blob/master/tutorials/elixir-phoenix-on-kubernetes-google-container-engine/Dockerfile)
91 | that I got from Google to create a docker image that creates our distillery
92 | release and then uses that compiled code to expose an http port and run the
93 | app.
94 |
95 | ```
96 | # Create an image using the Dockerfile
97 | $ docker build --no-cache -t hello .
98 |
99 | # Run the docker image we just created like this
100 | $ docker run -it --rm -p 8080:8080 hello
101 |
102 | # See that it works in a browser
103 | $ open http://localhost:8080
104 |
105 | # Stop the running container (lookup the container id, then kill it)
106 | $ docker ps
107 | $ docker kill
108 | ```
109 |
110 |
111 | ### Running the container in Minikube
112 |
113 | Running a container one at a time is pretty cool, but our goal here is to run
114 | many containers with our app. This is where Kubernetes comes in. Using
115 | [Minikube](https://github.com/kubernetes/minikube) we can play around with a
116 | local Kubernetes cluster. In addition, to just running mulitple containerized
117 | instances of our app we would also like to let our app instances to be able to
118 | "talk" to each other and share resources. This example repo is configured to
119 | allow us to do this using a few tricks that I'll describe in detail later on.
120 | But for now, let's see what it looks like to run it.
121 |
122 | ```
123 | # Start up Minikube (takes a minute or two)
124 | $ minikube start
125 |
126 | # See that we're up and running the cluster
127 | $ minikube status
128 |
129 | # Let Minikube talk to our local Docker daemon
130 | $ eval $(minikube docker-env)
131 |
132 | # Build another image for our app (like we did before)
133 | $ docker build --no-cache -t hello .
134 |
135 | # Tag the image with a name we can use in our Kubernetes config
136 | $ docker tag hello:latest liamgriffiths/hello:17
137 |
138 | # Edit ./k8s/hello/deployment and change the "image" entry to be the new tag we just used
139 | # (in this example it is "liamgriffiths/hello:17")
140 |
141 | # Apply our kubernetes config to the cluster (more on this later)
142 | $ kubectl apply -f ./k8s/hello.yaml
143 |
144 | # Checkout this awesome built-in dashboard to inspect it (see namespace "hello")
145 | $ minikube dashboard
146 |
147 | # Open the our kubernetes "service" in a web browser
148 | $ minikube service web --namespace=hello
149 |
150 | # Trash our Minikube cluster (if you don't want it anymore)
151 | $ minikube delete
152 | ```
153 |
154 | ### Seeing what is going on with the cluster
155 |
156 | ... todo ...
157 |
158 | ## How this all works
159 |
160 | ### Phoenix websockets, channels, Elixir processes
161 |
162 | ... todo ...
163 |
164 | * Card state, global processes (and why it might be a bad idea in prod :D)
165 | * Phoenix channels, PG2
166 |
167 | ### Distributed Elixir/Erlang
168 |
169 | ... todo ...
170 |
171 | * Erlang cookie
172 | * Node names
173 | * Peerage
174 | * vm.args and build steps
175 |
176 | ### Kubernetes configuration
177 |
178 | ... todo ...
179 |
180 | * About docker containers, tagging, versioning
181 | * About the "namespace" config
182 | * About the "deployment" config
183 | * About the "service" config
184 | * About the "headless-service" config
185 |
186 | ## Thanks ❤️
187 |
188 | Big thanks to all the free projects out there that let me put this together:
189 | Elixir, Phoenix, React, Docker, Kubernetes, Distillery, Peerage, and all people
190 | who write about these things on the internet.
191 |
192 | Some great blogs and tutorials that helped me out in particular:
193 | * https://medium.com/polyscribe/a-complete-guide-to-deploying-elixir-phoenix-applications-on-kubernetes-part-1-setting-up-d88b35b64dcd
194 | * https://cloud.google.com/community/tutorials/elixir-phoenix-on-kubernetes-google-container-engine
195 | * https://hackernoon.com/state-of-the-art-in-deploying-elixir-phoenix-applications-fe72a4563cd8
196 | * https://www.cogini.com/blog/best-practices-for-deploying-elixir-apps/
197 | * http://0length.com/posts/Erlang-Clustering-on-Kubernetes.html
198 |
--------------------------------------------------------------------------------
/assets/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "requires": true,
3 | "lockfileVersion": 1,
4 | "dependencies": {
5 | "accepts": {
6 | "version": "1.3.5",
7 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz",
8 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=",
9 | "dev": true,
10 | "requires": {
11 | "mime-types": "2.1.18",
12 | "negotiator": "0.6.1"
13 | }
14 | },
15 | "acorn": {
16 | "version": "5.5.3",
17 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz",
18 | "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==",
19 | "dev": true
20 | },
21 | "align-text": {
22 | "version": "0.1.4",
23 | "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz",
24 | "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=",
25 | "dev": true,
26 | "requires": {
27 | "kind-of": "3.2.2",
28 | "longest": "1.0.1",
29 | "repeat-string": "1.6.1"
30 | }
31 | },
32 | "ansi-regex": {
33 | "version": "2.1.1",
34 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
35 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
36 | "dev": true
37 | },
38 | "ansi-styles": {
39 | "version": "2.2.1",
40 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz",
41 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=",
42 | "dev": true
43 | },
44 | "ansicolors": {
45 | "version": "0.3.2",
46 | "resolved": "https://registry.npmjs.org/ansicolors/-/ansicolors-0.3.2.tgz",
47 | "integrity": "sha1-ZlWX3oap/+Oqm/vmyuXG6kJrSXk=",
48 | "dev": true
49 | },
50 | "anymatch": {
51 | "version": "1.3.2",
52 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz",
53 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==",
54 | "dev": true,
55 | "requires": {
56 | "micromatch": "2.3.11",
57 | "normalize-path": "2.1.1"
58 | }
59 | },
60 | "anysort": {
61 | "version": "1.0.1",
62 | "resolved": "https://registry.npmjs.org/anysort/-/anysort-1.0.1.tgz",
63 | "integrity": "sha1-NBvV1boUhfZOVa6GXx1FmUtQf8Q=",
64 | "dev": true,
65 | "requires": {
66 | "anymatch": "1.3.2"
67 | }
68 | },
69 | "arr-diff": {
70 | "version": "2.0.0",
71 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz",
72 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=",
73 | "dev": true,
74 | "requires": {
75 | "arr-flatten": "1.1.0"
76 | }
77 | },
78 | "arr-flatten": {
79 | "version": "1.1.0",
80 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz",
81 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==",
82 | "dev": true
83 | },
84 | "array-flatten": {
85 | "version": "1.1.1",
86 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
87 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=",
88 | "dev": true
89 | },
90 | "array-unique": {
91 | "version": "0.2.1",
92 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz",
93 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=",
94 | "dev": true
95 | },
96 | "asap": {
97 | "version": "2.0.6",
98 | "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz",
99 | "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY="
100 | },
101 | "asn1.js": {
102 | "version": "4.10.1",
103 | "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-4.10.1.tgz",
104 | "integrity": "sha512-p32cOF5q0Zqs9uBiONKYLm6BClCoBCM5O9JfeUSlnQLBTxYdTK+pW+nXflm8UkKd2UYlEbYz5qEi0JuZR9ckSw==",
105 | "dev": true,
106 | "requires": {
107 | "bn.js": "4.11.8",
108 | "inherits": "2.0.3",
109 | "minimalistic-assert": "1.0.0"
110 | }
111 | },
112 | "assert": {
113 | "version": "1.3.0",
114 | "resolved": "https://registry.npmjs.org/assert/-/assert-1.3.0.tgz",
115 | "integrity": "sha1-A5OaYiWCqBLMICMgoLmlbJuBWEk=",
116 | "dev": true,
117 | "requires": {
118 | "util": "0.10.3"
119 | }
120 | },
121 | "async": {
122 | "version": "0.2.10",
123 | "resolved": "https://registry.npmjs.org/async/-/async-0.2.10.tgz",
124 | "integrity": "sha1-trvgsGdLnXGXCMo43owjfLUmw9E=",
125 | "dev": true
126 | },
127 | "async-each": {
128 | "version": "1.0.1",
129 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz",
130 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=",
131 | "dev": true
132 | },
133 | "babel": {
134 | "version": "6.23.0",
135 | "resolved": "https://registry.npmjs.org/babel/-/babel-6.23.0.tgz",
136 | "integrity": "sha1-0NHn2APpdHZb7qMjLU4VPA77kPQ=",
137 | "dev": true
138 | },
139 | "babel-brunch": {
140 | "version": "6.1.1",
141 | "resolved": "https://registry.npmjs.org/babel-brunch/-/babel-brunch-6.1.1.tgz",
142 | "integrity": "sha1-C50Ewd8S9m52pNve402HNIdvGHc=",
143 | "dev": true,
144 | "requires": {
145 | "anymatch": "1.3.2",
146 | "babel-core": "6.26.0",
147 | "babel-preset-latest": "6.24.1",
148 | "loggy": "1.0.2"
149 | }
150 | },
151 | "babel-code-frame": {
152 | "version": "6.26.0",
153 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz",
154 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=",
155 | "dev": true,
156 | "requires": {
157 | "chalk": "1.1.3",
158 | "esutils": "2.0.2",
159 | "js-tokens": "3.0.2"
160 | }
161 | },
162 | "babel-core": {
163 | "version": "6.26.0",
164 | "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.0.tgz",
165 | "integrity": "sha1-rzL3izGm/O8RnIew/Y2XU/A6C7g=",
166 | "dev": true,
167 | "requires": {
168 | "babel-code-frame": "6.26.0",
169 | "babel-generator": "6.26.1",
170 | "babel-helpers": "6.24.1",
171 | "babel-messages": "6.23.0",
172 | "babel-register": "6.26.0",
173 | "babel-runtime": "6.26.0",
174 | "babel-template": "6.26.0",
175 | "babel-traverse": "6.26.0",
176 | "babel-types": "6.26.0",
177 | "babylon": "6.18.0",
178 | "convert-source-map": "1.5.1",
179 | "debug": "2.6.9",
180 | "json5": "0.5.1",
181 | "lodash": "4.17.5",
182 | "minimatch": "3.0.4",
183 | "path-is-absolute": "1.0.1",
184 | "private": "0.1.8",
185 | "slash": "1.0.0",
186 | "source-map": "0.5.7"
187 | }
188 | },
189 | "babel-generator": {
190 | "version": "6.26.1",
191 | "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.1.tgz",
192 | "integrity": "sha512-HyfwY6ApZj7BYTcJURpM5tznulaBvyio7/0d4zFOeMPUmfxkCjHocCuoLa2SAGzBI8AREcH3eP3758F672DppA==",
193 | "dev": true,
194 | "requires": {
195 | "babel-messages": "6.23.0",
196 | "babel-runtime": "6.26.0",
197 | "babel-types": "6.26.0",
198 | "detect-indent": "4.0.0",
199 | "jsesc": "1.3.0",
200 | "lodash": "4.17.5",
201 | "source-map": "0.5.7",
202 | "trim-right": "1.0.1"
203 | }
204 | },
205 | "babel-helper-builder-binary-assignment-operator-visitor": {
206 | "version": "6.24.1",
207 | "resolved": "https://registry.npmjs.org/babel-helper-builder-binary-assignment-operator-visitor/-/babel-helper-builder-binary-assignment-operator-visitor-6.24.1.tgz",
208 | "integrity": "sha1-zORReto1b0IgvK6KAsKzRvmlZmQ=",
209 | "dev": true,
210 | "requires": {
211 | "babel-helper-explode-assignable-expression": "6.24.1",
212 | "babel-runtime": "6.26.0",
213 | "babel-types": "6.26.0"
214 | }
215 | },
216 | "babel-helper-builder-react-jsx": {
217 | "version": "6.26.0",
218 | "resolved": "https://registry.npmjs.org/babel-helper-builder-react-jsx/-/babel-helper-builder-react-jsx-6.26.0.tgz",
219 | "integrity": "sha1-Of+DE7dci2Xc7/HzHTg+D/KkCKA=",
220 | "dev": true,
221 | "requires": {
222 | "babel-runtime": "6.26.0",
223 | "babel-types": "6.26.0",
224 | "esutils": "2.0.2"
225 | }
226 | },
227 | "babel-helper-call-delegate": {
228 | "version": "6.24.1",
229 | "resolved": "https://registry.npmjs.org/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz",
230 | "integrity": "sha1-7Oaqzdx25Bw0YfiL/Fdb0Nqi340=",
231 | "dev": true,
232 | "requires": {
233 | "babel-helper-hoist-variables": "6.24.1",
234 | "babel-runtime": "6.26.0",
235 | "babel-traverse": "6.26.0",
236 | "babel-types": "6.26.0"
237 | }
238 | },
239 | "babel-helper-define-map": {
240 | "version": "6.26.0",
241 | "resolved": "https://registry.npmjs.org/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz",
242 | "integrity": "sha1-pfVtq0GiX5fstJjH66ypgZ+Vvl8=",
243 | "dev": true,
244 | "requires": {
245 | "babel-helper-function-name": "6.24.1",
246 | "babel-runtime": "6.26.0",
247 | "babel-types": "6.26.0",
248 | "lodash": "4.17.5"
249 | }
250 | },
251 | "babel-helper-explode-assignable-expression": {
252 | "version": "6.24.1",
253 | "resolved": "https://registry.npmjs.org/babel-helper-explode-assignable-expression/-/babel-helper-explode-assignable-expression-6.24.1.tgz",
254 | "integrity": "sha1-8luCz33BBDPFX3BZLVdGQArCLKo=",
255 | "dev": true,
256 | "requires": {
257 | "babel-runtime": "6.26.0",
258 | "babel-traverse": "6.26.0",
259 | "babel-types": "6.26.0"
260 | }
261 | },
262 | "babel-helper-function-name": {
263 | "version": "6.24.1",
264 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz",
265 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=",
266 | "dev": true,
267 | "requires": {
268 | "babel-helper-get-function-arity": "6.24.1",
269 | "babel-runtime": "6.26.0",
270 | "babel-template": "6.26.0",
271 | "babel-traverse": "6.26.0",
272 | "babel-types": "6.26.0"
273 | }
274 | },
275 | "babel-helper-get-function-arity": {
276 | "version": "6.24.1",
277 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz",
278 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=",
279 | "dev": true,
280 | "requires": {
281 | "babel-runtime": "6.26.0",
282 | "babel-types": "6.26.0"
283 | }
284 | },
285 | "babel-helper-hoist-variables": {
286 | "version": "6.24.1",
287 | "resolved": "https://registry.npmjs.org/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz",
288 | "integrity": "sha1-HssnaJydJVE+rbyZFKc/VAi+enY=",
289 | "dev": true,
290 | "requires": {
291 | "babel-runtime": "6.26.0",
292 | "babel-types": "6.26.0"
293 | }
294 | },
295 | "babel-helper-optimise-call-expression": {
296 | "version": "6.24.1",
297 | "resolved": "https://registry.npmjs.org/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz",
298 | "integrity": "sha1-96E0J7qfc/j0+pk8VKl4gtEkQlc=",
299 | "dev": true,
300 | "requires": {
301 | "babel-runtime": "6.26.0",
302 | "babel-types": "6.26.0"
303 | }
304 | },
305 | "babel-helper-regex": {
306 | "version": "6.26.0",
307 | "resolved": "https://registry.npmjs.org/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz",
308 | "integrity": "sha1-MlxZ+QL4LyS3T6zu0DY5VPZJXnI=",
309 | "dev": true,
310 | "requires": {
311 | "babel-runtime": "6.26.0",
312 | "babel-types": "6.26.0",
313 | "lodash": "4.17.5"
314 | }
315 | },
316 | "babel-helper-remap-async-to-generator": {
317 | "version": "6.24.1",
318 | "resolved": "https://registry.npmjs.org/babel-helper-remap-async-to-generator/-/babel-helper-remap-async-to-generator-6.24.1.tgz",
319 | "integrity": "sha1-XsWBgnrXI/7N04HxySg5BnbkVRs=",
320 | "dev": true,
321 | "requires": {
322 | "babel-helper-function-name": "6.24.1",
323 | "babel-runtime": "6.26.0",
324 | "babel-template": "6.26.0",
325 | "babel-traverse": "6.26.0",
326 | "babel-types": "6.26.0"
327 | }
328 | },
329 | "babel-helper-replace-supers": {
330 | "version": "6.24.1",
331 | "resolved": "https://registry.npmjs.org/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz",
332 | "integrity": "sha1-v22/5Dk40XNpohPKiov3S2qQqxo=",
333 | "dev": true,
334 | "requires": {
335 | "babel-helper-optimise-call-expression": "6.24.1",
336 | "babel-messages": "6.23.0",
337 | "babel-runtime": "6.26.0",
338 | "babel-template": "6.26.0",
339 | "babel-traverse": "6.26.0",
340 | "babel-types": "6.26.0"
341 | }
342 | },
343 | "babel-helpers": {
344 | "version": "6.24.1",
345 | "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz",
346 | "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=",
347 | "dev": true,
348 | "requires": {
349 | "babel-runtime": "6.26.0",
350 | "babel-template": "6.26.0"
351 | }
352 | },
353 | "babel-messages": {
354 | "version": "6.23.0",
355 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz",
356 | "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=",
357 | "dev": true,
358 | "requires": {
359 | "babel-runtime": "6.26.0"
360 | }
361 | },
362 | "babel-plugin-check-es2015-constants": {
363 | "version": "6.22.0",
364 | "resolved": "https://registry.npmjs.org/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz",
365 | "integrity": "sha1-NRV7EBQm/S/9PaP3XH0ekYNbv4o=",
366 | "dev": true,
367 | "requires": {
368 | "babel-runtime": "6.26.0"
369 | }
370 | },
371 | "babel-plugin-syntax-async-functions": {
372 | "version": "6.13.0",
373 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz",
374 | "integrity": "sha1-ytnK0RkbWtY0vzCuCHI5HgZHvpU=",
375 | "dev": true
376 | },
377 | "babel-plugin-syntax-exponentiation-operator": {
378 | "version": "6.13.0",
379 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz",
380 | "integrity": "sha1-nufoM3KQ2pUoggGmpX9BcDF4MN4=",
381 | "dev": true
382 | },
383 | "babel-plugin-syntax-flow": {
384 | "version": "6.18.0",
385 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-flow/-/babel-plugin-syntax-flow-6.18.0.tgz",
386 | "integrity": "sha1-TDqyCiryaqIM0lmVw5jE63AxDI0=",
387 | "dev": true
388 | },
389 | "babel-plugin-syntax-jsx": {
390 | "version": "6.18.0",
391 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-jsx/-/babel-plugin-syntax-jsx-6.18.0.tgz",
392 | "integrity": "sha1-CvMqmm4Tyno/1QaeYtew9Y0NiUY=",
393 | "dev": true
394 | },
395 | "babel-plugin-syntax-trailing-function-commas": {
396 | "version": "6.22.0",
397 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-6.22.0.tgz",
398 | "integrity": "sha1-ugNgk3+NBuQBgKQ/4NVhb/9TLPM=",
399 | "dev": true
400 | },
401 | "babel-plugin-transform-async-to-generator": {
402 | "version": "6.24.1",
403 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-async-to-generator/-/babel-plugin-transform-async-to-generator-6.24.1.tgz",
404 | "integrity": "sha1-ZTbjeK/2yx1VF6wOQOs+n8jQh2E=",
405 | "dev": true,
406 | "requires": {
407 | "babel-helper-remap-async-to-generator": "6.24.1",
408 | "babel-plugin-syntax-async-functions": "6.13.0",
409 | "babel-runtime": "6.26.0"
410 | }
411 | },
412 | "babel-plugin-transform-es2015-arrow-functions": {
413 | "version": "6.22.0",
414 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz",
415 | "integrity": "sha1-RSaSy3EdX3ncf4XkQM5BufJE0iE=",
416 | "dev": true,
417 | "requires": {
418 | "babel-runtime": "6.26.0"
419 | }
420 | },
421 | "babel-plugin-transform-es2015-block-scoped-functions": {
422 | "version": "6.22.0",
423 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz",
424 | "integrity": "sha1-u8UbSflk1wy42OC5ToICRs46YUE=",
425 | "dev": true,
426 | "requires": {
427 | "babel-runtime": "6.26.0"
428 | }
429 | },
430 | "babel-plugin-transform-es2015-block-scoping": {
431 | "version": "6.26.0",
432 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz",
433 | "integrity": "sha1-1w9SmcEwjQXBL0Y4E7CgnnOxiV8=",
434 | "dev": true,
435 | "requires": {
436 | "babel-runtime": "6.26.0",
437 | "babel-template": "6.26.0",
438 | "babel-traverse": "6.26.0",
439 | "babel-types": "6.26.0",
440 | "lodash": "4.17.5"
441 | }
442 | },
443 | "babel-plugin-transform-es2015-classes": {
444 | "version": "6.24.1",
445 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz",
446 | "integrity": "sha1-WkxYpQyclGHlZLSyo7+ryXolhNs=",
447 | "dev": true,
448 | "requires": {
449 | "babel-helper-define-map": "6.26.0",
450 | "babel-helper-function-name": "6.24.1",
451 | "babel-helper-optimise-call-expression": "6.24.1",
452 | "babel-helper-replace-supers": "6.24.1",
453 | "babel-messages": "6.23.0",
454 | "babel-runtime": "6.26.0",
455 | "babel-template": "6.26.0",
456 | "babel-traverse": "6.26.0",
457 | "babel-types": "6.26.0"
458 | }
459 | },
460 | "babel-plugin-transform-es2015-computed-properties": {
461 | "version": "6.24.1",
462 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz",
463 | "integrity": "sha1-b+Ko0WiV1WNPTNmZttNICjCBWbM=",
464 | "dev": true,
465 | "requires": {
466 | "babel-runtime": "6.26.0",
467 | "babel-template": "6.26.0"
468 | }
469 | },
470 | "babel-plugin-transform-es2015-destructuring": {
471 | "version": "6.23.0",
472 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz",
473 | "integrity": "sha1-mXux8auWf2gtKwh2/jWNYOdlxW0=",
474 | "dev": true,
475 | "requires": {
476 | "babel-runtime": "6.26.0"
477 | }
478 | },
479 | "babel-plugin-transform-es2015-duplicate-keys": {
480 | "version": "6.24.1",
481 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz",
482 | "integrity": "sha1-c+s9MQypaePvnskcU3QabxV2Qj4=",
483 | "dev": true,
484 | "requires": {
485 | "babel-runtime": "6.26.0",
486 | "babel-types": "6.26.0"
487 | }
488 | },
489 | "babel-plugin-transform-es2015-for-of": {
490 | "version": "6.23.0",
491 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz",
492 | "integrity": "sha1-9HyVsrYT3x0+zC/bdXNiPHUkhpE=",
493 | "dev": true,
494 | "requires": {
495 | "babel-runtime": "6.26.0"
496 | }
497 | },
498 | "babel-plugin-transform-es2015-function-name": {
499 | "version": "6.24.1",
500 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz",
501 | "integrity": "sha1-g0yJhTvDaxrw86TF26qU/Y6sqos=",
502 | "dev": true,
503 | "requires": {
504 | "babel-helper-function-name": "6.24.1",
505 | "babel-runtime": "6.26.0",
506 | "babel-types": "6.26.0"
507 | }
508 | },
509 | "babel-plugin-transform-es2015-literals": {
510 | "version": "6.22.0",
511 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz",
512 | "integrity": "sha1-T1SgLWzWbPkVKAAZox0xklN3yi4=",
513 | "dev": true,
514 | "requires": {
515 | "babel-runtime": "6.26.0"
516 | }
517 | },
518 | "babel-plugin-transform-es2015-modules-amd": {
519 | "version": "6.24.1",
520 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz",
521 | "integrity": "sha1-Oz5UAXI5hC1tGcMBHEvS8AoA0VQ=",
522 | "dev": true,
523 | "requires": {
524 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0",
525 | "babel-runtime": "6.26.0",
526 | "babel-template": "6.26.0"
527 | }
528 | },
529 | "babel-plugin-transform-es2015-modules-commonjs": {
530 | "version": "6.26.0",
531 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.0.tgz",
532 | "integrity": "sha1-DYOUApt9xqvhqX7xgeAHWN0uXYo=",
533 | "dev": true,
534 | "requires": {
535 | "babel-plugin-transform-strict-mode": "6.24.1",
536 | "babel-runtime": "6.26.0",
537 | "babel-template": "6.26.0",
538 | "babel-types": "6.26.0"
539 | }
540 | },
541 | "babel-plugin-transform-es2015-modules-systemjs": {
542 | "version": "6.24.1",
543 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz",
544 | "integrity": "sha1-/4mhQrkRmpBhlfXxBuzzBdlAfSM=",
545 | "dev": true,
546 | "requires": {
547 | "babel-helper-hoist-variables": "6.24.1",
548 | "babel-runtime": "6.26.0",
549 | "babel-template": "6.26.0"
550 | }
551 | },
552 | "babel-plugin-transform-es2015-modules-umd": {
553 | "version": "6.24.1",
554 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz",
555 | "integrity": "sha1-rJl+YoXNGO1hdq22B9YCNErThGg=",
556 | "dev": true,
557 | "requires": {
558 | "babel-plugin-transform-es2015-modules-amd": "6.24.1",
559 | "babel-runtime": "6.26.0",
560 | "babel-template": "6.26.0"
561 | }
562 | },
563 | "babel-plugin-transform-es2015-object-super": {
564 | "version": "6.24.1",
565 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz",
566 | "integrity": "sha1-JM72muIcuDp/hgPa0CH1cusnj40=",
567 | "dev": true,
568 | "requires": {
569 | "babel-helper-replace-supers": "6.24.1",
570 | "babel-runtime": "6.26.0"
571 | }
572 | },
573 | "babel-plugin-transform-es2015-parameters": {
574 | "version": "6.24.1",
575 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz",
576 | "integrity": "sha1-V6w1GrScrxSpfNE7CfZv3wpiXys=",
577 | "dev": true,
578 | "requires": {
579 | "babel-helper-call-delegate": "6.24.1",
580 | "babel-helper-get-function-arity": "6.24.1",
581 | "babel-runtime": "6.26.0",
582 | "babel-template": "6.26.0",
583 | "babel-traverse": "6.26.0",
584 | "babel-types": "6.26.0"
585 | }
586 | },
587 | "babel-plugin-transform-es2015-shorthand-properties": {
588 | "version": "6.24.1",
589 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz",
590 | "integrity": "sha1-JPh11nIch2YbvZmkYi5R8U3jiqA=",
591 | "dev": true,
592 | "requires": {
593 | "babel-runtime": "6.26.0",
594 | "babel-types": "6.26.0"
595 | }
596 | },
597 | "babel-plugin-transform-es2015-spread": {
598 | "version": "6.22.0",
599 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz",
600 | "integrity": "sha1-1taKmfia7cRTbIGlQujdnxdG+NE=",
601 | "dev": true,
602 | "requires": {
603 | "babel-runtime": "6.26.0"
604 | }
605 | },
606 | "babel-plugin-transform-es2015-sticky-regex": {
607 | "version": "6.24.1",
608 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz",
609 | "integrity": "sha1-AMHNsaynERLN8M9hJsLta0V8zbw=",
610 | "dev": true,
611 | "requires": {
612 | "babel-helper-regex": "6.26.0",
613 | "babel-runtime": "6.26.0",
614 | "babel-types": "6.26.0"
615 | }
616 | },
617 | "babel-plugin-transform-es2015-template-literals": {
618 | "version": "6.22.0",
619 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz",
620 | "integrity": "sha1-qEs0UPfp+PH2g51taH2oS7EjbY0=",
621 | "dev": true,
622 | "requires": {
623 | "babel-runtime": "6.26.0"
624 | }
625 | },
626 | "babel-plugin-transform-es2015-typeof-symbol": {
627 | "version": "6.23.0",
628 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz",
629 | "integrity": "sha1-3sCfHN3/lLUqxz1QXITfWdzOs3I=",
630 | "dev": true,
631 | "requires": {
632 | "babel-runtime": "6.26.0"
633 | }
634 | },
635 | "babel-plugin-transform-es2015-unicode-regex": {
636 | "version": "6.24.1",
637 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz",
638 | "integrity": "sha1-04sS9C6nMj9yk4fxinxa4frrNek=",
639 | "dev": true,
640 | "requires": {
641 | "babel-helper-regex": "6.26.0",
642 | "babel-runtime": "6.26.0",
643 | "regexpu-core": "2.0.0"
644 | }
645 | },
646 | "babel-plugin-transform-exponentiation-operator": {
647 | "version": "6.24.1",
648 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-exponentiation-operator/-/babel-plugin-transform-exponentiation-operator-6.24.1.tgz",
649 | "integrity": "sha1-KrDJx/MJj6SJB3cruBP+QejeOg4=",
650 | "dev": true,
651 | "requires": {
652 | "babel-helper-builder-binary-assignment-operator-visitor": "6.24.1",
653 | "babel-plugin-syntax-exponentiation-operator": "6.13.0",
654 | "babel-runtime": "6.26.0"
655 | }
656 | },
657 | "babel-plugin-transform-flow-strip-types": {
658 | "version": "6.22.0",
659 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-flow-strip-types/-/babel-plugin-transform-flow-strip-types-6.22.0.tgz",
660 | "integrity": "sha1-hMtnKTXUNxT9wyvOhFaNh0Qc988=",
661 | "dev": true,
662 | "requires": {
663 | "babel-plugin-syntax-flow": "6.18.0",
664 | "babel-runtime": "6.26.0"
665 | }
666 | },
667 | "babel-plugin-transform-react-display-name": {
668 | "version": "6.25.0",
669 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-display-name/-/babel-plugin-transform-react-display-name-6.25.0.tgz",
670 | "integrity": "sha1-Z+K/Hx6ck6sI25Z5LgU5K/LMKNE=",
671 | "dev": true,
672 | "requires": {
673 | "babel-runtime": "6.26.0"
674 | }
675 | },
676 | "babel-plugin-transform-react-jsx": {
677 | "version": "6.24.1",
678 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-jsx/-/babel-plugin-transform-react-jsx-6.24.1.tgz",
679 | "integrity": "sha1-hAoCjn30YN/DotKfDA2R9jduZqM=",
680 | "dev": true,
681 | "requires": {
682 | "babel-helper-builder-react-jsx": "6.26.0",
683 | "babel-plugin-syntax-jsx": "6.18.0",
684 | "babel-runtime": "6.26.0"
685 | }
686 | },
687 | "babel-plugin-transform-react-jsx-self": {
688 | "version": "6.22.0",
689 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-jsx-self/-/babel-plugin-transform-react-jsx-self-6.22.0.tgz",
690 | "integrity": "sha1-322AqdomEqEh5t3XVYvL7PBuY24=",
691 | "dev": true,
692 | "requires": {
693 | "babel-plugin-syntax-jsx": "6.18.0",
694 | "babel-runtime": "6.26.0"
695 | }
696 | },
697 | "babel-plugin-transform-react-jsx-source": {
698 | "version": "6.22.0",
699 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-jsx-source/-/babel-plugin-transform-react-jsx-source-6.22.0.tgz",
700 | "integrity": "sha1-ZqwSFT9c0tF7PBkmj0vwGX9E7NY=",
701 | "dev": true,
702 | "requires": {
703 | "babel-plugin-syntax-jsx": "6.18.0",
704 | "babel-runtime": "6.26.0"
705 | }
706 | },
707 | "babel-plugin-transform-regenerator": {
708 | "version": "6.26.0",
709 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz",
710 | "integrity": "sha1-4HA2lvveJ/Cj78rPi03KL3s6jy8=",
711 | "dev": true,
712 | "requires": {
713 | "regenerator-transform": "0.10.1"
714 | }
715 | },
716 | "babel-plugin-transform-strict-mode": {
717 | "version": "6.24.1",
718 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz",
719 | "integrity": "sha1-1fr3qleKZbvlkc9e2uBKDGcCB1g=",
720 | "dev": true,
721 | "requires": {
722 | "babel-runtime": "6.26.0",
723 | "babel-types": "6.26.0"
724 | }
725 | },
726 | "babel-preset-es2015": {
727 | "version": "6.24.1",
728 | "resolved": "https://registry.npmjs.org/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz",
729 | "integrity": "sha1-1EBQ1rwsn+6nAqrzjXJ6AhBTiTk=",
730 | "dev": true,
731 | "requires": {
732 | "babel-plugin-check-es2015-constants": "6.22.0",
733 | "babel-plugin-transform-es2015-arrow-functions": "6.22.0",
734 | "babel-plugin-transform-es2015-block-scoped-functions": "6.22.0",
735 | "babel-plugin-transform-es2015-block-scoping": "6.26.0",
736 | "babel-plugin-transform-es2015-classes": "6.24.1",
737 | "babel-plugin-transform-es2015-computed-properties": "6.24.1",
738 | "babel-plugin-transform-es2015-destructuring": "6.23.0",
739 | "babel-plugin-transform-es2015-duplicate-keys": "6.24.1",
740 | "babel-plugin-transform-es2015-for-of": "6.23.0",
741 | "babel-plugin-transform-es2015-function-name": "6.24.1",
742 | "babel-plugin-transform-es2015-literals": "6.22.0",
743 | "babel-plugin-transform-es2015-modules-amd": "6.24.1",
744 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0",
745 | "babel-plugin-transform-es2015-modules-systemjs": "6.24.1",
746 | "babel-plugin-transform-es2015-modules-umd": "6.24.1",
747 | "babel-plugin-transform-es2015-object-super": "6.24.1",
748 | "babel-plugin-transform-es2015-parameters": "6.24.1",
749 | "babel-plugin-transform-es2015-shorthand-properties": "6.24.1",
750 | "babel-plugin-transform-es2015-spread": "6.22.0",
751 | "babel-plugin-transform-es2015-sticky-regex": "6.24.1",
752 | "babel-plugin-transform-es2015-template-literals": "6.22.0",
753 | "babel-plugin-transform-es2015-typeof-symbol": "6.23.0",
754 | "babel-plugin-transform-es2015-unicode-regex": "6.24.1",
755 | "babel-plugin-transform-regenerator": "6.26.0"
756 | }
757 | },
758 | "babel-preset-es2016": {
759 | "version": "6.24.1",
760 | "resolved": "https://registry.npmjs.org/babel-preset-es2016/-/babel-preset-es2016-6.24.1.tgz",
761 | "integrity": "sha1-+QC/k+LrwNJ235uKtZck6/2Vn4s=",
762 | "dev": true,
763 | "requires": {
764 | "babel-plugin-transform-exponentiation-operator": "6.24.1"
765 | }
766 | },
767 | "babel-preset-es2017": {
768 | "version": "6.24.1",
769 | "resolved": "https://registry.npmjs.org/babel-preset-es2017/-/babel-preset-es2017-6.24.1.tgz",
770 | "integrity": "sha1-WXvq37n38gi8/YoS6bKym4svFNE=",
771 | "dev": true,
772 | "requires": {
773 | "babel-plugin-syntax-trailing-function-commas": "6.22.0",
774 | "babel-plugin-transform-async-to-generator": "6.24.1"
775 | }
776 | },
777 | "babel-preset-flow": {
778 | "version": "6.23.0",
779 | "resolved": "https://registry.npmjs.org/babel-preset-flow/-/babel-preset-flow-6.23.0.tgz",
780 | "integrity": "sha1-5xIYiHCFrpoktb5Baa/7WZgWxJ0=",
781 | "dev": true,
782 | "requires": {
783 | "babel-plugin-transform-flow-strip-types": "6.22.0"
784 | }
785 | },
786 | "babel-preset-latest": {
787 | "version": "6.24.1",
788 | "resolved": "https://registry.npmjs.org/babel-preset-latest/-/babel-preset-latest-6.24.1.tgz",
789 | "integrity": "sha1-Z33gaRVKdIXC0lxXfAL2JLhbheg=",
790 | "dev": true,
791 | "requires": {
792 | "babel-preset-es2015": "6.24.1",
793 | "babel-preset-es2016": "6.24.1",
794 | "babel-preset-es2017": "6.24.1"
795 | }
796 | },
797 | "babel-preset-react": {
798 | "version": "6.24.1",
799 | "resolved": "https://registry.npmjs.org/babel-preset-react/-/babel-preset-react-6.24.1.tgz",
800 | "integrity": "sha1-umnfrqRfw+xjm2pOzqbhdwLJE4A=",
801 | "dev": true,
802 | "requires": {
803 | "babel-plugin-syntax-jsx": "6.18.0",
804 | "babel-plugin-transform-react-display-name": "6.25.0",
805 | "babel-plugin-transform-react-jsx": "6.24.1",
806 | "babel-plugin-transform-react-jsx-self": "6.22.0",
807 | "babel-plugin-transform-react-jsx-source": "6.22.0",
808 | "babel-preset-flow": "6.23.0"
809 | }
810 | },
811 | "babel-register": {
812 | "version": "6.26.0",
813 | "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz",
814 | "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=",
815 | "dev": true,
816 | "requires": {
817 | "babel-core": "6.26.0",
818 | "babel-runtime": "6.26.0",
819 | "core-js": "2.5.3",
820 | "home-or-tmp": "2.0.0",
821 | "lodash": "4.17.5",
822 | "mkdirp": "0.5.1",
823 | "source-map-support": "0.4.18"
824 | }
825 | },
826 | "babel-runtime": {
827 | "version": "6.26.0",
828 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz",
829 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=",
830 | "dev": true,
831 | "requires": {
832 | "core-js": "2.5.3",
833 | "regenerator-runtime": "0.11.1"
834 | }
835 | },
836 | "babel-template": {
837 | "version": "6.26.0",
838 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz",
839 | "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=",
840 | "dev": true,
841 | "requires": {
842 | "babel-runtime": "6.26.0",
843 | "babel-traverse": "6.26.0",
844 | "babel-types": "6.26.0",
845 | "babylon": "6.18.0",
846 | "lodash": "4.17.5"
847 | }
848 | },
849 | "babel-traverse": {
850 | "version": "6.26.0",
851 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz",
852 | "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=",
853 | "dev": true,
854 | "requires": {
855 | "babel-code-frame": "6.26.0",
856 | "babel-messages": "6.23.0",
857 | "babel-runtime": "6.26.0",
858 | "babel-types": "6.26.0",
859 | "babylon": "6.18.0",
860 | "debug": "2.6.9",
861 | "globals": "9.18.0",
862 | "invariant": "2.2.4",
863 | "lodash": "4.17.5"
864 | }
865 | },
866 | "babel-types": {
867 | "version": "6.26.0",
868 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz",
869 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=",
870 | "dev": true,
871 | "requires": {
872 | "babel-runtime": "6.26.0",
873 | "esutils": "2.0.2",
874 | "lodash": "4.17.5",
875 | "to-fast-properties": "1.0.3"
876 | }
877 | },
878 | "babylon": {
879 | "version": "6.18.0",
880 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz",
881 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==",
882 | "dev": true
883 | },
884 | "balanced-match": {
885 | "version": "1.0.0",
886 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
887 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
888 | "dev": true
889 | },
890 | "base64-js": {
891 | "version": "1.2.3",
892 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.2.3.tgz",
893 | "integrity": "sha512-MsAhsUW1GxCdgYSO6tAfZrNapmUKk7mWx/k5mFY/A1gBtkaCaNapTg+FExCw1r9yeaZhqx/xPg43xgTFH6KL5w==",
894 | "dev": true
895 | },
896 | "binary-extensions": {
897 | "version": "1.11.0",
898 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz",
899 | "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=",
900 | "dev": true
901 | },
902 | "bn.js": {
903 | "version": "4.11.8",
904 | "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz",
905 | "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==",
906 | "dev": true
907 | },
908 | "body-parser": {
909 | "version": "1.18.2",
910 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz",
911 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=",
912 | "dev": true,
913 | "requires": {
914 | "bytes": "3.0.0",
915 | "content-type": "1.0.4",
916 | "debug": "2.6.9",
917 | "depd": "1.1.2",
918 | "http-errors": "1.6.2",
919 | "iconv-lite": "0.4.19",
920 | "on-finished": "2.3.0",
921 | "qs": "6.5.1",
922 | "raw-body": "2.3.2",
923 | "type-is": "1.6.16"
924 | }
925 | },
926 | "bower-config": {
927 | "version": "1.4.1",
928 | "resolved": "https://registry.npmjs.org/bower-config/-/bower-config-1.4.1.tgz",
929 | "integrity": "sha1-hf2d82fCuNu9DKpMXyutQM2Ewsw=",
930 | "dev": true,
931 | "requires": {
932 | "graceful-fs": "4.1.11",
933 | "mout": "1.1.0",
934 | "optimist": "0.6.1",
935 | "osenv": "0.1.5",
936 | "untildify": "2.1.0"
937 | }
938 | },
939 | "brace-expansion": {
940 | "version": "1.1.11",
941 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
942 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
943 | "dev": true,
944 | "requires": {
945 | "balanced-match": "1.0.0",
946 | "concat-map": "0.0.1"
947 | }
948 | },
949 | "braces": {
950 | "version": "1.8.5",
951 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz",
952 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=",
953 | "dev": true,
954 | "requires": {
955 | "expand-range": "1.8.2",
956 | "preserve": "0.2.0",
957 | "repeat-element": "1.1.2"
958 | }
959 | },
960 | "brorand": {
961 | "version": "1.1.0",
962 | "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz",
963 | "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=",
964 | "dev": true
965 | },
966 | "browser-resolve": {
967 | "version": "1.11.2",
968 | "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.2.tgz",
969 | "integrity": "sha1-j/CbCixCFxihBRwmCzLkj0QpOM4=",
970 | "dev": true,
971 | "requires": {
972 | "resolve": "1.1.7"
973 | }
974 | },
975 | "browserify-aes": {
976 | "version": "1.1.1",
977 | "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.1.1.tgz",
978 | "integrity": "sha512-UGnTYAnB2a3YuYKIRy1/4FB2HdM866E0qC46JXvVTYKlBlZlnvfpSfY6OKfXZAkv70eJ2a1SqzpAo5CRhZGDFg==",
979 | "dev": true,
980 | "requires": {
981 | "buffer-xor": "1.0.3",
982 | "cipher-base": "1.0.4",
983 | "create-hash": "1.1.3",
984 | "evp_bytestokey": "1.0.3",
985 | "inherits": "2.0.3",
986 | "safe-buffer": "5.1.1"
987 | }
988 | },
989 | "browserify-cipher": {
990 | "version": "1.0.0",
991 | "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.0.tgz",
992 | "integrity": "sha1-mYgkSHS/XtTijalWZtzWasj8Njo=",
993 | "dev": true,
994 | "requires": {
995 | "browserify-aes": "1.1.1",
996 | "browserify-des": "1.0.0",
997 | "evp_bytestokey": "1.0.3"
998 | }
999 | },
1000 | "browserify-des": {
1001 | "version": "1.0.0",
1002 | "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.0.tgz",
1003 | "integrity": "sha1-2qJ3cXRwki7S/hhZQRihdUOXId0=",
1004 | "dev": true,
1005 | "requires": {
1006 | "cipher-base": "1.0.4",
1007 | "des.js": "1.0.0",
1008 | "inherits": "2.0.3"
1009 | }
1010 | },
1011 | "browserify-rsa": {
1012 | "version": "4.0.1",
1013 | "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz",
1014 | "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=",
1015 | "dev": true,
1016 | "requires": {
1017 | "bn.js": "4.11.8",
1018 | "randombytes": "2.0.6"
1019 | }
1020 | },
1021 | "browserify-sign": {
1022 | "version": "4.0.4",
1023 | "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.0.4.tgz",
1024 | "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=",
1025 | "dev": true,
1026 | "requires": {
1027 | "bn.js": "4.11.8",
1028 | "browserify-rsa": "4.0.1",
1029 | "create-hash": "1.1.3",
1030 | "create-hmac": "1.1.6",
1031 | "elliptic": "6.4.0",
1032 | "inherits": "2.0.3",
1033 | "parse-asn1": "5.1.0"
1034 | }
1035 | },
1036 | "brunch": {
1037 | "version": "2.10.9",
1038 | "resolved": "https://registry.npmjs.org/brunch/-/brunch-2.10.9.tgz",
1039 | "integrity": "sha1-p0u1rvh/qHzg3Uyk+ZZhAgQ1jTA=",
1040 | "dev": true,
1041 | "requires": {
1042 | "anymatch": "1.3.2",
1043 | "anysort": "1.0.1",
1044 | "check-dependencies": "1.0.1",
1045 | "chokidar": "1.7.0",
1046 | "coffee-script": "1.11.1",
1047 | "commander": "2.9.0",
1048 | "commonjs-require-definition": "0.6.2",
1049 | "debug": "2.2.0",
1050 | "deppack": "0.7.0",
1051 | "deps-install": "0.1.1",
1052 | "fcache": "0.3.0",
1053 | "init-skeleton": "1.0.1",
1054 | "loggy": "1.0.2",
1055 | "micro-es7-shim": "0.1.0",
1056 | "micro-promisify": "0.1.1",
1057 | "mkdirp": "0.5.1",
1058 | "promise.prototype.finally": "2.0.1",
1059 | "read-components": "0.7.0",
1060 | "serve-brunch": "0.2.0",
1061 | "since-app-start": "0.3.2",
1062 | "skemata": "0.1.2",
1063 | "source-map": "0.5.7",
1064 | "universal-path": "0.1.0"
1065 | },
1066 | "dependencies": {
1067 | "debug": {
1068 | "version": "2.2.0",
1069 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz",
1070 | "integrity": "sha1-+HBX6ZWxofauaklgZkE3vFbwOdo=",
1071 | "dev": true,
1072 | "requires": {
1073 | "ms": "0.7.1"
1074 | }
1075 | },
1076 | "ms": {
1077 | "version": "0.7.1",
1078 | "resolved": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz",
1079 | "integrity": "sha1-nNE8A62/8ltl7/3nzoZO6VIBcJg=",
1080 | "dev": true
1081 | }
1082 | }
1083 | },
1084 | "brunch-skeletons": {
1085 | "version": "0.1.6",
1086 | "resolved": "https://registry.npmjs.org/brunch-skeletons/-/brunch-skeletons-0.1.6.tgz",
1087 | "integrity": "sha512-x5ASPnG5yKyJFxJsCOydNPezP/YEyk4fB8GH9pdQA8sK2tFIO+RR0zzQ34Fs0y6AGcQJvx1FZvNjqW4f3Q5M3w==",
1088 | "dev": true
1089 | },
1090 | "buffer": {
1091 | "version": "4.3.1",
1092 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.3.1.tgz",
1093 | "integrity": "sha1-DmX9Acw+kVTRUvazyTS1uKG2czw=",
1094 | "dev": true,
1095 | "requires": {
1096 | "base64-js": "1.2.3",
1097 | "ieee754": "1.1.9",
1098 | "isarray": "1.0.0"
1099 | }
1100 | },
1101 | "buffer-xor": {
1102 | "version": "1.0.3",
1103 | "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz",
1104 | "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=",
1105 | "dev": true
1106 | },
1107 | "builtin-status-codes": {
1108 | "version": "2.0.0",
1109 | "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-2.0.0.tgz",
1110 | "integrity": "sha1-byIAO6rPADzNKHr+aHIVH93FhXk=",
1111 | "dev": true
1112 | },
1113 | "bytes": {
1114 | "version": "3.0.0",
1115 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz",
1116 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=",
1117 | "dev": true
1118 | },
1119 | "camelcase": {
1120 | "version": "1.2.1",
1121 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz",
1122 | "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=",
1123 | "dev": true
1124 | },
1125 | "center-align": {
1126 | "version": "0.1.3",
1127 | "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz",
1128 | "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=",
1129 | "dev": true,
1130 | "requires": {
1131 | "align-text": "0.1.4",
1132 | "lazy-cache": "1.0.4"
1133 | }
1134 | },
1135 | "chalk": {
1136 | "version": "1.1.3",
1137 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz",
1138 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=",
1139 | "dev": true,
1140 | "requires": {
1141 | "ansi-styles": "2.2.1",
1142 | "escape-string-regexp": "1.0.5",
1143 | "has-ansi": "2.0.0",
1144 | "strip-ansi": "3.0.1",
1145 | "supports-color": "2.0.0"
1146 | }
1147 | },
1148 | "check-dependencies": {
1149 | "version": "1.0.1",
1150 | "resolved": "https://registry.npmjs.org/check-dependencies/-/check-dependencies-1.0.1.tgz",
1151 | "integrity": "sha1-nn8Vgi3iBiHsa5/6q6xNWIw4EbA=",
1152 | "dev": true,
1153 | "requires": {
1154 | "bower-config": "1.4.1",
1155 | "chalk": "1.1.3",
1156 | "findup-sync": "0.4.3",
1157 | "lodash.camelcase": "4.3.0",
1158 | "minimist": "1.2.0",
1159 | "semver": "5.5.0"
1160 | },
1161 | "dependencies": {
1162 | "minimist": {
1163 | "version": "1.2.0",
1164 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz",
1165 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=",
1166 | "dev": true
1167 | }
1168 | }
1169 | },
1170 | "chokidar": {
1171 | "version": "1.7.0",
1172 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz",
1173 | "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=",
1174 | "dev": true,
1175 | "requires": {
1176 | "anymatch": "1.3.2",
1177 | "async-each": "1.0.1",
1178 | "fsevents": "1.1.3",
1179 | "glob-parent": "2.0.0",
1180 | "inherits": "2.0.3",
1181 | "is-binary-path": "1.0.1",
1182 | "is-glob": "2.0.1",
1183 | "path-is-absolute": "1.0.1",
1184 | "readdirp": "2.1.0"
1185 | }
1186 | },
1187 | "cipher-base": {
1188 | "version": "1.0.4",
1189 | "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz",
1190 | "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==",
1191 | "dev": true,
1192 | "requires": {
1193 | "inherits": "2.0.3",
1194 | "safe-buffer": "5.1.1"
1195 | }
1196 | },
1197 | "clean-css": {
1198 | "version": "4.0.13",
1199 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.0.13.tgz",
1200 | "integrity": "sha1-/rKhdgYtcqbD5iTZITysagxIXoA=",
1201 | "dev": true,
1202 | "requires": {
1203 | "source-map": "0.5.7"
1204 | }
1205 | },
1206 | "clean-css-brunch": {
1207 | "version": "2.10.0",
1208 | "resolved": "https://registry.npmjs.org/clean-css-brunch/-/clean-css-brunch-2.10.0.tgz",
1209 | "integrity": "sha1-ahUeZQlYnNNB3OBJgaHHUGKiLRg=",
1210 | "dev": true,
1211 | "requires": {
1212 | "clean-css": "4.0.13"
1213 | }
1214 | },
1215 | "cliui": {
1216 | "version": "2.1.0",
1217 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz",
1218 | "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=",
1219 | "dev": true,
1220 | "requires": {
1221 | "center-align": "0.1.3",
1222 | "right-align": "0.1.3",
1223 | "wordwrap": "0.0.2"
1224 | },
1225 | "dependencies": {
1226 | "wordwrap": {
1227 | "version": "0.0.2",
1228 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz",
1229 | "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=",
1230 | "dev": true
1231 | }
1232 | }
1233 | },
1234 | "coffee-script": {
1235 | "version": "1.11.1",
1236 | "resolved": "https://registry.npmjs.org/coffee-script/-/coffee-script-1.11.1.tgz",
1237 | "integrity": "sha1-vxxHrWREOg2V0S3ysUfMCk2q1uk=",
1238 | "dev": true
1239 | },
1240 | "commander": {
1241 | "version": "2.9.0",
1242 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.9.0.tgz",
1243 | "integrity": "sha1-nJkJQXbhIkDLItbFFGCYQA/g99Q=",
1244 | "dev": true,
1245 | "requires": {
1246 | "graceful-readlink": "1.0.1"
1247 | }
1248 | },
1249 | "commonjs-require-definition": {
1250 | "version": "0.6.2",
1251 | "resolved": "https://registry.npmjs.org/commonjs-require-definition/-/commonjs-require-definition-0.6.2.tgz",
1252 | "integrity": "sha1-G2ahur5gJgXB7gpthuLiZ5nKfOw=",
1253 | "dev": true
1254 | },
1255 | "concat-map": {
1256 | "version": "0.0.1",
1257 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
1258 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
1259 | "dev": true
1260 | },
1261 | "connect-slashes": {
1262 | "version": "1.3.1",
1263 | "resolved": "https://registry.npmjs.org/connect-slashes/-/connect-slashes-1.3.1.tgz",
1264 | "integrity": "sha1-ldYYMND51YU8hojwtfQ5iLGGrDc=",
1265 | "dev": true
1266 | },
1267 | "content-disposition": {
1268 | "version": "0.5.2",
1269 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz",
1270 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=",
1271 | "dev": true
1272 | },
1273 | "content-type": {
1274 | "version": "1.0.4",
1275 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
1276 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==",
1277 | "dev": true
1278 | },
1279 | "convert-source-map": {
1280 | "version": "1.5.1",
1281 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz",
1282 | "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=",
1283 | "dev": true
1284 | },
1285 | "cookie": {
1286 | "version": "0.3.1",
1287 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz",
1288 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=",
1289 | "dev": true
1290 | },
1291 | "cookie-signature": {
1292 | "version": "1.0.6",
1293 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
1294 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=",
1295 | "dev": true
1296 | },
1297 | "core-js": {
1298 | "version": "2.5.3",
1299 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.3.tgz",
1300 | "integrity": "sha1-isw4NFgk8W2DZbfJtCWRaOjtYD4=",
1301 | "dev": true
1302 | },
1303 | "core-util-is": {
1304 | "version": "1.0.2",
1305 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
1306 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
1307 | "dev": true
1308 | },
1309 | "create-ecdh": {
1310 | "version": "4.0.0",
1311 | "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.0.tgz",
1312 | "integrity": "sha1-iIxyNZbN92EvZJgjPuvXo1MBc30=",
1313 | "dev": true,
1314 | "requires": {
1315 | "bn.js": "4.11.8",
1316 | "elliptic": "6.4.0"
1317 | }
1318 | },
1319 | "create-hash": {
1320 | "version": "1.1.3",
1321 | "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.1.3.tgz",
1322 | "integrity": "sha1-YGBCrIuSYnUPSDyt2rD1gZFy2P0=",
1323 | "dev": true,
1324 | "requires": {
1325 | "cipher-base": "1.0.4",
1326 | "inherits": "2.0.3",
1327 | "ripemd160": "2.0.1",
1328 | "sha.js": "2.4.10"
1329 | }
1330 | },
1331 | "create-hmac": {
1332 | "version": "1.1.6",
1333 | "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.6.tgz",
1334 | "integrity": "sha1-rLniIaThe9sHbpBlfEK5PjcmzwY=",
1335 | "dev": true,
1336 | "requires": {
1337 | "cipher-base": "1.0.4",
1338 | "create-hash": "1.1.3",
1339 | "inherits": "2.0.3",
1340 | "ripemd160": "2.0.1",
1341 | "safe-buffer": "5.1.1",
1342 | "sha.js": "2.4.10"
1343 | }
1344 | },
1345 | "crypto-browserify": {
1346 | "version": "3.11.1",
1347 | "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.11.1.tgz",
1348 | "integrity": "sha512-Na7ZlwCOqoaW5RwUK1WpXws2kv8mNhWdTlzob0UXulk6G9BDbyiJaGTYBIX61Ozn9l1EPPJpICZb4DaOpT9NlQ==",
1349 | "dev": true,
1350 | "requires": {
1351 | "browserify-cipher": "1.0.0",
1352 | "browserify-sign": "4.0.4",
1353 | "create-ecdh": "4.0.0",
1354 | "create-hash": "1.1.3",
1355 | "create-hmac": "1.1.6",
1356 | "diffie-hellman": "5.0.2",
1357 | "inherits": "2.0.3",
1358 | "pbkdf2": "3.0.14",
1359 | "public-encrypt": "4.0.0",
1360 | "randombytes": "2.0.6"
1361 | }
1362 | },
1363 | "debug": {
1364 | "version": "2.6.9",
1365 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
1366 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
1367 | "dev": true,
1368 | "requires": {
1369 | "ms": "2.0.0"
1370 | }
1371 | },
1372 | "decamelize": {
1373 | "version": "1.2.0",
1374 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz",
1375 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=",
1376 | "dev": true
1377 | },
1378 | "deep-assign": {
1379 | "version": "2.0.0",
1380 | "resolved": "https://registry.npmjs.org/deep-assign/-/deep-assign-2.0.0.tgz",
1381 | "integrity": "sha1-6+BrHwfwja5ZdiDj3RYi83GhxXI=",
1382 | "dev": true,
1383 | "requires": {
1384 | "is-obj": "1.0.1"
1385 | }
1386 | },
1387 | "define-properties": {
1388 | "version": "1.1.2",
1389 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz",
1390 | "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=",
1391 | "dev": true,
1392 | "requires": {
1393 | "foreach": "2.0.5",
1394 | "object-keys": "1.0.11"
1395 | }
1396 | },
1397 | "defined": {
1398 | "version": "1.0.0",
1399 | "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz",
1400 | "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=",
1401 | "dev": true
1402 | },
1403 | "depd": {
1404 | "version": "1.1.2",
1405 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
1406 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=",
1407 | "dev": true
1408 | },
1409 | "deppack": {
1410 | "version": "0.7.0",
1411 | "resolved": "https://registry.npmjs.org/deppack/-/deppack-0.7.0.tgz",
1412 | "integrity": "sha1-+7hPmlMazi8oKJCSr8BWgpXHkLc=",
1413 | "dev": true,
1414 | "requires": {
1415 | "anymatch": "1.3.2",
1416 | "async-each": "1.0.1",
1417 | "browser-resolve": "1.11.2",
1418 | "deep-assign": "2.0.0",
1419 | "detective": "4.7.1",
1420 | "glob": "7.1.2",
1421 | "loggy": "0.3.5",
1422 | "micro-promisify": "0.1.1",
1423 | "node-browser-modules": "0.1.0",
1424 | "true-case-path": "1.0.2"
1425 | },
1426 | "dependencies": {
1427 | "loggy": {
1428 | "version": "0.3.5",
1429 | "resolved": "https://registry.npmjs.org/loggy/-/loggy-0.3.5.tgz",
1430 | "integrity": "sha1-M/EoAbH2Bjlm6nnZtqJduPy8QQc=",
1431 | "dev": true,
1432 | "requires": {
1433 | "ansicolors": "0.3.2",
1434 | "growl": "1.8.1"
1435 | }
1436 | }
1437 | }
1438 | },
1439 | "deps-install": {
1440 | "version": "0.1.1",
1441 | "resolved": "https://registry.npmjs.org/deps-install/-/deps-install-0.1.1.tgz",
1442 | "integrity": "sha512-jWfJiF0TZ4DgMcx6TIshx/slF6MexjHxik6iGlAx89z5cxHHtF/zt9c9UOC41PJX5kkJhlpXdU9msTq4K1v4Qg==",
1443 | "dev": true,
1444 | "requires": {
1445 | "loggy": "1.0.2",
1446 | "micro-promisify": "0.1.1"
1447 | }
1448 | },
1449 | "des.js": {
1450 | "version": "1.0.0",
1451 | "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.0.tgz",
1452 | "integrity": "sha1-wHTS4qpqipoH29YfmhXCzYPsjsw=",
1453 | "dev": true,
1454 | "requires": {
1455 | "inherits": "2.0.3",
1456 | "minimalistic-assert": "1.0.0"
1457 | }
1458 | },
1459 | "destroy": {
1460 | "version": "1.0.4",
1461 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
1462 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=",
1463 | "dev": true
1464 | },
1465 | "detect-file": {
1466 | "version": "0.1.0",
1467 | "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-0.1.0.tgz",
1468 | "integrity": "sha1-STXe39lIhkjgBrASlWbpOGcR6mM=",
1469 | "dev": true,
1470 | "requires": {
1471 | "fs-exists-sync": "0.1.0"
1472 | }
1473 | },
1474 | "detect-indent": {
1475 | "version": "4.0.0",
1476 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz",
1477 | "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=",
1478 | "dev": true,
1479 | "requires": {
1480 | "repeating": "2.0.1"
1481 | }
1482 | },
1483 | "detective": {
1484 | "version": "4.7.1",
1485 | "resolved": "https://registry.npmjs.org/detective/-/detective-4.7.1.tgz",
1486 | "integrity": "sha512-H6PmeeUcZloWtdt4DAkFyzFL94arpHr3NOwwmVILFiy+9Qd4JTxxXrzfyGk/lmct2qVGBwTSwSXagqu2BxmWig==",
1487 | "dev": true,
1488 | "requires": {
1489 | "acorn": "5.5.3",
1490 | "defined": "1.0.0"
1491 | }
1492 | },
1493 | "diffie-hellman": {
1494 | "version": "5.0.2",
1495 | "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.2.tgz",
1496 | "integrity": "sha1-tYNXOScM/ias9jIJn97SoH8gnl4=",
1497 | "dev": true,
1498 | "requires": {
1499 | "bn.js": "4.11.8",
1500 | "miller-rabin": "4.0.1",
1501 | "randombytes": "2.0.6"
1502 | }
1503 | },
1504 | "domain-browser": {
1505 | "version": "1.1.7",
1506 | "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.1.7.tgz",
1507 | "integrity": "sha1-hnqksJP6oF8d4IwG9NeyH9+GmLw=",
1508 | "dev": true
1509 | },
1510 | "ee-first": {
1511 | "version": "1.1.1",
1512 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
1513 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=",
1514 | "dev": true
1515 | },
1516 | "elliptic": {
1517 | "version": "6.4.0",
1518 | "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.4.0.tgz",
1519 | "integrity": "sha1-ysmvh2LIWDYYcAPI3+GT5eLq5d8=",
1520 | "dev": true,
1521 | "requires": {
1522 | "bn.js": "4.11.8",
1523 | "brorand": "1.1.0",
1524 | "hash.js": "1.1.3",
1525 | "hmac-drbg": "1.0.1",
1526 | "inherits": "2.0.3",
1527 | "minimalistic-assert": "1.0.0",
1528 | "minimalistic-crypto-utils": "1.0.1"
1529 | }
1530 | },
1531 | "encodeurl": {
1532 | "version": "1.0.2",
1533 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
1534 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=",
1535 | "dev": true
1536 | },
1537 | "encoding": {
1538 | "version": "0.1.12",
1539 | "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.12.tgz",
1540 | "integrity": "sha1-U4tm8+5izRq1HsMjgp0flIDHS+s=",
1541 | "requires": {
1542 | "iconv-lite": "0.4.19"
1543 | }
1544 | },
1545 | "es-abstract": {
1546 | "version": "1.10.0",
1547 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.10.0.tgz",
1548 | "integrity": "sha512-/uh/DhdqIOSkAWifU+8nG78vlQxdLckUdI/sPgy0VhuXi2qJ7T8czBmqIYtLQVpCIFYafChnsRsB5pyb1JdmCQ==",
1549 | "dev": true,
1550 | "requires": {
1551 | "es-to-primitive": "1.1.1",
1552 | "function-bind": "1.1.1",
1553 | "has": "1.0.1",
1554 | "is-callable": "1.1.3",
1555 | "is-regex": "1.0.4"
1556 | }
1557 | },
1558 | "es-to-primitive": {
1559 | "version": "1.1.1",
1560 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.1.1.tgz",
1561 | "integrity": "sha1-RTVSSKiJeQNLZ5Lhm7gfK3l13Q0=",
1562 | "dev": true,
1563 | "requires": {
1564 | "is-callable": "1.1.3",
1565 | "is-date-object": "1.0.1",
1566 | "is-symbol": "1.0.1"
1567 | }
1568 | },
1569 | "escape-html": {
1570 | "version": "1.0.3",
1571 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
1572 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=",
1573 | "dev": true
1574 | },
1575 | "escape-string-regexp": {
1576 | "version": "1.0.5",
1577 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
1578 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
1579 | "dev": true
1580 | },
1581 | "esutils": {
1582 | "version": "2.0.2",
1583 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz",
1584 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=",
1585 | "dev": true
1586 | },
1587 | "etag": {
1588 | "version": "1.8.1",
1589 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
1590 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=",
1591 | "dev": true
1592 | },
1593 | "events": {
1594 | "version": "1.1.1",
1595 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz",
1596 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=",
1597 | "dev": true
1598 | },
1599 | "evp_bytestokey": {
1600 | "version": "1.0.3",
1601 | "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz",
1602 | "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==",
1603 | "dev": true,
1604 | "requires": {
1605 | "md5.js": "1.3.4",
1606 | "safe-buffer": "5.1.1"
1607 | }
1608 | },
1609 | "expand-brackets": {
1610 | "version": "0.1.5",
1611 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz",
1612 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=",
1613 | "dev": true,
1614 | "requires": {
1615 | "is-posix-bracket": "0.1.1"
1616 | }
1617 | },
1618 | "expand-range": {
1619 | "version": "1.8.2",
1620 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz",
1621 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=",
1622 | "dev": true,
1623 | "requires": {
1624 | "fill-range": "2.2.3"
1625 | }
1626 | },
1627 | "expand-tilde": {
1628 | "version": "1.2.2",
1629 | "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-1.2.2.tgz",
1630 | "integrity": "sha1-C4HrqJflo9MdHD0QL48BRB5VlEk=",
1631 | "dev": true,
1632 | "requires": {
1633 | "os-homedir": "1.0.2"
1634 | }
1635 | },
1636 | "express": {
1637 | "version": "4.16.3",
1638 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.3.tgz",
1639 | "integrity": "sha1-avilAjUNsyRuzEvs9rWjTSL37VM=",
1640 | "dev": true,
1641 | "requires": {
1642 | "accepts": "1.3.5",
1643 | "array-flatten": "1.1.1",
1644 | "body-parser": "1.18.2",
1645 | "content-disposition": "0.5.2",
1646 | "content-type": "1.0.4",
1647 | "cookie": "0.3.1",
1648 | "cookie-signature": "1.0.6",
1649 | "debug": "2.6.9",
1650 | "depd": "1.1.2",
1651 | "encodeurl": "1.0.2",
1652 | "escape-html": "1.0.3",
1653 | "etag": "1.8.1",
1654 | "finalhandler": "1.1.1",
1655 | "fresh": "0.5.2",
1656 | "merge-descriptors": "1.0.1",
1657 | "methods": "1.1.2",
1658 | "on-finished": "2.3.0",
1659 | "parseurl": "1.3.2",
1660 | "path-to-regexp": "0.1.7",
1661 | "proxy-addr": "2.0.3",
1662 | "qs": "6.5.1",
1663 | "range-parser": "1.2.0",
1664 | "safe-buffer": "5.1.1",
1665 | "send": "0.16.2",
1666 | "serve-static": "1.13.2",
1667 | "setprototypeof": "1.1.0",
1668 | "statuses": "1.4.0",
1669 | "type-is": "1.6.16",
1670 | "utils-merge": "1.0.1",
1671 | "vary": "1.1.2"
1672 | }
1673 | },
1674 | "extglob": {
1675 | "version": "0.3.2",
1676 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz",
1677 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=",
1678 | "dev": true,
1679 | "requires": {
1680 | "is-extglob": "1.0.0"
1681 | }
1682 | },
1683 | "fast-levenshtein": {
1684 | "version": "1.1.4",
1685 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-1.1.4.tgz",
1686 | "integrity": "sha1-5qdUzI8V5YmHqpy9J69m/W9OWvk=",
1687 | "dev": true
1688 | },
1689 | "fbjs": {
1690 | "version": "0.8.16",
1691 | "resolved": "https://registry.npmjs.org/fbjs/-/fbjs-0.8.16.tgz",
1692 | "integrity": "sha1-XmdDL1UNxBtXK/VYR7ispk5TN9s=",
1693 | "requires": {
1694 | "core-js": "1.2.7",
1695 | "isomorphic-fetch": "2.2.1",
1696 | "loose-envify": "1.3.1",
1697 | "object-assign": "4.1.1",
1698 | "promise": "7.3.1",
1699 | "setimmediate": "1.0.5",
1700 | "ua-parser-js": "0.7.17"
1701 | },
1702 | "dependencies": {
1703 | "core-js": {
1704 | "version": "1.2.7",
1705 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-1.2.7.tgz",
1706 | "integrity": "sha1-ZSKUwUZR2yj6k70tX/KYOk8IxjY="
1707 | }
1708 | }
1709 | },
1710 | "fcache": {
1711 | "version": "0.3.0",
1712 | "resolved": "https://registry.npmjs.org/fcache/-/fcache-0.3.0.tgz",
1713 | "integrity": "sha1-1F8vkIZCuRt5jogZXsR4gaUcPUQ=",
1714 | "dev": true
1715 | },
1716 | "filename-regex": {
1717 | "version": "2.0.1",
1718 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz",
1719 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=",
1720 | "dev": true
1721 | },
1722 | "fill-range": {
1723 | "version": "2.2.3",
1724 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz",
1725 | "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=",
1726 | "dev": true,
1727 | "requires": {
1728 | "is-number": "2.1.0",
1729 | "isobject": "2.1.0",
1730 | "randomatic": "1.1.7",
1731 | "repeat-element": "1.1.2",
1732 | "repeat-string": "1.6.1"
1733 | }
1734 | },
1735 | "finalhandler": {
1736 | "version": "1.1.1",
1737 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz",
1738 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==",
1739 | "dev": true,
1740 | "requires": {
1741 | "debug": "2.6.9",
1742 | "encodeurl": "1.0.2",
1743 | "escape-html": "1.0.3",
1744 | "on-finished": "2.3.0",
1745 | "parseurl": "1.3.2",
1746 | "statuses": "1.4.0",
1747 | "unpipe": "1.0.0"
1748 | }
1749 | },
1750 | "findup-sync": {
1751 | "version": "0.4.3",
1752 | "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-0.4.3.tgz",
1753 | "integrity": "sha1-QAQ5Kee8YK3wt/SCfExudaDeyhI=",
1754 | "dev": true,
1755 | "requires": {
1756 | "detect-file": "0.1.0",
1757 | "is-glob": "2.0.1",
1758 | "micromatch": "2.3.11",
1759 | "resolve-dir": "0.1.1"
1760 | }
1761 | },
1762 | "for-in": {
1763 | "version": "1.0.2",
1764 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
1765 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=",
1766 | "dev": true
1767 | },
1768 | "for-own": {
1769 | "version": "0.1.5",
1770 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz",
1771 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=",
1772 | "dev": true,
1773 | "requires": {
1774 | "for-in": "1.0.2"
1775 | }
1776 | },
1777 | "foreach": {
1778 | "version": "2.0.5",
1779 | "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz",
1780 | "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=",
1781 | "dev": true
1782 | },
1783 | "forwarded": {
1784 | "version": "0.1.2",
1785 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz",
1786 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=",
1787 | "dev": true
1788 | },
1789 | "fresh": {
1790 | "version": "0.5.2",
1791 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
1792 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=",
1793 | "dev": true
1794 | },
1795 | "fs-exists-sync": {
1796 | "version": "0.1.0",
1797 | "resolved": "https://registry.npmjs.org/fs-exists-sync/-/fs-exists-sync-0.1.0.tgz",
1798 | "integrity": "sha1-mC1ok6+RjnLQjeyehnP/K1qNat0=",
1799 | "dev": true
1800 | },
1801 | "fs.realpath": {
1802 | "version": "1.0.0",
1803 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
1804 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
1805 | "dev": true
1806 | },
1807 | "fsevents": {
1808 | "version": "1.1.3",
1809 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.1.3.tgz",
1810 | "integrity": "sha512-WIr7iDkdmdbxu/Gh6eKEZJL6KPE74/5MEsf2whTOFNxbIoIixogroLdKYqB6FDav4Wavh/lZdzzd3b2KxIXC5Q==",
1811 | "dev": true,
1812 | "optional": true,
1813 | "requires": {
1814 | "nan": "2.10.0",
1815 | "node-pre-gyp": "0.6.39"
1816 | },
1817 | "dependencies": {
1818 | "abbrev": {
1819 | "version": "1.1.0",
1820 | "bundled": true,
1821 | "dev": true,
1822 | "optional": true
1823 | },
1824 | "ajv": {
1825 | "version": "4.11.8",
1826 | "bundled": true,
1827 | "dev": true,
1828 | "optional": true,
1829 | "requires": {
1830 | "co": "4.6.0",
1831 | "json-stable-stringify": "1.0.1"
1832 | }
1833 | },
1834 | "ansi-regex": {
1835 | "version": "2.1.1",
1836 | "bundled": true,
1837 | "dev": true
1838 | },
1839 | "aproba": {
1840 | "version": "1.1.1",
1841 | "bundled": true,
1842 | "dev": true,
1843 | "optional": true
1844 | },
1845 | "are-we-there-yet": {
1846 | "version": "1.1.4",
1847 | "bundled": true,
1848 | "dev": true,
1849 | "optional": true,
1850 | "requires": {
1851 | "delegates": "1.0.0",
1852 | "readable-stream": "2.2.9"
1853 | }
1854 | },
1855 | "asn1": {
1856 | "version": "0.2.3",
1857 | "bundled": true,
1858 | "dev": true,
1859 | "optional": true
1860 | },
1861 | "assert-plus": {
1862 | "version": "0.2.0",
1863 | "bundled": true,
1864 | "dev": true,
1865 | "optional": true
1866 | },
1867 | "asynckit": {
1868 | "version": "0.4.0",
1869 | "bundled": true,
1870 | "dev": true,
1871 | "optional": true
1872 | },
1873 | "aws-sign2": {
1874 | "version": "0.6.0",
1875 | "bundled": true,
1876 | "dev": true,
1877 | "optional": true
1878 | },
1879 | "aws4": {
1880 | "version": "1.6.0",
1881 | "bundled": true,
1882 | "dev": true,
1883 | "optional": true
1884 | },
1885 | "balanced-match": {
1886 | "version": "0.4.2",
1887 | "bundled": true,
1888 | "dev": true
1889 | },
1890 | "bcrypt-pbkdf": {
1891 | "version": "1.0.1",
1892 | "bundled": true,
1893 | "dev": true,
1894 | "optional": true,
1895 | "requires": {
1896 | "tweetnacl": "0.14.5"
1897 | }
1898 | },
1899 | "block-stream": {
1900 | "version": "0.0.9",
1901 | "bundled": true,
1902 | "dev": true,
1903 | "requires": {
1904 | "inherits": "2.0.3"
1905 | }
1906 | },
1907 | "boom": {
1908 | "version": "2.10.1",
1909 | "bundled": true,
1910 | "dev": true,
1911 | "requires": {
1912 | "hoek": "2.16.3"
1913 | }
1914 | },
1915 | "brace-expansion": {
1916 | "version": "1.1.7",
1917 | "bundled": true,
1918 | "dev": true,
1919 | "requires": {
1920 | "balanced-match": "0.4.2",
1921 | "concat-map": "0.0.1"
1922 | }
1923 | },
1924 | "buffer-shims": {
1925 | "version": "1.0.0",
1926 | "bundled": true,
1927 | "dev": true
1928 | },
1929 | "caseless": {
1930 | "version": "0.12.0",
1931 | "bundled": true,
1932 | "dev": true,
1933 | "optional": true
1934 | },
1935 | "co": {
1936 | "version": "4.6.0",
1937 | "bundled": true,
1938 | "dev": true,
1939 | "optional": true
1940 | },
1941 | "code-point-at": {
1942 | "version": "1.1.0",
1943 | "bundled": true,
1944 | "dev": true
1945 | },
1946 | "combined-stream": {
1947 | "version": "1.0.5",
1948 | "bundled": true,
1949 | "dev": true,
1950 | "requires": {
1951 | "delayed-stream": "1.0.0"
1952 | }
1953 | },
1954 | "concat-map": {
1955 | "version": "0.0.1",
1956 | "bundled": true,
1957 | "dev": true
1958 | },
1959 | "console-control-strings": {
1960 | "version": "1.1.0",
1961 | "bundled": true,
1962 | "dev": true
1963 | },
1964 | "core-util-is": {
1965 | "version": "1.0.2",
1966 | "bundled": true,
1967 | "dev": true
1968 | },
1969 | "cryptiles": {
1970 | "version": "2.0.5",
1971 | "bundled": true,
1972 | "dev": true,
1973 | "requires": {
1974 | "boom": "2.10.1"
1975 | }
1976 | },
1977 | "dashdash": {
1978 | "version": "1.14.1",
1979 | "bundled": true,
1980 | "dev": true,
1981 | "optional": true,
1982 | "requires": {
1983 | "assert-plus": "1.0.0"
1984 | },
1985 | "dependencies": {
1986 | "assert-plus": {
1987 | "version": "1.0.0",
1988 | "bundled": true,
1989 | "dev": true,
1990 | "optional": true
1991 | }
1992 | }
1993 | },
1994 | "debug": {
1995 | "version": "2.6.8",
1996 | "bundled": true,
1997 | "dev": true,
1998 | "optional": true,
1999 | "requires": {
2000 | "ms": "2.0.0"
2001 | }
2002 | },
2003 | "deep-extend": {
2004 | "version": "0.4.2",
2005 | "bundled": true,
2006 | "dev": true,
2007 | "optional": true
2008 | },
2009 | "delayed-stream": {
2010 | "version": "1.0.0",
2011 | "bundled": true,
2012 | "dev": true
2013 | },
2014 | "delegates": {
2015 | "version": "1.0.0",
2016 | "bundled": true,
2017 | "dev": true,
2018 | "optional": true
2019 | },
2020 | "detect-libc": {
2021 | "version": "1.0.2",
2022 | "bundled": true,
2023 | "dev": true,
2024 | "optional": true
2025 | },
2026 | "ecc-jsbn": {
2027 | "version": "0.1.1",
2028 | "bundled": true,
2029 | "dev": true,
2030 | "optional": true,
2031 | "requires": {
2032 | "jsbn": "0.1.1"
2033 | }
2034 | },
2035 | "extend": {
2036 | "version": "3.0.1",
2037 | "bundled": true,
2038 | "dev": true,
2039 | "optional": true
2040 | },
2041 | "extsprintf": {
2042 | "version": "1.0.2",
2043 | "bundled": true,
2044 | "dev": true
2045 | },
2046 | "forever-agent": {
2047 | "version": "0.6.1",
2048 | "bundled": true,
2049 | "dev": true,
2050 | "optional": true
2051 | },
2052 | "form-data": {
2053 | "version": "2.1.4",
2054 | "bundled": true,
2055 | "dev": true,
2056 | "optional": true,
2057 | "requires": {
2058 | "asynckit": "0.4.0",
2059 | "combined-stream": "1.0.5",
2060 | "mime-types": "2.1.15"
2061 | }
2062 | },
2063 | "fs.realpath": {
2064 | "version": "1.0.0",
2065 | "bundled": true,
2066 | "dev": true
2067 | },
2068 | "fstream": {
2069 | "version": "1.0.11",
2070 | "bundled": true,
2071 | "dev": true,
2072 | "requires": {
2073 | "graceful-fs": "4.1.11",
2074 | "inherits": "2.0.3",
2075 | "mkdirp": "0.5.1",
2076 | "rimraf": "2.6.1"
2077 | }
2078 | },
2079 | "fstream-ignore": {
2080 | "version": "1.0.5",
2081 | "bundled": true,
2082 | "dev": true,
2083 | "optional": true,
2084 | "requires": {
2085 | "fstream": "1.0.11",
2086 | "inherits": "2.0.3",
2087 | "minimatch": "3.0.4"
2088 | }
2089 | },
2090 | "gauge": {
2091 | "version": "2.7.4",
2092 | "bundled": true,
2093 | "dev": true,
2094 | "optional": true,
2095 | "requires": {
2096 | "aproba": "1.1.1",
2097 | "console-control-strings": "1.1.0",
2098 | "has-unicode": "2.0.1",
2099 | "object-assign": "4.1.1",
2100 | "signal-exit": "3.0.2",
2101 | "string-width": "1.0.2",
2102 | "strip-ansi": "3.0.1",
2103 | "wide-align": "1.1.2"
2104 | }
2105 | },
2106 | "getpass": {
2107 | "version": "0.1.7",
2108 | "bundled": true,
2109 | "dev": true,
2110 | "optional": true,
2111 | "requires": {
2112 | "assert-plus": "1.0.0"
2113 | },
2114 | "dependencies": {
2115 | "assert-plus": {
2116 | "version": "1.0.0",
2117 | "bundled": true,
2118 | "dev": true,
2119 | "optional": true
2120 | }
2121 | }
2122 | },
2123 | "glob": {
2124 | "version": "7.1.2",
2125 | "bundled": true,
2126 | "dev": true,
2127 | "requires": {
2128 | "fs.realpath": "1.0.0",
2129 | "inflight": "1.0.6",
2130 | "inherits": "2.0.3",
2131 | "minimatch": "3.0.4",
2132 | "once": "1.4.0",
2133 | "path-is-absolute": "1.0.1"
2134 | }
2135 | },
2136 | "graceful-fs": {
2137 | "version": "4.1.11",
2138 | "bundled": true,
2139 | "dev": true
2140 | },
2141 | "har-schema": {
2142 | "version": "1.0.5",
2143 | "bundled": true,
2144 | "dev": true,
2145 | "optional": true
2146 | },
2147 | "har-validator": {
2148 | "version": "4.2.1",
2149 | "bundled": true,
2150 | "dev": true,
2151 | "optional": true,
2152 | "requires": {
2153 | "ajv": "4.11.8",
2154 | "har-schema": "1.0.5"
2155 | }
2156 | },
2157 | "has-unicode": {
2158 | "version": "2.0.1",
2159 | "bundled": true,
2160 | "dev": true,
2161 | "optional": true
2162 | },
2163 | "hawk": {
2164 | "version": "3.1.3",
2165 | "bundled": true,
2166 | "dev": true,
2167 | "requires": {
2168 | "boom": "2.10.1",
2169 | "cryptiles": "2.0.5",
2170 | "hoek": "2.16.3",
2171 | "sntp": "1.0.9"
2172 | }
2173 | },
2174 | "hoek": {
2175 | "version": "2.16.3",
2176 | "bundled": true,
2177 | "dev": true
2178 | },
2179 | "http-signature": {
2180 | "version": "1.1.1",
2181 | "bundled": true,
2182 | "dev": true,
2183 | "optional": true,
2184 | "requires": {
2185 | "assert-plus": "0.2.0",
2186 | "jsprim": "1.4.0",
2187 | "sshpk": "1.13.0"
2188 | }
2189 | },
2190 | "inflight": {
2191 | "version": "1.0.6",
2192 | "bundled": true,
2193 | "dev": true,
2194 | "requires": {
2195 | "once": "1.4.0",
2196 | "wrappy": "1.0.2"
2197 | }
2198 | },
2199 | "inherits": {
2200 | "version": "2.0.3",
2201 | "bundled": true,
2202 | "dev": true
2203 | },
2204 | "ini": {
2205 | "version": "1.3.4",
2206 | "bundled": true,
2207 | "dev": true,
2208 | "optional": true
2209 | },
2210 | "is-fullwidth-code-point": {
2211 | "version": "1.0.0",
2212 | "bundled": true,
2213 | "dev": true,
2214 | "requires": {
2215 | "number-is-nan": "1.0.1"
2216 | }
2217 | },
2218 | "is-typedarray": {
2219 | "version": "1.0.0",
2220 | "bundled": true,
2221 | "dev": true,
2222 | "optional": true
2223 | },
2224 | "isarray": {
2225 | "version": "1.0.0",
2226 | "bundled": true,
2227 | "dev": true
2228 | },
2229 | "isstream": {
2230 | "version": "0.1.2",
2231 | "bundled": true,
2232 | "dev": true,
2233 | "optional": true
2234 | },
2235 | "jodid25519": {
2236 | "version": "1.0.2",
2237 | "bundled": true,
2238 | "dev": true,
2239 | "optional": true,
2240 | "requires": {
2241 | "jsbn": "0.1.1"
2242 | }
2243 | },
2244 | "jsbn": {
2245 | "version": "0.1.1",
2246 | "bundled": true,
2247 | "dev": true,
2248 | "optional": true
2249 | },
2250 | "json-schema": {
2251 | "version": "0.2.3",
2252 | "bundled": true,
2253 | "dev": true,
2254 | "optional": true
2255 | },
2256 | "json-stable-stringify": {
2257 | "version": "1.0.1",
2258 | "bundled": true,
2259 | "dev": true,
2260 | "optional": true,
2261 | "requires": {
2262 | "jsonify": "0.0.0"
2263 | }
2264 | },
2265 | "json-stringify-safe": {
2266 | "version": "5.0.1",
2267 | "bundled": true,
2268 | "dev": true,
2269 | "optional": true
2270 | },
2271 | "jsonify": {
2272 | "version": "0.0.0",
2273 | "bundled": true,
2274 | "dev": true,
2275 | "optional": true
2276 | },
2277 | "jsprim": {
2278 | "version": "1.4.0",
2279 | "bundled": true,
2280 | "dev": true,
2281 | "optional": true,
2282 | "requires": {
2283 | "assert-plus": "1.0.0",
2284 | "extsprintf": "1.0.2",
2285 | "json-schema": "0.2.3",
2286 | "verror": "1.3.6"
2287 | },
2288 | "dependencies": {
2289 | "assert-plus": {
2290 | "version": "1.0.0",
2291 | "bundled": true,
2292 | "dev": true,
2293 | "optional": true
2294 | }
2295 | }
2296 | },
2297 | "mime-db": {
2298 | "version": "1.27.0",
2299 | "bundled": true,
2300 | "dev": true
2301 | },
2302 | "mime-types": {
2303 | "version": "2.1.15",
2304 | "bundled": true,
2305 | "dev": true,
2306 | "requires": {
2307 | "mime-db": "1.27.0"
2308 | }
2309 | },
2310 | "minimatch": {
2311 | "version": "3.0.4",
2312 | "bundled": true,
2313 | "dev": true,
2314 | "requires": {
2315 | "brace-expansion": "1.1.7"
2316 | }
2317 | },
2318 | "minimist": {
2319 | "version": "0.0.8",
2320 | "bundled": true,
2321 | "dev": true
2322 | },
2323 | "mkdirp": {
2324 | "version": "0.5.1",
2325 | "bundled": true,
2326 | "dev": true,
2327 | "requires": {
2328 | "minimist": "0.0.8"
2329 | }
2330 | },
2331 | "ms": {
2332 | "version": "2.0.0",
2333 | "bundled": true,
2334 | "dev": true,
2335 | "optional": true
2336 | },
2337 | "node-pre-gyp": {
2338 | "version": "0.6.39",
2339 | "bundled": true,
2340 | "dev": true,
2341 | "optional": true,
2342 | "requires": {
2343 | "detect-libc": "1.0.2",
2344 | "hawk": "3.1.3",
2345 | "mkdirp": "0.5.1",
2346 | "nopt": "4.0.1",
2347 | "npmlog": "4.1.0",
2348 | "rc": "1.2.1",
2349 | "request": "2.81.0",
2350 | "rimraf": "2.6.1",
2351 | "semver": "5.3.0",
2352 | "tar": "2.2.1",
2353 | "tar-pack": "3.4.0"
2354 | }
2355 | },
2356 | "nopt": {
2357 | "version": "4.0.1",
2358 | "bundled": true,
2359 | "dev": true,
2360 | "optional": true,
2361 | "requires": {
2362 | "abbrev": "1.1.0",
2363 | "osenv": "0.1.4"
2364 | }
2365 | },
2366 | "npmlog": {
2367 | "version": "4.1.0",
2368 | "bundled": true,
2369 | "dev": true,
2370 | "optional": true,
2371 | "requires": {
2372 | "are-we-there-yet": "1.1.4",
2373 | "console-control-strings": "1.1.0",
2374 | "gauge": "2.7.4",
2375 | "set-blocking": "2.0.0"
2376 | }
2377 | },
2378 | "number-is-nan": {
2379 | "version": "1.0.1",
2380 | "bundled": true,
2381 | "dev": true
2382 | },
2383 | "oauth-sign": {
2384 | "version": "0.8.2",
2385 | "bundled": true,
2386 | "dev": true,
2387 | "optional": true
2388 | },
2389 | "object-assign": {
2390 | "version": "4.1.1",
2391 | "bundled": true,
2392 | "dev": true,
2393 | "optional": true
2394 | },
2395 | "once": {
2396 | "version": "1.4.0",
2397 | "bundled": true,
2398 | "dev": true,
2399 | "requires": {
2400 | "wrappy": "1.0.2"
2401 | }
2402 | },
2403 | "os-homedir": {
2404 | "version": "1.0.2",
2405 | "bundled": true,
2406 | "dev": true,
2407 | "optional": true
2408 | },
2409 | "os-tmpdir": {
2410 | "version": "1.0.2",
2411 | "bundled": true,
2412 | "dev": true,
2413 | "optional": true
2414 | },
2415 | "osenv": {
2416 | "version": "0.1.4",
2417 | "bundled": true,
2418 | "dev": true,
2419 | "optional": true,
2420 | "requires": {
2421 | "os-homedir": "1.0.2",
2422 | "os-tmpdir": "1.0.2"
2423 | }
2424 | },
2425 | "path-is-absolute": {
2426 | "version": "1.0.1",
2427 | "bundled": true,
2428 | "dev": true
2429 | },
2430 | "performance-now": {
2431 | "version": "0.2.0",
2432 | "bundled": true,
2433 | "dev": true,
2434 | "optional": true
2435 | },
2436 | "process-nextick-args": {
2437 | "version": "1.0.7",
2438 | "bundled": true,
2439 | "dev": true
2440 | },
2441 | "punycode": {
2442 | "version": "1.4.1",
2443 | "bundled": true,
2444 | "dev": true,
2445 | "optional": true
2446 | },
2447 | "qs": {
2448 | "version": "6.4.0",
2449 | "bundled": true,
2450 | "dev": true,
2451 | "optional": true
2452 | },
2453 | "rc": {
2454 | "version": "1.2.1",
2455 | "bundled": true,
2456 | "dev": true,
2457 | "optional": true,
2458 | "requires": {
2459 | "deep-extend": "0.4.2",
2460 | "ini": "1.3.4",
2461 | "minimist": "1.2.0",
2462 | "strip-json-comments": "2.0.1"
2463 | },
2464 | "dependencies": {
2465 | "minimist": {
2466 | "version": "1.2.0",
2467 | "bundled": true,
2468 | "dev": true,
2469 | "optional": true
2470 | }
2471 | }
2472 | },
2473 | "readable-stream": {
2474 | "version": "2.2.9",
2475 | "bundled": true,
2476 | "dev": true,
2477 | "requires": {
2478 | "buffer-shims": "1.0.0",
2479 | "core-util-is": "1.0.2",
2480 | "inherits": "2.0.3",
2481 | "isarray": "1.0.0",
2482 | "process-nextick-args": "1.0.7",
2483 | "string_decoder": "1.0.1",
2484 | "util-deprecate": "1.0.2"
2485 | }
2486 | },
2487 | "request": {
2488 | "version": "2.81.0",
2489 | "bundled": true,
2490 | "dev": true,
2491 | "optional": true,
2492 | "requires": {
2493 | "aws-sign2": "0.6.0",
2494 | "aws4": "1.6.0",
2495 | "caseless": "0.12.0",
2496 | "combined-stream": "1.0.5",
2497 | "extend": "3.0.1",
2498 | "forever-agent": "0.6.1",
2499 | "form-data": "2.1.4",
2500 | "har-validator": "4.2.1",
2501 | "hawk": "3.1.3",
2502 | "http-signature": "1.1.1",
2503 | "is-typedarray": "1.0.0",
2504 | "isstream": "0.1.2",
2505 | "json-stringify-safe": "5.0.1",
2506 | "mime-types": "2.1.15",
2507 | "oauth-sign": "0.8.2",
2508 | "performance-now": "0.2.0",
2509 | "qs": "6.4.0",
2510 | "safe-buffer": "5.0.1",
2511 | "stringstream": "0.0.5",
2512 | "tough-cookie": "2.3.2",
2513 | "tunnel-agent": "0.6.0",
2514 | "uuid": "3.0.1"
2515 | }
2516 | },
2517 | "rimraf": {
2518 | "version": "2.6.1",
2519 | "bundled": true,
2520 | "dev": true,
2521 | "requires": {
2522 | "glob": "7.1.2"
2523 | }
2524 | },
2525 | "safe-buffer": {
2526 | "version": "5.0.1",
2527 | "bundled": true,
2528 | "dev": true
2529 | },
2530 | "semver": {
2531 | "version": "5.3.0",
2532 | "bundled": true,
2533 | "dev": true,
2534 | "optional": true
2535 | },
2536 | "set-blocking": {
2537 | "version": "2.0.0",
2538 | "bundled": true,
2539 | "dev": true,
2540 | "optional": true
2541 | },
2542 | "signal-exit": {
2543 | "version": "3.0.2",
2544 | "bundled": true,
2545 | "dev": true,
2546 | "optional": true
2547 | },
2548 | "sntp": {
2549 | "version": "1.0.9",
2550 | "bundled": true,
2551 | "dev": true,
2552 | "requires": {
2553 | "hoek": "2.16.3"
2554 | }
2555 | },
2556 | "sshpk": {
2557 | "version": "1.13.0",
2558 | "bundled": true,
2559 | "dev": true,
2560 | "optional": true,
2561 | "requires": {
2562 | "asn1": "0.2.3",
2563 | "assert-plus": "1.0.0",
2564 | "bcrypt-pbkdf": "1.0.1",
2565 | "dashdash": "1.14.1",
2566 | "ecc-jsbn": "0.1.1",
2567 | "getpass": "0.1.7",
2568 | "jodid25519": "1.0.2",
2569 | "jsbn": "0.1.1",
2570 | "tweetnacl": "0.14.5"
2571 | },
2572 | "dependencies": {
2573 | "assert-plus": {
2574 | "version": "1.0.0",
2575 | "bundled": true,
2576 | "dev": true,
2577 | "optional": true
2578 | }
2579 | }
2580 | },
2581 | "string-width": {
2582 | "version": "1.0.2",
2583 | "bundled": true,
2584 | "dev": true,
2585 | "requires": {
2586 | "code-point-at": "1.1.0",
2587 | "is-fullwidth-code-point": "1.0.0",
2588 | "strip-ansi": "3.0.1"
2589 | }
2590 | },
2591 | "string_decoder": {
2592 | "version": "1.0.1",
2593 | "bundled": true,
2594 | "dev": true,
2595 | "requires": {
2596 | "safe-buffer": "5.0.1"
2597 | }
2598 | },
2599 | "stringstream": {
2600 | "version": "0.0.5",
2601 | "bundled": true,
2602 | "dev": true,
2603 | "optional": true
2604 | },
2605 | "strip-ansi": {
2606 | "version": "3.0.1",
2607 | "bundled": true,
2608 | "dev": true,
2609 | "requires": {
2610 | "ansi-regex": "2.1.1"
2611 | }
2612 | },
2613 | "strip-json-comments": {
2614 | "version": "2.0.1",
2615 | "bundled": true,
2616 | "dev": true,
2617 | "optional": true
2618 | },
2619 | "tar": {
2620 | "version": "2.2.1",
2621 | "bundled": true,
2622 | "dev": true,
2623 | "requires": {
2624 | "block-stream": "0.0.9",
2625 | "fstream": "1.0.11",
2626 | "inherits": "2.0.3"
2627 | }
2628 | },
2629 | "tar-pack": {
2630 | "version": "3.4.0",
2631 | "bundled": true,
2632 | "dev": true,
2633 | "optional": true,
2634 | "requires": {
2635 | "debug": "2.6.8",
2636 | "fstream": "1.0.11",
2637 | "fstream-ignore": "1.0.5",
2638 | "once": "1.4.0",
2639 | "readable-stream": "2.2.9",
2640 | "rimraf": "2.6.1",
2641 | "tar": "2.2.1",
2642 | "uid-number": "0.0.6"
2643 | }
2644 | },
2645 | "tough-cookie": {
2646 | "version": "2.3.2",
2647 | "bundled": true,
2648 | "dev": true,
2649 | "optional": true,
2650 | "requires": {
2651 | "punycode": "1.4.1"
2652 | }
2653 | },
2654 | "tunnel-agent": {
2655 | "version": "0.6.0",
2656 | "bundled": true,
2657 | "dev": true,
2658 | "optional": true,
2659 | "requires": {
2660 | "safe-buffer": "5.0.1"
2661 | }
2662 | },
2663 | "tweetnacl": {
2664 | "version": "0.14.5",
2665 | "bundled": true,
2666 | "dev": true,
2667 | "optional": true
2668 | },
2669 | "uid-number": {
2670 | "version": "0.0.6",
2671 | "bundled": true,
2672 | "dev": true,
2673 | "optional": true
2674 | },
2675 | "util-deprecate": {
2676 | "version": "1.0.2",
2677 | "bundled": true,
2678 | "dev": true
2679 | },
2680 | "uuid": {
2681 | "version": "3.0.1",
2682 | "bundled": true,
2683 | "dev": true,
2684 | "optional": true
2685 | },
2686 | "verror": {
2687 | "version": "1.3.6",
2688 | "bundled": true,
2689 | "dev": true,
2690 | "optional": true,
2691 | "requires": {
2692 | "extsprintf": "1.0.2"
2693 | }
2694 | },
2695 | "wide-align": {
2696 | "version": "1.1.2",
2697 | "bundled": true,
2698 | "dev": true,
2699 | "optional": true,
2700 | "requires": {
2701 | "string-width": "1.0.2"
2702 | }
2703 | },
2704 | "wrappy": {
2705 | "version": "1.0.2",
2706 | "bundled": true,
2707 | "dev": true
2708 | }
2709 | }
2710 | },
2711 | "function-bind": {
2712 | "version": "1.1.1",
2713 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
2714 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
2715 | "dev": true
2716 | },
2717 | "glob": {
2718 | "version": "7.1.2",
2719 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
2720 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
2721 | "dev": true,
2722 | "requires": {
2723 | "fs.realpath": "1.0.0",
2724 | "inflight": "1.0.6",
2725 | "inherits": "2.0.3",
2726 | "minimatch": "3.0.4",
2727 | "once": "1.4.0",
2728 | "path-is-absolute": "1.0.1"
2729 | }
2730 | },
2731 | "glob-base": {
2732 | "version": "0.3.0",
2733 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz",
2734 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=",
2735 | "dev": true,
2736 | "requires": {
2737 | "glob-parent": "2.0.0",
2738 | "is-glob": "2.0.1"
2739 | }
2740 | },
2741 | "glob-parent": {
2742 | "version": "2.0.0",
2743 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz",
2744 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=",
2745 | "dev": true,
2746 | "requires": {
2747 | "is-glob": "2.0.1"
2748 | }
2749 | },
2750 | "global-modules": {
2751 | "version": "0.2.3",
2752 | "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-0.2.3.tgz",
2753 | "integrity": "sha1-6lo77ULG1s6ZWk+KEmm12uIjgo0=",
2754 | "dev": true,
2755 | "requires": {
2756 | "global-prefix": "0.1.5",
2757 | "is-windows": "0.2.0"
2758 | }
2759 | },
2760 | "global-prefix": {
2761 | "version": "0.1.5",
2762 | "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-0.1.5.tgz",
2763 | "integrity": "sha1-jTvGuNo8qBEqFg2NSW/wRiv+948=",
2764 | "dev": true,
2765 | "requires": {
2766 | "homedir-polyfill": "1.0.1",
2767 | "ini": "1.3.5",
2768 | "is-windows": "0.2.0",
2769 | "which": "1.3.0"
2770 | }
2771 | },
2772 | "globals": {
2773 | "version": "9.18.0",
2774 | "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz",
2775 | "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==",
2776 | "dev": true
2777 | },
2778 | "graceful-fs": {
2779 | "version": "4.1.11",
2780 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz",
2781 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=",
2782 | "dev": true
2783 | },
2784 | "graceful-readlink": {
2785 | "version": "1.0.1",
2786 | "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz",
2787 | "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=",
2788 | "dev": true
2789 | },
2790 | "growl": {
2791 | "version": "1.8.1",
2792 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.8.1.tgz",
2793 | "integrity": "sha1-Sy3sjZB+k9szZiTc7AGDUC+MlCg=",
2794 | "dev": true
2795 | },
2796 | "has": {
2797 | "version": "1.0.1",
2798 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz",
2799 | "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=",
2800 | "dev": true,
2801 | "requires": {
2802 | "function-bind": "1.1.1"
2803 | }
2804 | },
2805 | "has-ansi": {
2806 | "version": "2.0.0",
2807 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz",
2808 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=",
2809 | "dev": true,
2810 | "requires": {
2811 | "ansi-regex": "2.1.1"
2812 | }
2813 | },
2814 | "hash-base": {
2815 | "version": "2.0.2",
2816 | "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-2.0.2.tgz",
2817 | "integrity": "sha1-ZuodhW206KVHDK32/OI65SRO8uE=",
2818 | "dev": true,
2819 | "requires": {
2820 | "inherits": "2.0.3"
2821 | }
2822 | },
2823 | "hash.js": {
2824 | "version": "1.1.3",
2825 | "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.3.tgz",
2826 | "integrity": "sha512-/UETyP0W22QILqS+6HowevwhEFJ3MBJnwTf75Qob9Wz9t0DPuisL8kW8YZMK62dHAKE1c1p+gY1TtOLY+USEHA==",
2827 | "dev": true,
2828 | "requires": {
2829 | "inherits": "2.0.3",
2830 | "minimalistic-assert": "1.0.0"
2831 | }
2832 | },
2833 | "hmac-drbg": {
2834 | "version": "1.0.1",
2835 | "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz",
2836 | "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=",
2837 | "dev": true,
2838 | "requires": {
2839 | "hash.js": "1.1.3",
2840 | "minimalistic-assert": "1.0.0",
2841 | "minimalistic-crypto-utils": "1.0.1"
2842 | }
2843 | },
2844 | "home-or-tmp": {
2845 | "version": "2.0.0",
2846 | "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz",
2847 | "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=",
2848 | "dev": true,
2849 | "requires": {
2850 | "os-homedir": "1.0.2",
2851 | "os-tmpdir": "1.0.2"
2852 | }
2853 | },
2854 | "homedir-polyfill": {
2855 | "version": "1.0.1",
2856 | "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.1.tgz",
2857 | "integrity": "sha1-TCu8inWJmP7r9e1oWA921GdotLw=",
2858 | "dev": true,
2859 | "requires": {
2860 | "parse-passwd": "1.0.0"
2861 | }
2862 | },
2863 | "hosted-git-info": {
2864 | "version": "2.1.5",
2865 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.1.5.tgz",
2866 | "integrity": "sha1-C6gdkNouJas0ozLm7HeTbhWYEYs=",
2867 | "dev": true
2868 | },
2869 | "http-errors": {
2870 | "version": "1.6.2",
2871 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz",
2872 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=",
2873 | "dev": true,
2874 | "requires": {
2875 | "depd": "1.1.1",
2876 | "inherits": "2.0.3",
2877 | "setprototypeof": "1.0.3",
2878 | "statuses": "1.4.0"
2879 | },
2880 | "dependencies": {
2881 | "depd": {
2882 | "version": "1.1.1",
2883 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz",
2884 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=",
2885 | "dev": true
2886 | },
2887 | "setprototypeof": {
2888 | "version": "1.0.3",
2889 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz",
2890 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=",
2891 | "dev": true
2892 | }
2893 | }
2894 | },
2895 | "https-browserify": {
2896 | "version": "0.0.1",
2897 | "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-0.0.1.tgz",
2898 | "integrity": "sha1-P5E2XKvmC3ftDruiS0VOPgnZWoI=",
2899 | "dev": true
2900 | },
2901 | "iconv-lite": {
2902 | "version": "0.4.19",
2903 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz",
2904 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ=="
2905 | },
2906 | "ieee754": {
2907 | "version": "1.1.9",
2908 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.9.tgz",
2909 | "integrity": "sha512-yWDsidMaZHbeTa0a1iSFpK8QhzicsFxo8zKxH0YU2g47rNUZql5+2o3DSc5Z070kjGPLP292BWiF4bd8Q+G87g==",
2910 | "dev": true
2911 | },
2912 | "indexof": {
2913 | "version": "0.0.1",
2914 | "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz",
2915 | "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=",
2916 | "dev": true
2917 | },
2918 | "inflight": {
2919 | "version": "1.0.6",
2920 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
2921 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
2922 | "dev": true,
2923 | "requires": {
2924 | "once": "1.4.0",
2925 | "wrappy": "1.0.2"
2926 | }
2927 | },
2928 | "inherits": {
2929 | "version": "2.0.3",
2930 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
2931 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=",
2932 | "dev": true
2933 | },
2934 | "ini": {
2935 | "version": "1.3.5",
2936 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz",
2937 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==",
2938 | "dev": true
2939 | },
2940 | "init-skeleton": {
2941 | "version": "1.0.1",
2942 | "resolved": "https://registry.npmjs.org/init-skeleton/-/init-skeleton-1.0.1.tgz",
2943 | "integrity": "sha1-MQq3MK06VLA9xLCNaZ1XZnSuEcg=",
2944 | "dev": true,
2945 | "requires": {
2946 | "brunch-skeletons": "0.1.6",
2947 | "deps-install": "0.1.1",
2948 | "hosted-git-info": "2.1.5",
2949 | "micro-promisify": "0.1.1",
2950 | "mkdirp": "0.5.1",
2951 | "ncp": "2.0.0",
2952 | "normalize-git-url": "3.0.2"
2953 | }
2954 | },
2955 | "invariant": {
2956 | "version": "2.2.4",
2957 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz",
2958 | "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==",
2959 | "dev": true,
2960 | "requires": {
2961 | "loose-envify": "1.3.1"
2962 | }
2963 | },
2964 | "ipaddr.js": {
2965 | "version": "1.6.0",
2966 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.6.0.tgz",
2967 | "integrity": "sha1-4/o1e3c9phnybpXwSdBVxyeW+Gs=",
2968 | "dev": true
2969 | },
2970 | "is-binary-path": {
2971 | "version": "1.0.1",
2972 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
2973 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
2974 | "dev": true,
2975 | "requires": {
2976 | "binary-extensions": "1.11.0"
2977 | }
2978 | },
2979 | "is-buffer": {
2980 | "version": "1.1.6",
2981 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz",
2982 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==",
2983 | "dev": true
2984 | },
2985 | "is-callable": {
2986 | "version": "1.1.3",
2987 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz",
2988 | "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=",
2989 | "dev": true
2990 | },
2991 | "is-date-object": {
2992 | "version": "1.0.1",
2993 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz",
2994 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=",
2995 | "dev": true
2996 | },
2997 | "is-dotfile": {
2998 | "version": "1.0.3",
2999 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz",
3000 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=",
3001 | "dev": true
3002 | },
3003 | "is-equal-shallow": {
3004 | "version": "0.1.3",
3005 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz",
3006 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=",
3007 | "dev": true,
3008 | "requires": {
3009 | "is-primitive": "2.0.0"
3010 | }
3011 | },
3012 | "is-extendable": {
3013 | "version": "0.1.1",
3014 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz",
3015 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=",
3016 | "dev": true
3017 | },
3018 | "is-extglob": {
3019 | "version": "1.0.0",
3020 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz",
3021 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=",
3022 | "dev": true
3023 | },
3024 | "is-finite": {
3025 | "version": "1.0.2",
3026 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz",
3027 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=",
3028 | "dev": true,
3029 | "requires": {
3030 | "number-is-nan": "1.0.1"
3031 | }
3032 | },
3033 | "is-glob": {
3034 | "version": "2.0.1",
3035 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz",
3036 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=",
3037 | "dev": true,
3038 | "requires": {
3039 | "is-extglob": "1.0.0"
3040 | }
3041 | },
3042 | "is-number": {
3043 | "version": "2.1.0",
3044 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz",
3045 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=",
3046 | "dev": true,
3047 | "requires": {
3048 | "kind-of": "3.2.2"
3049 | }
3050 | },
3051 | "is-obj": {
3052 | "version": "1.0.1",
3053 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz",
3054 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=",
3055 | "dev": true
3056 | },
3057 | "is-posix-bracket": {
3058 | "version": "0.1.1",
3059 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz",
3060 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=",
3061 | "dev": true
3062 | },
3063 | "is-primitive": {
3064 | "version": "2.0.0",
3065 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz",
3066 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=",
3067 | "dev": true
3068 | },
3069 | "is-regex": {
3070 | "version": "1.0.4",
3071 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz",
3072 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=",
3073 | "dev": true,
3074 | "requires": {
3075 | "has": "1.0.1"
3076 | }
3077 | },
3078 | "is-stream": {
3079 | "version": "1.1.0",
3080 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz",
3081 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ="
3082 | },
3083 | "is-symbol": {
3084 | "version": "1.0.1",
3085 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.1.tgz",
3086 | "integrity": "sha1-PMWfAAJRlLarLjjbrmaJJWtmBXI=",
3087 | "dev": true
3088 | },
3089 | "is-windows": {
3090 | "version": "0.2.0",
3091 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-0.2.0.tgz",
3092 | "integrity": "sha1-3hqm1j6indJIc3tp8f+LgALSEIw=",
3093 | "dev": true
3094 | },
3095 | "isarray": {
3096 | "version": "1.0.0",
3097 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
3098 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
3099 | "dev": true
3100 | },
3101 | "isexe": {
3102 | "version": "2.0.0",
3103 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
3104 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
3105 | "dev": true
3106 | },
3107 | "isobject": {
3108 | "version": "2.1.0",
3109 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz",
3110 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=",
3111 | "dev": true,
3112 | "requires": {
3113 | "isarray": "1.0.0"
3114 | }
3115 | },
3116 | "isomorphic-fetch": {
3117 | "version": "2.2.1",
3118 | "resolved": "https://registry.npmjs.org/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz",
3119 | "integrity": "sha1-YRrhrPFPXoH3KVB0coGf6XM1WKk=",
3120 | "requires": {
3121 | "node-fetch": "1.7.3",
3122 | "whatwg-fetch": "2.0.3"
3123 | }
3124 | },
3125 | "js-tokens": {
3126 | "version": "3.0.2",
3127 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz",
3128 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls="
3129 | },
3130 | "jsesc": {
3131 | "version": "1.3.0",
3132 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz",
3133 | "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=",
3134 | "dev": true
3135 | },
3136 | "json5": {
3137 | "version": "0.5.1",
3138 | "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz",
3139 | "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=",
3140 | "dev": true
3141 | },
3142 | "kind-of": {
3143 | "version": "3.2.2",
3144 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
3145 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
3146 | "dev": true,
3147 | "requires": {
3148 | "is-buffer": "1.1.6"
3149 | }
3150 | },
3151 | "lazy-cache": {
3152 | "version": "1.0.4",
3153 | "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz",
3154 | "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=",
3155 | "dev": true
3156 | },
3157 | "lodash": {
3158 | "version": "4.17.5",
3159 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.5.tgz",
3160 | "integrity": "sha512-svL3uiZf1RwhH+cWrfZn3A4+U58wbP0tGVTLQPbjplZxZ8ROD9VLuNgsRniTlLe7OlSqR79RUehXgpBW/s0IQw==",
3161 | "dev": true
3162 | },
3163 | "lodash.camelcase": {
3164 | "version": "4.3.0",
3165 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz",
3166 | "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=",
3167 | "dev": true
3168 | },
3169 | "loggy": {
3170 | "version": "1.0.2",
3171 | "resolved": "https://registry.npmjs.org/loggy/-/loggy-1.0.2.tgz",
3172 | "integrity": "sha1-0MoxxCE5X4xGLQSHDdIijePE4hk=",
3173 | "dev": true,
3174 | "requires": {
3175 | "chalk": "1.1.3",
3176 | "native-notifier": "0.1.1"
3177 | }
3178 | },
3179 | "longest": {
3180 | "version": "1.0.1",
3181 | "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz",
3182 | "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=",
3183 | "dev": true
3184 | },
3185 | "loose-envify": {
3186 | "version": "1.3.1",
3187 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.3.1.tgz",
3188 | "integrity": "sha1-0aitM/qc4OcT1l/dCsi3SNR4yEg=",
3189 | "requires": {
3190 | "js-tokens": "3.0.2"
3191 | }
3192 | },
3193 | "md5.js": {
3194 | "version": "1.3.4",
3195 | "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.4.tgz",
3196 | "integrity": "sha1-6b296UogpawYsENA/Fdk1bCdkB0=",
3197 | "dev": true,
3198 | "requires": {
3199 | "hash-base": "3.0.4",
3200 | "inherits": "2.0.3"
3201 | },
3202 | "dependencies": {
3203 | "hash-base": {
3204 | "version": "3.0.4",
3205 | "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz",
3206 | "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=",
3207 | "dev": true,
3208 | "requires": {
3209 | "inherits": "2.0.3",
3210 | "safe-buffer": "5.1.1"
3211 | }
3212 | }
3213 | }
3214 | },
3215 | "media-typer": {
3216 | "version": "0.3.0",
3217 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
3218 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=",
3219 | "dev": true
3220 | },
3221 | "merge-descriptors": {
3222 | "version": "1.0.1",
3223 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
3224 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=",
3225 | "dev": true
3226 | },
3227 | "methods": {
3228 | "version": "1.1.2",
3229 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
3230 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=",
3231 | "dev": true
3232 | },
3233 | "micro-es7-shim": {
3234 | "version": "0.1.0",
3235 | "resolved": "https://registry.npmjs.org/micro-es7-shim/-/micro-es7-shim-0.1.0.tgz",
3236 | "integrity": "sha1-qpmJovkwN6k+ezDiySQz2wtMoig=",
3237 | "dev": true
3238 | },
3239 | "micro-promisify": {
3240 | "version": "0.1.1",
3241 | "resolved": "https://registry.npmjs.org/micro-promisify/-/micro-promisify-0.1.1.tgz",
3242 | "integrity": "sha1-Bx2lkLSVZWDe30qucERynBookC0=",
3243 | "dev": true
3244 | },
3245 | "micromatch": {
3246 | "version": "2.3.11",
3247 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz",
3248 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=",
3249 | "dev": true,
3250 | "requires": {
3251 | "arr-diff": "2.0.0",
3252 | "array-unique": "0.2.1",
3253 | "braces": "1.8.5",
3254 | "expand-brackets": "0.1.5",
3255 | "extglob": "0.3.2",
3256 | "filename-regex": "2.0.1",
3257 | "is-extglob": "1.0.0",
3258 | "is-glob": "2.0.1",
3259 | "kind-of": "3.2.2",
3260 | "normalize-path": "2.1.1",
3261 | "object.omit": "2.0.1",
3262 | "parse-glob": "3.0.4",
3263 | "regex-cache": "0.4.4"
3264 | }
3265 | },
3266 | "miller-rabin": {
3267 | "version": "4.0.1",
3268 | "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz",
3269 | "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==",
3270 | "dev": true,
3271 | "requires": {
3272 | "bn.js": "4.11.8",
3273 | "brorand": "1.1.0"
3274 | }
3275 | },
3276 | "mime": {
3277 | "version": "1.4.1",
3278 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz",
3279 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==",
3280 | "dev": true
3281 | },
3282 | "mime-db": {
3283 | "version": "1.33.0",
3284 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.33.0.tgz",
3285 | "integrity": "sha512-BHJ/EKruNIqJf/QahvxwQZXKygOQ256myeN/Ew+THcAa5q+PjyTTMMeNQC4DZw5AwfvelsUrA6B67NKMqXDbzQ==",
3286 | "dev": true
3287 | },
3288 | "mime-types": {
3289 | "version": "2.1.18",
3290 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.18.tgz",
3291 | "integrity": "sha512-lc/aahn+t4/SWV/qcmumYjymLsWfN3ELhpmVuUFjgsORruuZPVSwAQryq+HHGvO/SI2KVX26bx+En+zhM8g8hQ==",
3292 | "dev": true,
3293 | "requires": {
3294 | "mime-db": "1.33.0"
3295 | }
3296 | },
3297 | "minimalistic-assert": {
3298 | "version": "1.0.0",
3299 | "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.0.tgz",
3300 | "integrity": "sha1-cCvi3aazf0g2vLP121ZkG2Sh09M=",
3301 | "dev": true
3302 | },
3303 | "minimalistic-crypto-utils": {
3304 | "version": "1.0.1",
3305 | "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz",
3306 | "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=",
3307 | "dev": true
3308 | },
3309 | "minimatch": {
3310 | "version": "3.0.4",
3311 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
3312 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
3313 | "dev": true,
3314 | "requires": {
3315 | "brace-expansion": "1.1.11"
3316 | }
3317 | },
3318 | "minimist": {
3319 | "version": "0.0.8",
3320 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz",
3321 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=",
3322 | "dev": true
3323 | },
3324 | "mkdirp": {
3325 | "version": "0.5.1",
3326 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz",
3327 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=",
3328 | "dev": true,
3329 | "requires": {
3330 | "minimist": "0.0.8"
3331 | }
3332 | },
3333 | "mout": {
3334 | "version": "1.1.0",
3335 | "resolved": "https://registry.npmjs.org/mout/-/mout-1.1.0.tgz",
3336 | "integrity": "sha512-XsP0vf4As6BfqglxZqbqQ8SR6KQot2AgxvR0gG+WtUkf90vUXchMOZQtPf/Hml1rEffJupqL/tIrU6EYhsUQjw==",
3337 | "dev": true
3338 | },
3339 | "ms": {
3340 | "version": "2.0.0",
3341 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
3342 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
3343 | "dev": true
3344 | },
3345 | "nan": {
3346 | "version": "2.10.0",
3347 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz",
3348 | "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==",
3349 | "dev": true,
3350 | "optional": true
3351 | },
3352 | "native-notifier": {
3353 | "version": "0.1.1",
3354 | "resolved": "https://registry.npmjs.org/native-notifier/-/native-notifier-0.1.1.tgz",
3355 | "integrity": "sha1-D3GXMaQQp6JDQJ6roQoURsLfgxo=",
3356 | "dev": true,
3357 | "requires": {
3358 | "tag-shell": "0.1.0"
3359 | }
3360 | },
3361 | "ncp": {
3362 | "version": "2.0.0",
3363 | "resolved": "https://registry.npmjs.org/ncp/-/ncp-2.0.0.tgz",
3364 | "integrity": "sha1-GVoh1sRuNh0vsSgbo4uR6d9727M=",
3365 | "dev": true
3366 | },
3367 | "negotiator": {
3368 | "version": "0.6.1",
3369 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz",
3370 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=",
3371 | "dev": true
3372 | },
3373 | "node-browser-modules": {
3374 | "version": "0.1.0",
3375 | "resolved": "https://registry.npmjs.org/node-browser-modules/-/node-browser-modules-0.1.0.tgz",
3376 | "integrity": "sha1-QZPLtw9UJ1ml5ObWsBzLY46Zoaw=",
3377 | "dev": true,
3378 | "requires": {
3379 | "assert": "1.3.0",
3380 | "buffer": "4.3.1",
3381 | "crypto-browserify": "3.11.1",
3382 | "domain-browser": "1.1.7",
3383 | "events": "1.1.1",
3384 | "https-browserify": "0.0.1",
3385 | "os-browserify": "0.2.1",
3386 | "path-browserify": "0.0.0",
3387 | "process": "0.11.10",
3388 | "punycode": "1.4.1",
3389 | "querystring-es3": "0.2.1",
3390 | "readable-stream": "2.0.6",
3391 | "stream-browserify": "2.0.1",
3392 | "stream-http": "2.1.1",
3393 | "string_decoder": "0.10.31",
3394 | "timers-browserify": "1.4.2",
3395 | "tty-browserify": "0.0.1",
3396 | "url": "0.11.0",
3397 | "util": "0.10.3",
3398 | "vm-browserify": "0.0.4"
3399 | },
3400 | "dependencies": {
3401 | "process-nextick-args": {
3402 | "version": "1.0.7",
3403 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz",
3404 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=",
3405 | "dev": true
3406 | },
3407 | "readable-stream": {
3408 | "version": "2.0.6",
3409 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.0.6.tgz",
3410 | "integrity": "sha1-j5A0HmilPMySh4jaz80Rs265t44=",
3411 | "dev": true,
3412 | "requires": {
3413 | "core-util-is": "1.0.2",
3414 | "inherits": "2.0.3",
3415 | "isarray": "1.0.0",
3416 | "process-nextick-args": "1.0.7",
3417 | "string_decoder": "0.10.31",
3418 | "util-deprecate": "1.0.2"
3419 | }
3420 | },
3421 | "string_decoder": {
3422 | "version": "0.10.31",
3423 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz",
3424 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=",
3425 | "dev": true
3426 | }
3427 | }
3428 | },
3429 | "node-fetch": {
3430 | "version": "1.7.3",
3431 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-1.7.3.tgz",
3432 | "integrity": "sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ==",
3433 | "requires": {
3434 | "encoding": "0.1.12",
3435 | "is-stream": "1.1.0"
3436 | }
3437 | },
3438 | "normalize-git-url": {
3439 | "version": "3.0.2",
3440 | "resolved": "https://registry.npmjs.org/normalize-git-url/-/normalize-git-url-3.0.2.tgz",
3441 | "integrity": "sha1-jl8Uvgva7bc+ByADEKpBbCc1D8Q=",
3442 | "dev": true
3443 | },
3444 | "normalize-path": {
3445 | "version": "2.1.1",
3446 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
3447 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
3448 | "dev": true,
3449 | "requires": {
3450 | "remove-trailing-separator": "1.1.0"
3451 | }
3452 | },
3453 | "number-is-nan": {
3454 | "version": "1.0.1",
3455 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz",
3456 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=",
3457 | "dev": true
3458 | },
3459 | "object-assign": {
3460 | "version": "4.1.1",
3461 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
3462 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM="
3463 | },
3464 | "object-keys": {
3465 | "version": "1.0.11",
3466 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz",
3467 | "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=",
3468 | "dev": true
3469 | },
3470 | "object.omit": {
3471 | "version": "2.0.1",
3472 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz",
3473 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=",
3474 | "dev": true,
3475 | "requires": {
3476 | "for-own": "0.1.5",
3477 | "is-extendable": "0.1.1"
3478 | }
3479 | },
3480 | "on-finished": {
3481 | "version": "2.3.0",
3482 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
3483 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
3484 | "dev": true,
3485 | "requires": {
3486 | "ee-first": "1.1.1"
3487 | }
3488 | },
3489 | "once": {
3490 | "version": "1.4.0",
3491 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
3492 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
3493 | "dev": true,
3494 | "requires": {
3495 | "wrappy": "1.0.2"
3496 | }
3497 | },
3498 | "optimist": {
3499 | "version": "0.6.1",
3500 | "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz",
3501 | "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=",
3502 | "dev": true,
3503 | "requires": {
3504 | "minimist": "0.0.8",
3505 | "wordwrap": "0.0.3"
3506 | }
3507 | },
3508 | "os-browserify": {
3509 | "version": "0.2.1",
3510 | "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.2.1.tgz",
3511 | "integrity": "sha1-Y/xMzuXS13Y9Jrv4YBB45sLgBE8=",
3512 | "dev": true
3513 | },
3514 | "os-homedir": {
3515 | "version": "1.0.2",
3516 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz",
3517 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=",
3518 | "dev": true
3519 | },
3520 | "os-tmpdir": {
3521 | "version": "1.0.2",
3522 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
3523 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=",
3524 | "dev": true
3525 | },
3526 | "osenv": {
3527 | "version": "0.1.5",
3528 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz",
3529 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==",
3530 | "dev": true,
3531 | "requires": {
3532 | "os-homedir": "1.0.2",
3533 | "os-tmpdir": "1.0.2"
3534 | }
3535 | },
3536 | "parse-asn1": {
3537 | "version": "5.1.0",
3538 | "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.0.tgz",
3539 | "integrity": "sha1-N8T5t+06tlx0gXtfJICTf7+XxxI=",
3540 | "dev": true,
3541 | "requires": {
3542 | "asn1.js": "4.10.1",
3543 | "browserify-aes": "1.1.1",
3544 | "create-hash": "1.1.3",
3545 | "evp_bytestokey": "1.0.3",
3546 | "pbkdf2": "3.0.14"
3547 | }
3548 | },
3549 | "parse-glob": {
3550 | "version": "3.0.4",
3551 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz",
3552 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=",
3553 | "dev": true,
3554 | "requires": {
3555 | "glob-base": "0.3.0",
3556 | "is-dotfile": "1.0.3",
3557 | "is-extglob": "1.0.0",
3558 | "is-glob": "2.0.1"
3559 | }
3560 | },
3561 | "parse-passwd": {
3562 | "version": "1.0.0",
3563 | "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz",
3564 | "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=",
3565 | "dev": true
3566 | },
3567 | "parseurl": {
3568 | "version": "1.3.2",
3569 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz",
3570 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=",
3571 | "dev": true
3572 | },
3573 | "path-browserify": {
3574 | "version": "0.0.0",
3575 | "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.0.tgz",
3576 | "integrity": "sha1-oLhwcpquIUAFt9UDLsLLuw+0RRo=",
3577 | "dev": true
3578 | },
3579 | "path-is-absolute": {
3580 | "version": "1.0.1",
3581 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
3582 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
3583 | "dev": true
3584 | },
3585 | "path-to-regexp": {
3586 | "version": "0.1.7",
3587 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
3588 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=",
3589 | "dev": true
3590 | },
3591 | "pbkdf2": {
3592 | "version": "3.0.14",
3593 | "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.14.tgz",
3594 | "integrity": "sha512-gjsZW9O34fm0R7PaLHRJmLLVfSoesxztjPjE9o6R+qtVJij90ltg1joIovN9GKrRW3t1PzhDDG3UMEMFfZ+1wA==",
3595 | "dev": true,
3596 | "requires": {
3597 | "create-hash": "1.1.3",
3598 | "create-hmac": "1.1.6",
3599 | "ripemd160": "2.0.1",
3600 | "safe-buffer": "5.1.1",
3601 | "sha.js": "2.4.10"
3602 | }
3603 | },
3604 | "phoenix": {
3605 | "version": "file:../deps/phoenix"
3606 | },
3607 | "phoenix_html": {
3608 | "version": "file:../deps/phoenix_html"
3609 | },
3610 | "preserve": {
3611 | "version": "0.2.0",
3612 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz",
3613 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=",
3614 | "dev": true
3615 | },
3616 | "private": {
3617 | "version": "0.1.8",
3618 | "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz",
3619 | "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==",
3620 | "dev": true
3621 | },
3622 | "process": {
3623 | "version": "0.11.10",
3624 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
3625 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=",
3626 | "dev": true
3627 | },
3628 | "process-nextick-args": {
3629 | "version": "2.0.0",
3630 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz",
3631 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==",
3632 | "dev": true
3633 | },
3634 | "promise": {
3635 | "version": "7.3.1",
3636 | "resolved": "https://registry.npmjs.org/promise/-/promise-7.3.1.tgz",
3637 | "integrity": "sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg==",
3638 | "requires": {
3639 | "asap": "2.0.6"
3640 | }
3641 | },
3642 | "promise.prototype.finally": {
3643 | "version": "2.0.1",
3644 | "resolved": "https://registry.npmjs.org/promise.prototype.finally/-/promise.prototype.finally-2.0.1.tgz",
3645 | "integrity": "sha1-tw1EzrOCX6iABLXR+9kGs7fZt1g=",
3646 | "dev": true,
3647 | "requires": {
3648 | "define-properties": "1.1.2",
3649 | "es-abstract": "1.10.0",
3650 | "function-bind": "1.1.1"
3651 | }
3652 | },
3653 | "prop-types": {
3654 | "version": "15.6.1",
3655 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.6.1.tgz",
3656 | "integrity": "sha512-4ec7bY1Y66LymSUOH/zARVYObB23AT2h8cf6e/O6ZALB/N0sqZFEx7rq6EYPX2MkOdKORuooI/H5k9TlR4q7kQ==",
3657 | "requires": {
3658 | "fbjs": "0.8.16",
3659 | "loose-envify": "1.3.1",
3660 | "object-assign": "4.1.1"
3661 | }
3662 | },
3663 | "proxy-addr": {
3664 | "version": "2.0.3",
3665 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.3.tgz",
3666 | "integrity": "sha512-jQTChiCJteusULxjBp8+jftSQE5Obdl3k4cnmLA6WXtK6XFuWRnvVL7aCiBqaLPM8c4ph0S4tKna8XvmIwEnXQ==",
3667 | "dev": true,
3668 | "requires": {
3669 | "forwarded": "0.1.2",
3670 | "ipaddr.js": "1.6.0"
3671 | }
3672 | },
3673 | "public-encrypt": {
3674 | "version": "4.0.0",
3675 | "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.0.tgz",
3676 | "integrity": "sha1-OfaZ86RlYN1eusvKaTyvfGXBjMY=",
3677 | "dev": true,
3678 | "requires": {
3679 | "bn.js": "4.11.8",
3680 | "browserify-rsa": "4.0.1",
3681 | "create-hash": "1.1.3",
3682 | "parse-asn1": "5.1.0",
3683 | "randombytes": "2.0.6"
3684 | }
3685 | },
3686 | "punycode": {
3687 | "version": "1.4.1",
3688 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz",
3689 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=",
3690 | "dev": true
3691 | },
3692 | "pushserve": {
3693 | "version": "1.0.2",
3694 | "resolved": "https://registry.npmjs.org/pushserve/-/pushserve-1.0.2.tgz",
3695 | "integrity": "sha1-/fuAOTnKM3UtOPLRqpdawBqTJT8=",
3696 | "dev": true,
3697 | "requires": {
3698 | "commander": "2.9.0",
3699 | "connect-slashes": "1.3.1",
3700 | "express": "4.16.3",
3701 | "serve-static": "1.13.2"
3702 | }
3703 | },
3704 | "qs": {
3705 | "version": "6.5.1",
3706 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz",
3707 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==",
3708 | "dev": true
3709 | },
3710 | "querystring": {
3711 | "version": "0.2.0",
3712 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz",
3713 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=",
3714 | "dev": true
3715 | },
3716 | "querystring-es3": {
3717 | "version": "0.2.1",
3718 | "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz",
3719 | "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=",
3720 | "dev": true
3721 | },
3722 | "randomatic": {
3723 | "version": "1.1.7",
3724 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz",
3725 | "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==",
3726 | "dev": true,
3727 | "requires": {
3728 | "is-number": "3.0.0",
3729 | "kind-of": "4.0.0"
3730 | },
3731 | "dependencies": {
3732 | "is-number": {
3733 | "version": "3.0.0",
3734 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
3735 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
3736 | "dev": true,
3737 | "requires": {
3738 | "kind-of": "3.2.2"
3739 | },
3740 | "dependencies": {
3741 | "kind-of": {
3742 | "version": "3.2.2",
3743 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
3744 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
3745 | "dev": true,
3746 | "requires": {
3747 | "is-buffer": "1.1.6"
3748 | }
3749 | }
3750 | }
3751 | },
3752 | "kind-of": {
3753 | "version": "4.0.0",
3754 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz",
3755 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=",
3756 | "dev": true,
3757 | "requires": {
3758 | "is-buffer": "1.1.6"
3759 | }
3760 | }
3761 | }
3762 | },
3763 | "randombytes": {
3764 | "version": "2.0.6",
3765 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.0.6.tgz",
3766 | "integrity": "sha512-CIQ5OFxf4Jou6uOKe9t1AOgqpeU5fd70A8NPdHSGeYXqXsPe6peOwI0cUl88RWZ6sP1vPMV3avd/R6cZ5/sP1A==",
3767 | "dev": true,
3768 | "requires": {
3769 | "safe-buffer": "5.1.1"
3770 | }
3771 | },
3772 | "range-parser": {
3773 | "version": "1.2.0",
3774 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz",
3775 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=",
3776 | "dev": true
3777 | },
3778 | "raw-body": {
3779 | "version": "2.3.2",
3780 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz",
3781 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=",
3782 | "dev": true,
3783 | "requires": {
3784 | "bytes": "3.0.0",
3785 | "http-errors": "1.6.2",
3786 | "iconv-lite": "0.4.19",
3787 | "unpipe": "1.0.0"
3788 | }
3789 | },
3790 | "react": {
3791 | "version": "16.2.0",
3792 | "resolved": "https://registry.npmjs.org/react/-/react-16.2.0.tgz",
3793 | "integrity": "sha512-ZmIomM7EE1DvPEnSFAHZn9Vs9zJl5A9H7el0EGTE6ZbW9FKe/14IYAlPbC8iH25YarEQxZL+E8VW7Mi7kfQrDQ==",
3794 | "requires": {
3795 | "fbjs": "0.8.16",
3796 | "loose-envify": "1.3.1",
3797 | "object-assign": "4.1.1",
3798 | "prop-types": "15.6.1"
3799 | }
3800 | },
3801 | "react-dom": {
3802 | "version": "16.2.0",
3803 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.2.0.tgz",
3804 | "integrity": "sha512-zpGAdwHVn9K0091d+hr+R0qrjoJ84cIBFL2uU60KvWBPfZ7LPSrfqviTxGHWN0sjPZb2hxWzMexwrvJdKePvjg==",
3805 | "requires": {
3806 | "fbjs": "0.8.16",
3807 | "loose-envify": "1.3.1",
3808 | "object-assign": "4.1.1",
3809 | "prop-types": "15.6.1"
3810 | }
3811 | },
3812 | "read-components": {
3813 | "version": "0.7.0",
3814 | "resolved": "https://registry.npmjs.org/read-components/-/read-components-0.7.0.tgz",
3815 | "integrity": "sha1-d9znrctypRQkDEemdbm896NQndk=",
3816 | "dev": true,
3817 | "requires": {
3818 | "async-each": "1.0.1"
3819 | }
3820 | },
3821 | "readable-stream": {
3822 | "version": "2.3.5",
3823 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.5.tgz",
3824 | "integrity": "sha512-tK0yDhrkygt/knjowCUiWP9YdV7c5R+8cR0r/kt9ZhBU906Fs6RpQJCEilamRJj1Nx2rWI6LkW9gKqjTkshhEw==",
3825 | "dev": true,
3826 | "requires": {
3827 | "core-util-is": "1.0.2",
3828 | "inherits": "2.0.3",
3829 | "isarray": "1.0.0",
3830 | "process-nextick-args": "2.0.0",
3831 | "safe-buffer": "5.1.1",
3832 | "string_decoder": "1.0.3",
3833 | "util-deprecate": "1.0.2"
3834 | }
3835 | },
3836 | "readdirp": {
3837 | "version": "2.1.0",
3838 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz",
3839 | "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=",
3840 | "dev": true,
3841 | "requires": {
3842 | "graceful-fs": "4.1.11",
3843 | "minimatch": "3.0.4",
3844 | "readable-stream": "2.3.5",
3845 | "set-immediate-shim": "1.0.1"
3846 | }
3847 | },
3848 | "regenerate": {
3849 | "version": "1.3.3",
3850 | "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.3.3.tgz",
3851 | "integrity": "sha512-jVpo1GadrDAK59t/0jRx5VxYWQEDkkEKi6+HjE3joFVLfDOh9Xrdh0dF1eSq+BI/SwvTQ44gSscJ8N5zYL61sg==",
3852 | "dev": true
3853 | },
3854 | "regenerator-runtime": {
3855 | "version": "0.11.1",
3856 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz",
3857 | "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==",
3858 | "dev": true
3859 | },
3860 | "regenerator-transform": {
3861 | "version": "0.10.1",
3862 | "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.10.1.tgz",
3863 | "integrity": "sha512-PJepbvDbuK1xgIgnau7Y90cwaAmO/LCLMI2mPvaXq2heGMR3aWW5/BQvYrhJ8jgmQjXewXvBjzfqKcVOmhjZ6Q==",
3864 | "dev": true,
3865 | "requires": {
3866 | "babel-runtime": "6.26.0",
3867 | "babel-types": "6.26.0",
3868 | "private": "0.1.8"
3869 | }
3870 | },
3871 | "regex-cache": {
3872 | "version": "0.4.4",
3873 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz",
3874 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==",
3875 | "dev": true,
3876 | "requires": {
3877 | "is-equal-shallow": "0.1.3"
3878 | }
3879 | },
3880 | "regexpu-core": {
3881 | "version": "2.0.0",
3882 | "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-2.0.0.tgz",
3883 | "integrity": "sha1-SdA4g3uNz4v6W5pCE5k45uoq4kA=",
3884 | "dev": true,
3885 | "requires": {
3886 | "regenerate": "1.3.3",
3887 | "regjsgen": "0.2.0",
3888 | "regjsparser": "0.1.5"
3889 | }
3890 | },
3891 | "regjsgen": {
3892 | "version": "0.2.0",
3893 | "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.2.0.tgz",
3894 | "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=",
3895 | "dev": true
3896 | },
3897 | "regjsparser": {
3898 | "version": "0.1.5",
3899 | "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz",
3900 | "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=",
3901 | "dev": true,
3902 | "requires": {
3903 | "jsesc": "0.5.0"
3904 | },
3905 | "dependencies": {
3906 | "jsesc": {
3907 | "version": "0.5.0",
3908 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz",
3909 | "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=",
3910 | "dev": true
3911 | }
3912 | }
3913 | },
3914 | "remove-trailing-separator": {
3915 | "version": "1.1.0",
3916 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
3917 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
3918 | "dev": true
3919 | },
3920 | "repeat-element": {
3921 | "version": "1.1.2",
3922 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz",
3923 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=",
3924 | "dev": true
3925 | },
3926 | "repeat-string": {
3927 | "version": "1.6.1",
3928 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz",
3929 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=",
3930 | "dev": true
3931 | },
3932 | "repeating": {
3933 | "version": "2.0.1",
3934 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz",
3935 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=",
3936 | "dev": true,
3937 | "requires": {
3938 | "is-finite": "1.0.2"
3939 | }
3940 | },
3941 | "resolve": {
3942 | "version": "1.1.7",
3943 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz",
3944 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=",
3945 | "dev": true
3946 | },
3947 | "resolve-dir": {
3948 | "version": "0.1.1",
3949 | "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-0.1.1.tgz",
3950 | "integrity": "sha1-shklmlYC+sXFxJatiUpujMQwJh4=",
3951 | "dev": true,
3952 | "requires": {
3953 | "expand-tilde": "1.2.2",
3954 | "global-modules": "0.2.3"
3955 | }
3956 | },
3957 | "right-align": {
3958 | "version": "0.1.3",
3959 | "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz",
3960 | "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=",
3961 | "dev": true,
3962 | "requires": {
3963 | "align-text": "0.1.4"
3964 | }
3965 | },
3966 | "ripemd160": {
3967 | "version": "2.0.1",
3968 | "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.1.tgz",
3969 | "integrity": "sha1-D0WEKVxTo2KK9+bXmsohzlfRxuc=",
3970 | "dev": true,
3971 | "requires": {
3972 | "hash-base": "2.0.2",
3973 | "inherits": "2.0.3"
3974 | }
3975 | },
3976 | "safe-buffer": {
3977 | "version": "5.1.1",
3978 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz",
3979 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==",
3980 | "dev": true
3981 | },
3982 | "semver": {
3983 | "version": "5.5.0",
3984 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz",
3985 | "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==",
3986 | "dev": true
3987 | },
3988 | "send": {
3989 | "version": "0.16.2",
3990 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz",
3991 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==",
3992 | "dev": true,
3993 | "requires": {
3994 | "debug": "2.6.9",
3995 | "depd": "1.1.2",
3996 | "destroy": "1.0.4",
3997 | "encodeurl": "1.0.2",
3998 | "escape-html": "1.0.3",
3999 | "etag": "1.8.1",
4000 | "fresh": "0.5.2",
4001 | "http-errors": "1.6.2",
4002 | "mime": "1.4.1",
4003 | "ms": "2.0.0",
4004 | "on-finished": "2.3.0",
4005 | "range-parser": "1.2.0",
4006 | "statuses": "1.4.0"
4007 | }
4008 | },
4009 | "serve-brunch": {
4010 | "version": "0.2.0",
4011 | "resolved": "https://registry.npmjs.org/serve-brunch/-/serve-brunch-0.2.0.tgz",
4012 | "integrity": "sha1-L5t1C6iYmD7wg4uU446k7tiOPFU=",
4013 | "dev": true,
4014 | "requires": {
4015 | "debug": "2.6.9",
4016 | "loggy": "1.0.2",
4017 | "pushserve": "1.0.2"
4018 | }
4019 | },
4020 | "serve-static": {
4021 | "version": "1.13.2",
4022 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz",
4023 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==",
4024 | "dev": true,
4025 | "requires": {
4026 | "encodeurl": "1.0.2",
4027 | "escape-html": "1.0.3",
4028 | "parseurl": "1.3.2",
4029 | "send": "0.16.2"
4030 | }
4031 | },
4032 | "set-immediate-shim": {
4033 | "version": "1.0.1",
4034 | "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz",
4035 | "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=",
4036 | "dev": true
4037 | },
4038 | "setimmediate": {
4039 | "version": "1.0.5",
4040 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz",
4041 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU="
4042 | },
4043 | "setprototypeof": {
4044 | "version": "1.1.0",
4045 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz",
4046 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==",
4047 | "dev": true
4048 | },
4049 | "sha.js": {
4050 | "version": "2.4.10",
4051 | "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.10.tgz",
4052 | "integrity": "sha512-vnwmrFDlOExK4Nm16J2KMWHLrp14lBrjxMxBJpu++EnsuBmpiYaM/MEs46Vxxm/4FvdP5yTwuCTO9it5FSjrqA==",
4053 | "dev": true,
4054 | "requires": {
4055 | "inherits": "2.0.3",
4056 | "safe-buffer": "5.1.1"
4057 | }
4058 | },
4059 | "since-app-start": {
4060 | "version": "0.3.2",
4061 | "resolved": "https://registry.npmjs.org/since-app-start/-/since-app-start-0.3.2.tgz",
4062 | "integrity": "sha1-xZFY+/yGpdwju918TeFID7tV0Ik=",
4063 | "dev": true,
4064 | "requires": {
4065 | "debug": "2.2.0"
4066 | },
4067 | "dependencies": {
4068 | "debug": {
4069 | "version": "2.2.0",
4070 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz",
4071 | "integrity": "sha1-+HBX6ZWxofauaklgZkE3vFbwOdo=",
4072 | "dev": true,
4073 | "requires": {
4074 | "ms": "0.7.1"
4075 | }
4076 | },
4077 | "ms": {
4078 | "version": "0.7.1",
4079 | "resolved": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz",
4080 | "integrity": "sha1-nNE8A62/8ltl7/3nzoZO6VIBcJg=",
4081 | "dev": true
4082 | }
4083 | }
4084 | },
4085 | "skemata": {
4086 | "version": "0.1.2",
4087 | "resolved": "https://registry.npmjs.org/skemata/-/skemata-0.1.2.tgz",
4088 | "integrity": "sha1-88UhAptnvm4IJfDfhn7peRbeRTA=",
4089 | "dev": true,
4090 | "requires": {
4091 | "fast-levenshtein": "1.1.4"
4092 | }
4093 | },
4094 | "slash": {
4095 | "version": "1.0.0",
4096 | "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz",
4097 | "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=",
4098 | "dev": true
4099 | },
4100 | "source-map": {
4101 | "version": "0.5.7",
4102 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
4103 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
4104 | "dev": true
4105 | },
4106 | "source-map-support": {
4107 | "version": "0.4.18",
4108 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz",
4109 | "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==",
4110 | "dev": true,
4111 | "requires": {
4112 | "source-map": "0.5.7"
4113 | }
4114 | },
4115 | "statuses": {
4116 | "version": "1.4.0",
4117 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz",
4118 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==",
4119 | "dev": true
4120 | },
4121 | "stream-browserify": {
4122 | "version": "2.0.1",
4123 | "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz",
4124 | "integrity": "sha1-ZiZu5fm9uZQKTkUUyvtDu3Hlyds=",
4125 | "dev": true,
4126 | "requires": {
4127 | "inherits": "2.0.3",
4128 | "readable-stream": "2.3.5"
4129 | }
4130 | },
4131 | "stream-http": {
4132 | "version": "2.1.1",
4133 | "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.1.1.tgz",
4134 | "integrity": "sha1-O4gDA7q+A21va0MSfU3Nb4iT4ds=",
4135 | "dev": true,
4136 | "requires": {
4137 | "builtin-status-codes": "2.0.0",
4138 | "inherits": "2.0.3",
4139 | "to-arraybuffer": "1.0.1",
4140 | "xtend": "4.0.1"
4141 | }
4142 | },
4143 | "string_decoder": {
4144 | "version": "1.0.3",
4145 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz",
4146 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==",
4147 | "dev": true,
4148 | "requires": {
4149 | "safe-buffer": "5.1.1"
4150 | }
4151 | },
4152 | "strip-ansi": {
4153 | "version": "3.0.1",
4154 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
4155 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
4156 | "dev": true,
4157 | "requires": {
4158 | "ansi-regex": "2.1.1"
4159 | }
4160 | },
4161 | "supports-color": {
4162 | "version": "2.0.0",
4163 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz",
4164 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=",
4165 | "dev": true
4166 | },
4167 | "tag-shell": {
4168 | "version": "0.1.0",
4169 | "resolved": "https://registry.npmjs.org/tag-shell/-/tag-shell-0.1.0.tgz",
4170 | "integrity": "sha1-50OBbmpugFrDc19BYuAWuXp9370=",
4171 | "dev": true
4172 | },
4173 | "timers-browserify": {
4174 | "version": "1.4.2",
4175 | "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-1.4.2.tgz",
4176 | "integrity": "sha1-ycWLV1voQHN1y14kYtrO50NZ9B0=",
4177 | "dev": true,
4178 | "requires": {
4179 | "process": "0.11.10"
4180 | }
4181 | },
4182 | "to-arraybuffer": {
4183 | "version": "1.0.1",
4184 | "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz",
4185 | "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=",
4186 | "dev": true
4187 | },
4188 | "to-fast-properties": {
4189 | "version": "1.0.3",
4190 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz",
4191 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=",
4192 | "dev": true
4193 | },
4194 | "trim-right": {
4195 | "version": "1.0.1",
4196 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz",
4197 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=",
4198 | "dev": true
4199 | },
4200 | "true-case-path": {
4201 | "version": "1.0.2",
4202 | "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-1.0.2.tgz",
4203 | "integrity": "sha1-fskRMJJHZsf1c74wIMNPj9/QDWI=",
4204 | "dev": true,
4205 | "requires": {
4206 | "glob": "6.0.4"
4207 | },
4208 | "dependencies": {
4209 | "glob": {
4210 | "version": "6.0.4",
4211 | "resolved": "https://registry.npmjs.org/glob/-/glob-6.0.4.tgz",
4212 | "integrity": "sha1-DwiGD2oVUSey+t1PnOJLGqtuTSI=",
4213 | "dev": true,
4214 | "requires": {
4215 | "inflight": "1.0.6",
4216 | "inherits": "2.0.3",
4217 | "minimatch": "3.0.4",
4218 | "once": "1.4.0",
4219 | "path-is-absolute": "1.0.1"
4220 | }
4221 | }
4222 | }
4223 | },
4224 | "tty-browserify": {
4225 | "version": "0.0.1",
4226 | "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.1.tgz",
4227 | "integrity": "sha512-C3TaO7K81YvjCgQH9Q1S3R3P3BtN3RIM8n+OvX4il1K1zgE8ZhI0op7kClgkxtutIE8hQrcrHBXvIheqKUUCxw==",
4228 | "dev": true
4229 | },
4230 | "type-is": {
4231 | "version": "1.6.16",
4232 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz",
4233 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==",
4234 | "dev": true,
4235 | "requires": {
4236 | "media-typer": "0.3.0",
4237 | "mime-types": "2.1.18"
4238 | }
4239 | },
4240 | "ua-parser-js": {
4241 | "version": "0.7.17",
4242 | "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.17.tgz",
4243 | "integrity": "sha512-uRdSdu1oA1rncCQL7sCj8vSyZkgtL7faaw9Tc9rZ3mGgraQ7+Pdx7w5mnOSF3gw9ZNG6oc+KXfkon3bKuROm0g=="
4244 | },
4245 | "uglify-js": {
4246 | "version": "2.6.4",
4247 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.6.4.tgz",
4248 | "integrity": "sha1-ZeovswWck5RpLxX+2HwrNsFrmt8=",
4249 | "dev": true,
4250 | "requires": {
4251 | "async": "0.2.10",
4252 | "source-map": "0.5.7",
4253 | "uglify-to-browserify": "1.0.2",
4254 | "yargs": "3.10.0"
4255 | }
4256 | },
4257 | "uglify-js-brunch": {
4258 | "version": "2.10.0",
4259 | "resolved": "https://registry.npmjs.org/uglify-js-brunch/-/uglify-js-brunch-2.10.0.tgz",
4260 | "integrity": "sha1-YM0PtlKIegLOarzRWI3lXcw0bwU=",
4261 | "dev": true,
4262 | "requires": {
4263 | "uglify-js": "2.6.4"
4264 | }
4265 | },
4266 | "uglify-to-browserify": {
4267 | "version": "1.0.2",
4268 | "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz",
4269 | "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=",
4270 | "dev": true
4271 | },
4272 | "universal-path": {
4273 | "version": "0.1.0",
4274 | "resolved": "https://registry.npmjs.org/universal-path/-/universal-path-0.1.0.tgz",
4275 | "integrity": "sha1-D8okyTbqPSKCAT0UNxDAZoftBnc=",
4276 | "dev": true
4277 | },
4278 | "unpipe": {
4279 | "version": "1.0.0",
4280 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
4281 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=",
4282 | "dev": true
4283 | },
4284 | "untildify": {
4285 | "version": "2.1.0",
4286 | "resolved": "https://registry.npmjs.org/untildify/-/untildify-2.1.0.tgz",
4287 | "integrity": "sha1-F+soB5h/dpUunASF/DEdBqgmouA=",
4288 | "dev": true,
4289 | "requires": {
4290 | "os-homedir": "1.0.2"
4291 | }
4292 | },
4293 | "url": {
4294 | "version": "0.11.0",
4295 | "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz",
4296 | "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=",
4297 | "dev": true,
4298 | "requires": {
4299 | "punycode": "1.3.2",
4300 | "querystring": "0.2.0"
4301 | },
4302 | "dependencies": {
4303 | "punycode": {
4304 | "version": "1.3.2",
4305 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz",
4306 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=",
4307 | "dev": true
4308 | }
4309 | }
4310 | },
4311 | "util": {
4312 | "version": "0.10.3",
4313 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz",
4314 | "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=",
4315 | "dev": true,
4316 | "requires": {
4317 | "inherits": "2.0.1"
4318 | },
4319 | "dependencies": {
4320 | "inherits": {
4321 | "version": "2.0.1",
4322 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz",
4323 | "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=",
4324 | "dev": true
4325 | }
4326 | }
4327 | },
4328 | "util-deprecate": {
4329 | "version": "1.0.2",
4330 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
4331 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
4332 | "dev": true
4333 | },
4334 | "utils-merge": {
4335 | "version": "1.0.1",
4336 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
4337 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=",
4338 | "dev": true
4339 | },
4340 | "vary": {
4341 | "version": "1.1.2",
4342 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
4343 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=",
4344 | "dev": true
4345 | },
4346 | "vm-browserify": {
4347 | "version": "0.0.4",
4348 | "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-0.0.4.tgz",
4349 | "integrity": "sha1-XX6kW7755Kb/ZflUOOCofDV9WnM=",
4350 | "dev": true,
4351 | "requires": {
4352 | "indexof": "0.0.1"
4353 | }
4354 | },
4355 | "whatwg-fetch": {
4356 | "version": "2.0.3",
4357 | "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-2.0.3.tgz",
4358 | "integrity": "sha1-nITsLc9oGH/wC8ZOEnS0QhduHIQ="
4359 | },
4360 | "which": {
4361 | "version": "1.3.0",
4362 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz",
4363 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==",
4364 | "dev": true,
4365 | "requires": {
4366 | "isexe": "2.0.0"
4367 | }
4368 | },
4369 | "window-size": {
4370 | "version": "0.1.0",
4371 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz",
4372 | "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=",
4373 | "dev": true
4374 | },
4375 | "wordwrap": {
4376 | "version": "0.0.3",
4377 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz",
4378 | "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=",
4379 | "dev": true
4380 | },
4381 | "wrappy": {
4382 | "version": "1.0.2",
4383 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
4384 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
4385 | "dev": true
4386 | },
4387 | "xtend": {
4388 | "version": "4.0.1",
4389 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz",
4390 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=",
4391 | "dev": true
4392 | },
4393 | "yargs": {
4394 | "version": "3.10.0",
4395 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz",
4396 | "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=",
4397 | "dev": true,
4398 | "requires": {
4399 | "camelcase": "1.2.1",
4400 | "cliui": "2.1.0",
4401 | "decamelize": "1.2.0",
4402 | "window-size": "0.1.0"
4403 | }
4404 | }
4405 | }
4406 | }
4407 |
--------------------------------------------------------------------------------