Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/elixir-soap/soap
SOAP client for Elixir programming language
https://github.com/elixir-soap/soap
elixir soap
Last synced: 2 months ago
JSON representation
SOAP client for Elixir programming language
- Host: GitHub
- URL: https://github.com/elixir-soap/soap
- Owner: elixir-soap
- License: mit
- Created: 2017-12-21T13:25:02.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-06-18T11:14:55.000Z (7 months ago)
- Last Synced: 2024-09-24T17:17:34.962Z (4 months ago)
- Topics: elixir, soap
- Language: Elixir
- Homepage:
- Size: 1.74 MB
- Stars: 134
- Watchers: 6
- Forks: 75
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
- fucking-awesome-elixir - SOAP client - Hex-documented SOAP client based on HTTPoison. (REST and API)
- awesome-elixir - SOAP client - Hex-documented SOAP client based on HTTPoison. (REST and API)
README
# Soap
[![Build Status](https://travis-ci.org/elixir-soap/soap.svg?branch=master)](https://travis-ci.org/elixir-soap/soap)
[![Code coverage](https://img.shields.io/coveralls/github/elixir-soap/soap.svg?style=flat)](https://coveralls.io/github/elixir-soap/soap)
[![Module Version](https://img.shields.io/hexpm/v/soap.svg)](https://hex.pm/packages/soap)
[![Hex Docs](https://img.shields.io/badge/hex-docs-lightgreen.svg)](https://hexdocs.pm/soap/)
[![Total Download](https://img.shields.io/hexpm/dt/soap.svg)](https://hex.pm/packages/soap)
[![License](https://img.shields.io/hexpm/l/soap.svg)](https://github.com/elixir-soap/soap/blob/master/LICENSE.md)
[![Last Updated](https://img.shields.io/github/last-commit/elixir-soap/soap.svg)](https://github.com/elixir-soap/soap/commits/master)SOAP client for Elixir programming language.
## Installation
Add `:soap` to your deps:
```elixir
def deps do
[
{:soap, "~> 1.0"}
]
end
```
Add `:soap` to the list of application dependencies(or just use `extra_applications`):```elixir
def application do
[
applications: [:logger, :soap]
]
end
```## Configuration
Configure version of SOAP protocol. Supported versions `1.1`(default) and `1.2`:
```elixir
config :soap, :globals, version: "1.1"
```## Usage
The documentation is available on [HexDocs](https://hexdocs.pm/soap/api-reference.html).
Parse WSDL file for execution of actions on its basis:
```elixir
iex> {:ok, wsdl} = Soap.init_model(wsdl_path, :url)
{:ok, parsed_wsdl}
```Get list of available operations:
```elixir
iex> Soap.operations(wsdl)
[
%{
input: %{body: nil, header: nil},
name: "Add",
soap_action: "http://tempuri.org/Add"
},
%{
input: %{body: nil, header: nil},
name: "Subtract",
soap_action: "http://tempuri.org/Subtract"
},
%{
input: %{body: nil, header: nil},
name: "Multiply",
soap_action: "http://tempuri.org/Multiply"
},
%{
input: %{body: nil, header: nil},
name: "Divide",
soap_action: "http://tempuri.org/Divide"
}
]
```Call action:
```elixir
wsdl_path = "http://www.dneonline.com/calculator.asmx?WSDL"
action = "Add"
params = %{intA: 1, intB: 2}iex> {:ok, response} = Soap.call(wsdl, action, params)
{:ok,
%Soap.Response{
body: "3",
headers: [
{"Cache-Control", "private, max-age=0"},
{"Content-Length", "325"},
{"Content-Type", "text/xml; charset=utf-8"},
{"Server", "Microsoft-IIS/7.5"},
{"X-AspNet-Version", "2.0.50727"},
{"X-Powered-By", "ASP.NET"},
{"Date", "Thu, 14 Feb 2019 07:52:04 GMT"}
],
request_url: "http://www.dneonline.com/calculator.asmx",
status_code: 200
}}
```Parse response:
```elixir
iex> Soap.Response.parse(response)
%{AddResponse: %{AddResult: "3"}}
```To add SOAP headers, pass in a `{headers, params}` tuple instead of just params:
```elixir
{:ok, %Soap.Response{}} = Soap.call(wsdl, action, {%{Token: "foo"}, params})
```## Contributing
We appreciate any contribution and open to [future requests](https://github.com/elixir-soap/soap/pulls).You can find a list of features and bugs in the [issue tracker](https://github.com/elixir-soap/soap/issues).
## Copyright and License
Copyright (c) 2017 Petr Stepchenko
This work is free. You can redistribute it and/or modify it under the
terms of the MIT License. See the [LICENSE.md](./LICENSE.md) file for more details.