TeslaCurl is a middleware for Tesla. It will log a curl command for each request.
The package can be installed by adding tesla_curl
to your list of dependencies in mix.exs
:
def deps do
[
{:tesla_curl, "~> 1.3.1"}
]
end
defmodule HelloWorld do
use Tesla
plug Tesla.Middleware.Curl
end
Note - Plugs are executed in the order they are defined. As such, it is recommended you define TeslaCurl below other middlewares. For example, if the TeslaCurl plug is defined above the Headers middleware, headers will not be included in the curl log output.
If you prefer to use this library without the plug, you can use the TeslaCurl
module directly with log/2
:
defmodule HelloWorld do
def foo(Tesla.Env{} = env, opts \\ []) do
Tesla.Middleware.Curl.log(env, opts)
end
end
You can pass a list of header keys or body field keys to be redacted in the options, like so:
redact_fields: ["api_token", "authorization", "password"]
If supplied, the redacted fields will be replaced with REDACTED
in the curl command.
If a request's body is a string, you can use a regular expression with a capture group to redact the field. For example, if you were supplying Tesla with a string body that looked like this-
"<username>John Doe</username><password>horse battery staple</password>"
You could redact the password field by supplying the following option- redact_fields: [~r{<password>(.*?)</password>}]
. This field
will be replaced with <password>REDACTED</password>
in the curl command.
If you would like to enable the flag to follow redirects by default, supply follow_redirects: true
in the options list.
For compressed responses, you can supply the compressed: true
option. This will add the --compressed
flag to the curl command.
You can supply the logger_level
option to set the level of the logger. The default is :info
. Must be one of :debug
, :info
, :warn
, :error
, :fatal
, :none
.
Here is an example of options configuration with all options enabled:
plug Tesla.Middleware.Curl, follow_redirects: true, redact_fields: ["api_token", "authorization", "password"], compressed: true, logger_level: :debug
The source code is under the MIT License. Copyright (c) 2023-2025 Colin Cromar.