Mint.TransportError exception (Mint v1.2.1) View Source
Represents an error with the transport used by an HTTP connection.
A Mint.TransportError
struct is an exception, so it can be raised as any
other exception.
Struct fields
This exception represents an error with the transport (TCP or SSL) used by an HTTP connection. The exception struct itself is opaque, that is, not all fields are public. The following are the public fields:
:reason
- a term representing the error reason. The value of this field can be::timeout
- if there's a timeout in interacting with the socket.:closed
- if the connection has been closed.:protocol_not_negotiated
- if the ALPN protocol negotiation failed.{:bad_alpn_protocol, protocol}
- when the ALPN protocol is not one of the supported protocols, which arehttp/1.1
andh2
.- the
:inet.posix/0
type - if there's any other error with the socket, such as:econnrefused
or:nxdomain
. - the
:ssl.error_alert/0
type - if there's an SSL error.
Message representation
If you want to convert an error reason to a human-friendly message (for example
for using in logs), you can use Exception.message/1
:
iex> {:error, %Mint.TransportError{} = error} = Mint.HTTP.connect(:http, "nonexistent", 80)
iex> Exception.message(error)
"non-existing domain"
Link to this section Summary
Functions
Callback implementation for Exception.message/1
.
Link to this section Types
Specs
t() :: %Mint.TransportError{ __exception__: term(), reason: ((:timeout | :closed | :protocol_not_negotiated | {:bad_alpn_protocol, String.t()} | :inet.posix()) | :ssl.error_alert()) | term() }
Link to this section Functions
Callback implementation for Exception.message/1
.