Akd v0.2.1 Akd.Build.Phoenix.Brunch View Source
A native Hook module that comes shipped with Akd.
This module uses Akd.Hook
.
Provides a set of operations that build a brunch release for a given phoenix app
at a deployment’s build_at
destination. This hook assumes that an executable
brunch binary file is already present or initialized by either
a previously executed hook or manually.
Ensures to cleanup and empty the deps folder created by this build.
Doesn’t have any Rollback operations.
Options:
run_ensure
:boolean
. Specifies whether to a run a command or not.ignore_failure
:boolean
. Specifies whether to continue if this hook fails.brunch
:string
. Path to brunch executable from project’s root.brunch_config
:string
. Path to brunch config from project’s root.cmd_envs
:list
oftuples
. Specifies the environments to provide while building the distillery release.
Defaults:
run_ensure
:true
ignore_failure
:false
brunch
: “node_modules/brunch/bin/brunch”brunch_config
: “.”
Link to this section Summary
Functions
Callback implementation for get_hooks/2
Link to this section Functions
Link to this function
get_hooks(deployment, opts)
View Source
get_hooks(Akd.Deployment.t(), Keyword.t()) :: [Akd.Hook.t()]
get_hooks(Akd.Deployment.t(), list()) :: Akd.Hook.t()
Callback implementation for get_hooks/2
.
This function returns a list of operations that can be used to build a brunch
release on the build_at
destination of a deployment.
Examples
iex> deployment = %Akd.Deployment{mix_env: "prod",
...> build_at: Akd.Destination.local("."),
...> publish_to: Akd.Destination.local("."),
...> name: "name",
...> vsn: "0.1.1"}
iex> Akd.Build.Phoenix.Brunch.get_hooks(deployment, [])
[%Akd.Hook{ensure: [], ignore_failure: false,
main: [%Akd.Operation{cmd: "mix deps.get \n mix compile",
cmd_envs: [{"MIX_ENV", "prod"}],
destination: %Akd.Destination{host: :local, path: ".",
user: :current}},
%Akd.Operation{cmd: "cd . \n node_modules/brunch/bin/brunch build --production",
cmd_envs: [],
destination: %Akd.Destination{host: :local, path: ".",
user: :current}},
%Akd.Operation{cmd: "mix phx.digest",
cmd_envs: [{"MIX_ENV", "prod"}],
destination: %Akd.Destination{host: :local, path: ".",
user: :current}}], rollback: [], run_ensure: true}]