Wow, this is an odd one.
I’m making an http request (post) to a server.
- Work fine from curl
- Works fine from iex
- Bombs out when I run from within app!
I have literally never had this happen before, when the EXACT same function behaves differently live vs. iex.
Just wondering if anyone has insight into some magic that might be going on behind the scenes that could be causing this! (This is a phoenix app, but doesn’t seem phoenix-related…)
I even added a checksum function to make sure the data being sent was identical & there wasn’t some odd file-write delay causing the issue.
Example - Success from iex (note–iex is actually connected to the running app!):
iex(91be5e1d30ff@172.21.0.3)5> Polo.Ib.Connect.post(body, "/create")
13:24:11.570 [info] Ib.Connect.post endpoint: [ https://qa.xyz.com/ws/eca/create ]
13:24:11.573 [warn]
Mojito.request(
method: :post,
url: https://qa.xyz.com/ws/eca/create,
headers: [{"Content-Type", "application/json"}, {"User-Agent", "Elixir"}, {"Accept", "*/*"}],
body: data -> checksum = 904033a8a73bdea778edf96317957f40704686cd,
opts: [timeout: 180_000, transport_opts: [verify: :verify_none]]
)
{:ok,
%{
"batchId" => 305738,
"fileData" => %{
"data" => "hQ ... eFBJXdc/cKHQ==",
"name" => "sgimFA_20200211-082414031_965716.xml"
},
"isProcessed" => true,
"timestamp" => "2020-02-11 08:24:15"
}}
works great!
From with the app, when running programmatically, I get
[info] Ib.Connect.post endpoint: [ https://qa.xyz.com/ws/eca/create ]
[warn]
Mojito.request(
method: :post,
url: https://qa.xyz.com/ws/eca/create,
headers: [{"Content-Type", "application/json"}, {"User-Agent", "Elixir"}, {"Accept", "*/*"}],
body: data -> checksum = 904033a8a73bdea778edf96317957f40704686cd,
opts: [timeout: 180_000, transport_opts: [verify: :verify_none]]
)
[error] %Mojito.Response{body: "<!DOCTYPE html>\n<html>
\n<head>\n<title>Account Management Unavailable | ... \" content=\"500 Error\">\n<<> ...,
complete: true,
headers: [{"date", "Tue, 11 Feb 2020 13:21:47 GMT"},
{"server", "Apache"},
{"vary", "\\\"Origin\\\""},
{"content-security-policy", "frame-ancestors 'self' ... .com;"},
{"content-length", "5879"},
{"connection", "close"},
{"content-type", "text/html; charset=UTF-8"}],
status_code: 500}
Note that the checksum of the data is identical! The headers are identical! It’s literally the exact same function with identical arguments.
I am just totally at a loss as to what could be different.
Any thoughts are appreciated!
ps Was using HTTPPoision, then switched to Mojito/Mint to see if that would fix, but same issue.