2017-09-10 23:26:00 +02:00
|
|
|
diff --git a/bootstrap b/bootstrap
|
2018-07-12 21:48:43 +02:00
|
|
|
index 5dedd713..864056c4 100755
|
2017-09-10 23:26:00 +02:00
|
|
|
--- a/bootstrap
|
|
|
|
+++ b/bootstrap
|
|
|
|
@@ -101,7 +101,7 @@ extract(Binary) ->
|
|
|
|
request(Url) ->
|
|
|
|
HttpOptions = [{relaxed, true} | get_proxy_auth()],
|
2016-11-23 22:06:15 +01:00
|
|
|
|
2017-09-10 23:26:00 +02:00
|
|
|
- case httpc:request(get, {Url, []},
|
|
|
|
+ case rebar_hermeticity:request(get, {Url, []},
|
|
|
|
HttpOptions,
|
|
|
|
[{body_format, binary}],
|
|
|
|
rebar) of
|
2016-11-23 22:06:15 +01:00
|
|
|
diff --git a/src/rebar_hermeticity.erl b/src/rebar_hermeticity.erl
|
2018-07-12 21:48:43 +02:00
|
|
|
index e69de29b..8f6cc7d0 100644
|
|
|
|
--- a/src/rebar_hermeticity.erl
|
2016-11-23 22:06:15 +01:00
|
|
|
+++ b/src/rebar_hermeticity.erl
|
2016-01-16 22:47:21 +01:00
|
|
|
@@ -0,0 +1,42 @@
|
|
|
|
+%% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*-
|
|
|
|
+%% ex: ts=4 sw=4 et
|
|
|
|
+%% -------------------------------------------------------------------
|
|
|
|
+%%
|
|
|
|
+%% rebar: Erlang Build Tools
|
|
|
|
+%%
|
|
|
|
+%% Copyright (c) 2016 Eric Merritt (eric@merritt.tech)
|
|
|
|
+%%
|
|
|
|
+%% Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
+%% of this software and associated documentation files (the "Software"), to deal
|
|
|
|
+%% in the Software without restriction, including without limitation the rights
|
|
|
|
+%% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
+%% copies of the Software, and to permit persons to whom the Software is
|
|
|
|
+%% furnished to do so, subject to the following conditions:
|
|
|
|
+%%
|
|
|
|
+%% The above copyright notice and this permission notice shall be included in
|
|
|
|
+%% all copies or substantial portions of the Software.
|
|
|
|
+%%
|
|
|
|
+%% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
+%% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
+%% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
+%% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
+%% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
+%% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
+%% THE SOFTWARE.
|
|
|
|
+%% -------------------------------------------------------------------
|
2016-11-23 22:06:15 +01:00
|
|
|
+-module(rebar_hermeticity).
|
2016-01-16 22:47:21 +01:00
|
|
|
+
|
|
|
|
+-export([request/5]).
|
|
|
|
+
|
|
|
|
+-include("rebar.hrl").
|
|
|
|
+
|
|
|
|
+%% ====================================================================
|
|
|
|
+%% Public API
|
|
|
|
+%% ====================================================================
|
|
|
|
+
|
|
|
|
+request(Method, {Url, _Headers}, _HTTPOptions, _Options, _Profile) ->
|
|
|
|
+ ?ERROR("A request is being made that violates Nix hermicity "
|
|
|
|
+ "This request has been stopped. Details of the request "
|
|
|
|
+ "are as follows:", []),
|
2016-11-23 22:06:15 +01:00
|
|
|
+ ?ERROR("Request: ~p ~s", [Method, Url]),
|
2016-01-16 22:47:21 +01:00
|
|
|
+ erlang:halt(1).
|
2016-11-23 22:06:15 +01:00
|
|
|
diff --git a/src/rebar_pkg_resource.erl b/src/rebar_pkg_resource.erl
|
2018-07-12 21:48:43 +02:00
|
|
|
index 2cf167ee..6080aaca 100644
|
2016-01-16 22:47:21 +01:00
|
|
|
--- a/src/rebar_pkg_resource.erl
|
|
|
|
+++ b/src/rebar_pkg_resource.erl
|
2018-07-12 21:48:43 +02:00
|
|
|
@@ -127,7 +127,7 @@ make_vsn(_) ->
|
2016-01-16 22:47:21 +01:00
|
|
|
request(Url, ETag) ->
|
2018-07-12 21:48:43 +02:00
|
|
|
HttpOptions = [{ssl, ssl_opts(Url)},
|
|
|
|
{relaxed, true} | rebar_utils:get_proxy_auth()],
|
|
|
|
- case httpc:request(get, {Url, [{"if-none-match", "\"" ++ ETag ++ "\""}
|
|
|
|
+ case rebar_hermeticity:request(get, {Url, [{"if-none-match", "\"" ++ ETag ++ "\""}
|
|
|
|
|| ETag =/= false] ++
|
|
|
|
[{"User-Agent", rebar_utils:user_agent()}]},
|
|
|
|
HttpOptions, [{body_format, binary}], rebar) of
|
2016-11-23 22:06:15 +01:00
|
|
|
diff --git a/src/rebar_prv_update.erl b/src/rebar_prv_update.erl
|
2018-07-12 21:48:43 +02:00
|
|
|
index 17446311..4d44d794 100644
|
2016-01-16 22:47:21 +01:00
|
|
|
--- a/src/rebar_prv_update.erl
|
|
|
|
+++ b/src/rebar_prv_update.erl
|
2017-09-10 23:26:00 +02:00
|
|
|
@@ -38,6 +38,8 @@ init(State) ->
|
|
|
|
{ok, State1}.
|
|
|
|
|
|
|
|
-spec do(rebar_state:t()) -> {ok, rebar_state:t()} | {error, string()}.
|
|
|
|
+do(State) -> {ok, State}.
|
|
|
|
+-ifdef(non_hermetic).
|
|
|
|
do(State) ->
|
|
|
|
try
|
|
|
|
case rebar_packages:registry_dir(State) of
|
2018-07-12 21:48:43 +02:00
|
|
|
@@ -53,7 +55,7 @@ do(State) ->
|
2016-04-22 20:03:39 +02:00
|
|
|
{ok, Url} ->
|
2018-07-12 21:48:43 +02:00
|
|
|
HttpOptions = [{relaxed, true} | rebar_utils:get_proxy_auth()],
|
2016-04-22 20:03:39 +02:00
|
|
|
?DEBUG("Fetching registry from ~p", [Url]),
|
|
|
|
- case httpc:request(get, {Url, [{"User-Agent", rebar_utils:user_agent()}]},
|
2016-11-23 22:06:15 +01:00
|
|
|
+ case rebar_hermeticity:request(get, {Url, [{"User-Agent", rebar_utils:user_agent()}]},
|
2018-07-12 21:48:43 +02:00
|
|
|
HttpOptions, [{stream, TmpFile}, {sync, true}],
|
2016-04-22 20:03:39 +02:00
|
|
|
rebar) of
|
|
|
|
{ok, saved_to_file} ->
|
2018-07-12 21:48:43 +02:00
|
|
|
@@ -77,6 +79,7 @@ do(State) ->
|
|
|
|
?DEBUG("Error creating package index: ~p ~p", [C, S]),
|
2017-09-10 23:26:00 +02:00
|
|
|
throw(?PRV_ERROR(package_index_write))
|
|
|
|
end.
|
|
|
|
+-endif.
|
|
|
|
|
|
|
|
-spec format_error(any()) -> iolist().
|
|
|
|
format_error({package_parse_cdn, Uri}) ->
|