Skip to content

Commit

Permalink
Check CAcert file exists when installing extension
Browse files Browse the repository at this point in the history
The extension installation will no longer fail if the CA cert file is
not accessible. It'll print a warning and use the library defaults.
  • Loading branch information
luismiramirez committed Feb 14, 2022
1 parent faa7441 commit 45b32aa
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 7 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
bump: "patch"
type: "change"
---

The extension installation will no longer fail when the CA certificate file is not accessible.
42 changes: 35 additions & 7 deletions mix_helpers.exs
Original file line number Diff line number Diff line change
Expand Up @@ -252,13 +252,28 @@ defmodule Mix.Appsignal.Helper do
end

defp download_options do
options = [
ssl_options:
[
verify: :verify_peer,
cacertfile: priv_path("cacert.pem")
] ++ tls_options() ++ customize_hostname_check_or_verify_fun()
]
default_cacert_file_path = priv_path("popo.pem")

options =
case check_cacert_access(default_cacert_file_path) do
:ok ->
[
ssl_options:
[
verify: :verify_peer,
cacertfile: default_cacert_file_path
] ++ tls_options() ++ customize_hostname_check_or_verify_fun()
]

{:error, message} ->
Logger.warn(
"The cacert file path: #{default_cacert_file_path} is not accessible. " <>
"Reason: #{inspect(message)}. " <>
"Using system defaults instead."
)

[]
end

case check_proxy() do
nil ->
Expand All @@ -270,6 +285,19 @@ defmodule Mix.Appsignal.Helper do
end
end

defp check_cacert_access(cacert_path) do
case File.stat(cacert_path) do
{:ok, %{access: access}} when access in [:read, :read_write] ->
:ok

{:ok, %{access: access}} ->
{:error, "File access is #{inspect(access)}"}

{:error, reason} ->
{:error, reason}
end
end

defp extract_package(filename) do
case System.cmd("tar", ["zxf", filename, "--no-same-owner"],
stderr_to_stdout: true,
Expand Down

0 comments on commit 45b32aa

Please sign in to comment.