diff options
author | Fred Hebert <mononcqc@ferd.ca> | 2015-09-10 18:02:22 -0400 |
---|---|---|
committer | Fred Hebert <mononcqc@ferd.ca> | 2015-09-10 18:02:22 -0400 |
commit | e5b8a97c5f1bf4968cfd545945fb37ab7386cab4 (patch) | |
tree | d2f76cc9192ba143f0f8ebda72657c6a25e89037 /src/rebar_prv_local_upgrade.erl | |
parent | ebb919f228ab694ddd6c114fb6dc66989e7d8707 (diff) | |
parent | 9fb81989267b01a954108c4b9528e52a595aa199 (diff) |
Merge pull request #784 from tsloughter/extract
add 'local install' and 'local upgrade'
Diffstat (limited to 'src/rebar_prv_local_upgrade.erl')
-rw-r--r-- | src/rebar_prv_local_upgrade.erl | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/src/rebar_prv_local_upgrade.erl b/src/rebar_prv_local_upgrade.erl new file mode 100644 index 0000000..9431524 --- /dev/null +++ b/src/rebar_prv_local_upgrade.erl @@ -0,0 +1,84 @@ +%% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*- +%% ex: ts=4 sw=4 et + +-module(rebar_prv_local_upgrade). + +-behaviour(provider). + +-export([init/1, + do/1, + format_error/1]). + +-include("rebar.hrl"). +-include_lib("kernel/include/file.hrl"). + +-define(PROVIDER, upgrade). +-define(NAMESPACE, unstable). +-define(DEPS, []). + +%% =================================================================== +%% Public API +%% =================================================================== + +-spec init(rebar_state:t()) -> {ok, rebar_state:t()}. +init(State) -> + State1 = + rebar_state:add_provider(State, + providers:create([{name, ?PROVIDER}, + {module, ?MODULE}, + {bare, true}, + {namespace, ?NAMESPACE}, + {deps, ?DEPS}, + {example, "rebar3 unstable upgrade"}, + {short_desc, "Download latest rebar3 escript and extract."}, + {desc, ""}, + {opts, []}])), + {ok, State1}. + +-spec do(rebar_state:t()) -> {ok, rebar_state:t()} | {error, string()}. +do(State) -> + case os:type() of + {win32, _} -> + ?ERROR("Sorry, this feature is not yet available on Windows.", []), + {ok, State}; + _ -> + Md5 = case rebar_state:escript_path(State) of + undefined -> + false; + ScriptPath -> + get_md5(ScriptPath) + end, + + case maybe_fetch_rebar3(Md5) of + {saved, TmpRebar3} -> + rebar_prv_local_install:extract_escript(State, TmpRebar3); + _ -> + {ok, State} + end + end. + +-spec format_error(any()) -> iolist(). +format_error(Reason) -> + io_lib:format("~p", [Reason]). + +%% Internal + +get_md5(Rebar3Path) -> + {ok, Rebar3File} = file:read_file(Rebar3Path), + Digest = crypto:hash(md5, Rebar3File), + DigestHex = lists:flatten([io_lib:format("~2.16.0B", [X]) || X <- binary_to_list(Digest)]), + string:to_lower(DigestHex). + +maybe_fetch_rebar3(Rebar3Md5) -> + TmpDir = ec_file:insecure_mkdtemp(), + TmpFile = filename:join(TmpDir, "rebar3"), + case rebar_pkg_resource:request("https://s3.amazonaws.com/rebar3/rebar4", Rebar3Md5) of + {ok, Binary, _ETag} -> + file:write_file(TmpFile, Binary), + {saved, TmpFile}; + error -> + ?ERROR("Unable to fetch latest rebar3 escript. Please try again later.", []); + _ -> + ?CONSOLE("No upgrade available", []), + up_to_date + end. |