Pass cacerts options to Mint only when SSL (#2449)

This commit is contained in:
Jonatan Kłosko 2024-01-25 14:58:53 +01:00 committed by GitHub
parent 0056a81b7f
commit 883c0f39ec
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -21,7 +21,14 @@ defmodule Livebook.Teams.WebSocket do
uri = URI.parse(Livebook.Config.teams_url()) uri = URI.parse(Livebook.Config.teams_url())
{http_scheme, ws_scheme} = parse_scheme(uri) {http_scheme, ws_scheme} = parse_scheme(uri)
state = %{status: nil, headers: [], body: []} state = %{status: nil, headers: [], body: []}
opts = [protocols: [:http1], transport_opts: [cacerts: :public_key.cacerts_get()]] opts = [protocols: [:http1]]
opts =
if http_scheme == :https do
put_in(opts[:transport_opts][:cacerts], :public_key.cacerts_get())
else
opts
end
with {:ok, conn} <- Mint.HTTP.connect(http_scheme, uri.host, uri.port, opts), with {:ok, conn} <- Mint.HTTP.connect(http_scheme, uri.host, uri.port, opts),
{:ok, conn, ref} <- Mint.WebSocket.upgrade(ws_scheme, conn, @ws_path, headers) do {:ok, conn, ref} <- Mint.WebSocket.upgrade(ws_scheme, conn, @ws_path, headers) do