Making SOAP requests to third part web service

I am working with a third-party web service that was originally integrated into a .NET application. I am looking to port this functionality over to an elixir web application. The company that provides the web service does not provide a WSDL so I can’t use a SOAP library like elixir-soap/soap.

Below is an example SOAP request that is made. Let’s say the request gets the inventory for a store.

<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing" xmlns:u="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
    <s:Header>
        <a:Action s:mustUnderstand="1">{action url goes here}/GetInventory</a:Action>
        <a:To s:mustUnderstand="1">{the web service url goes here}/WS</a:To>
        <o:Security s:mustUnderstand="1" xmlns:o="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
            <o:UsernameToken u:Id="uuid-14f7c28e-ae3e-42l3kj23">
                <o:Username>{{client_username}}</o:Username>
                <o:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">{{client_password}}</o:Password>
            </o:UsernameToken>
        </o:Security>
    </s:Header>
    <s:Body>
        <GetInventory xmlns="https://www.provexchnet.com/dsi" />
    </s:Body>
</s:Envelope>

Question 1: Is phoenix the best tool for something like this?
Question 2: What the best way to build these XML SOAP requests in elixir prior to sending?
Question 3: What is the best way to send these requests via HTTP?
Question 4: What is the best way to parse the responses?

Q1: Phoenix is a web server, not an HTTP request client, but there is no reason not to be able to integrate that.
Q2: I can’t answer that because I don’t use SOAP, but a simple Google search for: “soap elixir” should give you a decent start. You can always build it yourself if you need it to be custom. In the end, it is just an HTTP request.
Q3: HTTP client libraries and wrappers
Q4: Are you parsing a JSON or XML?

1 Like

Thanks arcyfelix! I get that phoenix is not an http client. Just looking for personal opinions on whether or not phoenix is the right choice for a task like this over languages like C# or Java.

Q4: I will be parsing XML.

I would approach the problem a little bit differently by asking two questions:

  1. What are the subparts of my problem?
    In your case: A web server, a soap library, an HTTP client and an xml parser.

  2. What are the best tools for the job?
    Well, I generally just Google: “<my problem / subsystem> elixir” or search in the forum and I look at if the project is maintained or complete.

In your case:

  1. Phoenix or if you go minimalistically cowboy + plug (Building a web framework from scratch in Elixir).
  2. In your case, you might need to search a little bit more if the library you found doesn’t support what you want.
  3. HTTP client (already answered on this forum - HTTP client libraries and wrappers)
  4. XML parser (already answered on this forum - Library to safely parse XML (by avoiding random atom creation))
2 Likes

Really hard to answer without seeming biased but, with respect to your requirements, I think Phoenix is indeed one of the best tools for your project, because:

  1. You essentially need a reverse proxy of sorts, a rewriting one i.e. you accept certain data, massage it and send it downstream to other services. And then get data back from them, maybe massage them as well, and return those to your users.
  2. The Erlang’s runtime is excellent at this because if your downstream services are slow – say, it needs 5-10 seconds to respond – then your Phoenix app will easily take it because you have hundreds of thousands of such requests waiting and every single one of them will get fair treatment. You only have to tune your own Phoenix app’s response timeouts (i.e. give them more generous values, from 10s and up I suppose).
  3. Your memory load should remain predictable because each request (== Erlang “process” which is :exclamation:NOT:exclamation: the same as OS process!) is isolated and garbage-collected separately.

All in all, your latency will be predictable, memory requirements and pressure will be stable, and 99.9999% of all your problems will be with your downstream services and not with Phoenix (unless you get DDoS-ed).

Honestly no clue but you can’t go wrong with any library that supports building XML e.g. GitHub - joshnuss/xml_builder: Elixir library for generating XML.

Try this Hex search maybe?

I’d say either Req or Tesla + Finch below it.

I would say reach for Erlang’s :xmerl_scan directly but be warned: it’s not trivial. You can make some scary fast code, but it’s not easy to write. There are several libraries i.e. sweet_xml that step on top of xmerl that might be a bit easier for you but be warned (again) that you have to monitor your app well – good telemetry and metrics will be pretty much mandatory so you can keep track of CPU and memory usage and be able to switch to another library if the current one is under-performing or is straining your hosting too much.

1 Like