NAV
curl Python Ruby java csharp

MassPay API v0.1.4

Scroll down for code samples, example requests and responses. Select a language for code samples from the tabs above or the mobile navigation menu.

MassPay API

Base URLs:

Introduction

Welcome to the MassPay API documentation! Our API will give you the functionality to add beneficiaries, fund wallets, initiate transfers.

We have language bindings in Shell, Ruby, Python, Java and JavaScript! You can view code examples in the dark area to the right, and you can switch the programming language of the examples with the tabs in the top right.

Our API utilizes versioning and will therefore have different functionality based on the version set up in your account.

Making Requests

All requests and responses are JSON encoded. Requests must be made over SSL connections using HTTPS. Requests made over HTTP will be redirected to HTTPS.

Authentication

The MassPay API uses API keys to allow access to the API. You can register a new MassPay API key at our developer portal.

Do not share your secret API keys in publicly accessible areas such as GitHub, BitBucket, Open Source projects or client scripts.

MassPay API expects for the API key to be included in all API requests to the server in a header that looks like the following:

Authorization: bearer API_KEY

You must replace API_KEY with your personal API key.

Idempotent Requests

The API supports idempotency for safely retrying requests without accidentally performing the same operation twice. This is useful when an API call is disrupted in transit and you do not receive a response. For example, if a request to create a charge does not respond due to a network connection error, you can retry the request with the same idempotency key to guarantee that no more than one charge is created.

To perform an idempotent request, provide an additional Idempotency-Key: key header to the request.

MassPay's idempotency works by saving the resulting status code and body of the first request made for any given idempotency key, regardless of whether it succeeded or failed. Subsequent requests with the same key return the same result, including 500 errors.

An idempotency key is a unique value generated by the client which the server uses to recognize subsequent retries of the same request. How you create unique keys is up to you, but we suggest using V4 UUIDs, or another random string with enough entropy to avoid collisions.

Keys expire after 24 hours, so a new request is generated if a key is reused outside of that time frame. The idempotency layer compares incoming parameters to those of the original request and errors unless they're the same to prevent accidental misuse.

Results are only saved if an API endpoint started executing. If incoming parameters failed validation, or the request conflicted with another that was executing concurrently, no idempotent result is saved because no API endpoint began execution. It is safe to retry these requests.

Versioning

When we make backwards-incompatible changes to the API, we release new, dated versions. The current version is 0.1.4. Read our API upgrades guide to see our API changelog and to learn more about backwards compatibility.

To set the API version on a specific request, pass the version in the url. i.e. https://api.masspay.io/VERSION

Status Callbacks

There is support for initiating a callback to an https URL every time there is a status update to one of the payout transactions. In order to enable this feature, please provide a callback URL to your account representative. The URL will receive a POST request with the following payload format for every status change for a transaction.

Payout status change:

{
  "payout_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "client_transfer_id": "aEjn345",
  "source_currency_code": "USD",
  "destination_currency_code": "MXN",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "d2138fd0-00be-45a8-985f-4f5bde500962",
  "destination_amount": 100.5,
  "source_amount": 100.5,
  "attr_set_token": "b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
  "exchange_rate": 18.55,
  "fee": 2.99,
  "expiration": "2019-10-30T05:40:58.475Z",
  "status": "PENDING"
}

Scheduled load status change:

{
  "load_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "time_of_load": "2019-10-24T22:54:54.793Z",
  "client_load_id": "aEjn345",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "wallet_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "amount": 100.5,
  "source_currency_code": "USD",
  "notes": "Commission payment for July",
  "status": "COMPLETED"
}

Swimlanes

Changelog

0.1.3 to 0.1.4:

0.1.2 to 0.1.3:

0.1.1 to 0.1.2:

0.1.0 to 0.1.1:

0.0.3 to 0.1.0:

A user represents an individual or a business that can receive payments, such as employees, survey participants, contractors, or distributors. Users can withdraw funds using any of MassPay's supported payout options, including but not limited to bank accounts, debit card, PayPal account, prepaid cards, cash pickup locations, mobile wallets, etc. All payout options for a user are attached to their user resource, so you will always need to create users.

createUser

Code samples

# You can also use wget
curl -X POST https://{environment}.masspay.io/{VERSION}/user \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.post('https://{environment}.masspay.io/{VERSION}/user', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.post 'https://{environment}.masspay.io/{VERSION}/user',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/user";

      string json = @"{
  ""internal_user_id"": ""4324-rOzk"",
  ""address1"": ""2000 main st"",
  ""address2"": ""apt D"",
  ""city"": ""Santa Monica"",
  ""state_province"": ""CA"",
  ""postal_code"": ""90405"",
  ""country"": ""USA"",
  ""first_name"": ""John"",
  ""middle_name"": """",
  ""last_name"": ""Doe"",
  ""email"": ""jdoe@gmail.com"",
  ""language"": ""en"",
  ""mobile_number"": ""16502000226"",
  ""business_name"": ""ABC Company"",
  ""date_of_birth"": ""1975-03-24"",
  ""metadata"": {""group_id"":541},
  ""notify_user"": false
}";
      User content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(User content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(User content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /user

Create a user

To create a user, send a POST request to the /user endpoint and include the user details in JSON format in the request body. Upon creation of a user, you'll receive a user_token which would be used to interact with that user.

Body parameter

{
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "date_of_birth": "1975-03-24",
  "metadata": {"group_id":541},
  "notify_user": false
}

Parameters

Name In Type Required Description
body body User true Created user object

Example responses

200 Response

{
  "user_token": "usr_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "ACTIVE",
  "created_on": "2019-07-07T23:03:05",
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "timezone": "America/Los_Angeles",
  "date_of_birth": "1975-03-24",
  "metadata": {"group_id":541}
}

Responses

Status Meaning Description Schema
200 OK successful operation StoredUser
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input Exception

getUserByToken

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/user/{user_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/user/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/user/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/user/{user_token}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /user/{user_token}

Get user by user token

Gets a user profile for a provided user token.

Parameters

Name In Type Required Description
user_token path string true The user token that needs to be fetched.
Idempotency-Key header string false Unique key to prevent duplicate processing

Example responses

200 Response

{
  "user_token": "usr_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "ACTIVE",
  "created_on": "2019-07-07T23:03:05",
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "timezone": "America/Los_Angeles",
  "date_of_birth": "1975-03-24",
  "metadata": {"group_id":541}
}

Responses

Status Meaning Description Schema
200 OK successful operation StoredUser
400 Bad Request Invalid user token supplied None
404 Not Found User not found None

updateUser

Code samples

# You can also use wget
curl -X PUT https://{environment}.masspay.io/{VERSION}/user/{user_token} \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.put('https://{environment}.masspay.io/{VERSION}/user/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.put 'https://{environment}.masspay.io/{VERSION}/user/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("PUT");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "https://{environment}.masspay.io/{VERSION}/user/{user_token}";


      string json = @"{
  ""status"": ""ACTIVE"",
  ""created_on"": ""2019-07-07T23:03:05"",
  ""internal_user_id"": ""4324-rOzk"",
  ""address1"": ""2000 main st"",
  ""address2"": ""apt D"",
  ""city"": ""Santa Monica"",
  ""state_province"": ""CA"",
  ""postal_code"": ""90405"",
  ""country"": ""USA"",
  ""first_name"": ""John"",
  ""middle_name"": """",
  ""last_name"": ""Doe"",
  ""email"": ""jdoe@gmail.com"",
  ""language"": ""en"",
  ""mobile_number"": ""16502000226"",
  ""business_name"": ""ABC Company"",
  ""date_of_birth"": ""1975-03-24"",
  ""metadata"": {
    ""group_id"": 541
  }
}";
      UpdateUser content = JsonConvert.DeserializeObject(json);
      var result = await PutAsync(id, content, url);


    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, UpdateUser content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(UpdateUser content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /user/{user_token}

Updated user

Updates profile information for a provided user token.

Body parameter

{
  "status": "ACTIVE",
  "created_on": "2019-07-07T23:03:05",
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "date_of_birth": "1975-03-24",
  "metadata": {
    "group_id": 541
  }
}

Parameters

Name In Type Required Description
user_token path string true user token that need to be updated
Idempotency-Key header string false Unique key to prevent duplicate processing
body body UpdateUser true Updated user object

Example responses

200 Response

{
  "user_token": "usr_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "ACTIVE",
  "created_on": "2019-07-07T23:03:05",
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "timezone": "America/Los_Angeles",
  "date_of_birth": "1975-03-24",
  "metadata": {
    "group_id": 541
  }
}

Responses

Status Meaning Description Schema
200 OK successful operation StoredUser
400 Bad Request Invalid user supplied None
404 Not Found User not found None

userLookup

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/user/lookup?email=string&first_name=string&internal_user_id=string \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/user/lookup', params={
  'email': 'string',  'first_name': 'string',  'internal_user_id': 'string'
}, headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/user/lookup',
  params: {
  'email' => 'string',
'first_name' => 'string',
'internal_user_id' => 'string'
}, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user/lookup?email=string&first_name=string&internal_user_id=string");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/user/lookup";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /user/lookup

Lookup an existing user

Looksup whether a user with the provided email and first name exist

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
email query string true User's email address. Required if First Name is provided
first_name query string true User's first name. Required if email is provided
internal_user_id query string true A client-defined identifier for the user. This is the unique ID assigned to the user on your system. Max 75 characters. Allows letters, numbers, and + , - . / _ ~

Example responses

405 Response

{
  "Exception": "string",
  "Errors": [
    "string"
  ]
}

Responses

Status Meaning Description Schema
200 OK Found a matching user FoundUser
403 Forbidden You do not have necessary permissions for the resource None
404 Not Found A user matching this email and first name could not be found None
405 Method Not Allowed Invalid input Exception

getUserHistory

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/user/{user_token}/history \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/user/{user_token}/history', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/user/{user_token}/history',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user/{user_token}/history");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/user/{user_token}/history";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /user/{user_token}/history

Transactions history

Retrieve list of all tranasctions (payouts/loads/spendbacks) for a provider user.

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
number_of_records query number false Number of records to return
start_date query string(date) false Starting date
end_date query string(date) false Ending date
page query integer false Page number
type query string false Filter particular types of transactions. Comma separated to include multiple types
wallet_token query string(uuid) false Filter transactions to include only provided wallet token.
user_token path string true Token representing the user to get transactions history for

Enumerated Values

Parameter Value
type payout
type load
type spendback

Example responses

200 Response

[
  {
    "token": "payout_d2138fd0-00be-45a8-985f-4f5b87500962",
    "type": "payout",
    "time_of_txn": "2021-02-25T01:24:44Z",
    "source_amount": 50.1,
    "source_currency_code": "USD",
    "destination_amount": 44.99,
    "destination_currency_code": "str",
    "fee": 2.98,
    "status": "READY_FOR_PICKUP",
    "notes": "Purchase of Candles. Order #14930",
    "payer_name": "Elektra",
    "pickup_code": "343432",
    "source_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
    "delivery_type": "CASH_PICKUP",
    "client_transfer_id": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK OK Inline

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [TxnHistoryResp] false none [Record that represents a transaction]
» TxnHistoryResp TxnHistoryResp false none Record that represents a transaction
»» token string(uuid) true none Token represnting the transaction
»» type string true none Type of transaction
»» time_of_txn string(date-time) true none Time the transaction was created. In UTC
»» source_amount number(float) true none Source amount
»» source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
»» destination_amount number(float) true none The amount that was received in destination_currency_code
»» destination_currency_code string true none The currency of the funds received. Using ISO 4217 format
»» fee number(float) true none Fee of the transaction
»» status string true none Status of the transaction
»» notes string false none Notes of the transaction when load or spend back
»» payer_name string false none Name of the payer when payout transaction
»» pickup_code string false none Code/pin that is required when collecting the money when payout transaction
»» source_token string(uuid) false none Token that represents the funding source i.e. bank account, wallet. 36 characters long
»» destination_token string(uuid) true none Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback. If not provided, the last destination that was used for this user will be used. 36 characters long
»» delivery_type string false none The type of service. I.e. cash pickup, home delivery, etc. Only provided for payouts
»» client_transfer_id string false none A client defined transfer identifier. This is the unique ID assigned to the transfer on your system. Max 50 characters.

Enumerated Values

Property Value
type load
type payout
type spend back
type info
status PENDING
status PROCESSING
status COMPLETED
status CANCELLED
status SCHEDULED
status READY_FOR_PICKUP
status HOLD
status ERROR
delivery_type CASH_PICKUP
delivery_type BANK_DEPOSIT
delivery_type HOME_DELIVERY
delivery_type MOBILE_WALLET
delivery_type MASSPAY_CARD
delivery_type PAPER_CHECK
delivery_type BILL
delivery_type CRYPTOCURRENCY

Payout

The payout resource describes a transfer from user’s account to a payout method.

initiatePayout

Code samples

# You can also use wget
curl -X POST https://{environment}.masspay.io/{VERSION}/payout/{user_token} \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.post('https://{environment}.masspay.io/{VERSION}/payout/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.post 'https://{environment}.masspay.io/{VERSION}/payout/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/payout/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/payout/{user_token}";

      string json = @"{
  ""client_transfer_id"": ""aEjn345"",
  ""source_currency_code"": ""USD"",
  ""destination_currency_code"": ""MXN"",
  ""source_token"": ""usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574"",
  ""destination_token"": ""dest_d2138fd0-00be-45a8-985f-4f5bde500962"",
  ""destination_amount"": 100.5,
  ""source_amount"": 100.5,
  ""attr_set_token"": ""attr_set_b1a867c1-6e36-4525-b6d5-a20bac80e3b0"",
  ""metadata"": {
    ""group_id"": 541
  }
}";
      PayoutTxn content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(PayoutTxn content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(PayoutTxn content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /payout/{user_token}

Initiate a payout transaction

Initiates a payout transaction to a provided user token.

Body parameter

{
  "client_transfer_id": "aEjn345",
  "source_currency_code": "USD",
  "destination_currency_code": "MXN",
  "source_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "destination_amount": 100.5,
  "source_amount": 100.5,
  "attr_set_token": "attr_set_b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
  "metadata": {
    "group_id": 541
  }
}

Parameters

Name In Type Required Description
user_token path string true Token representing the user to pay out
Idempotency-Key header string false Unique key to prevent duplicate processing
limit query number false Limit amount for transaction amount + fee. If fee + amount are higher than the limit, the output will automatically adjust to maximize the possible amount sent
body body PayoutTxn true Payout parameters for a quote

Example responses

200 Response

{
  "payout_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "client_transfer_id": "aEjn345",
  "source_currency_code": "USD",
  "destination_currency_code": "MXN",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "d2138fd0-00be-45a8-985f-4f5bde500962",
  "destination_amount": 100.5,
  "source_amount": 100.5,
  "attr_set_token": "b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
  "exchange_rate": 18.55,
  "fee": 2.99,
  "expiration": "2019-06-26T22:32:05",
  "pickup_code": "54238173",
  "status": "PENDING",
  "payer_logo": "...",
  "payer_name": "Elektra",
  "delivery_type": "CASH_PICKUP",
  "country_code": "MEX",
  "metadata": {
    "group_id": 541
  }
}

Responses

Status Meaning Description Schema
200 OK successful operation PayoutTxnResp
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input Exception

getUserPayoutsByToken

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/payout/{user_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/payout/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/payout/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/payout/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/payout/{user_token}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /payout/{user_token}

Get history of payouts by user token

Gets a list of all historical payouts for a provided user token.

Parameters

Name In Type Required Description
user_token path string true The user token that needs to be fetched.
Idempotency-Key header string false Unique key to prevent duplicate processing
include_payer_logos query boolean false Whether to include the payers logo in base64 format.

Example responses

200 Response

[
  {
    "payout_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "client_transfer_id": "aEjn345",
    "source_currency_code": "USD",
    "destination_currency_code": "MXN",
    "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "destination_token": "d2138fd0-00be-45a8-985f-4f5bde500962",
    "destination_amount": 100.5,
    "source_amount": 100.5,
    "attr_set_token": "b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
    "exchange_rate": 18.55,
    "fee": 2.99,
    "expiration": "2019-06-26T22:32:05",
    "pickup_code": "54238173",
    "status": "PENDING",
    "payer_logo": "...",
    "payer_name": "Elektra",
    "delivery_type": "CASH_PICKUP",
    "country_code": "MEX",
    "metadata": {
      "group_id": 541
    }
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
400 Bad Request Invalid user token supplied None
404 Not Found User not found None

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [PayoutTxnResp] false none none
» payout_token string(uuid) true none Token that represents the transaction that was just created. Need to be used to commit the transaction in /payout/{user_token}/{payout_token}. Value would be NSF if there are not enough funds in the source_token. Value would be DUPLICATE if there is a duplicate client_transfer_id.
» client_transfer_id string true none A client defined transfer identifier. This is the unique ID assigned to the transfer on your system. Max 50 characters.
» source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
» destination_currency_code string true none The currency the funds will be deposited into. Using ISO 4217 format
» source_token string(uuid) true none Token that represents the funding source i.e. your bank account, user's wallet. 36 characters long
» destination_token string(uuid) true none Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback. If not provided, the last destination that was used for this user will be used. 36 characters long
» destination_amount number(float) true none The amount to be sent for payout in source currency. i.e USD. Must be provided if source_amount is empty
» source_amount number(float) true none The amount to be received by the payout in source currency. i.e USD. Must be provided if destination_amount is empty
» attr_set_token string(uuid) true none Token that represents set of attributes that associated with destination_token. For example, bank account, mobile account, wallet id, etc. If not provided, uses the last one used. 36 characters long
» exchange_rate number(float) true none The exchange rate to convert source_amount to destination_amount
» fee number(float) true none Fee to be charged for the transaction
» expiration string(YYYY-MMDDThh:mm:ss) true none The time and date at which the transaction will expire. The transaction has to be finalized before this time. Transactions are valid for 2 minutes from creation time. If expired, a new transaction has to be created.
» pickup_code string true none Code/pin that is required when collecting the money. Should be provided to the recipient to present to payout location.
» status string true none The status of the transaction
» payer_logo string(byte) false none base64 representation of the payer logo
» payer_name string false none Name of payer
» delivery_type string false none none
» country_code string false none Country code ISO_3166
» metadata string false none Optional JSON object with attributes that can later be searched to locate this payout. Do not include PII as this object is not encrypted.

Enumerated Values

Property Value
status PENDING
status PROCESSING
status COMPLETED
status CANCELLED
status SCHEDULED
status READY_FOR_PICKUP
status HOLD
status ERROR
delivery_type CASH_PICKUP
delivery_type BANK_DEPOSIT
delivery_type HOME_DELIVERY
delivery_type MOBILE_WALLET
delivery_type MASSPAY_CARD
delivery_type PAPER_CHECK
delivery_type BILL
delivery_type CRYPTOCURRENCY

commitPayoutTxn

Code samples

# You can also use wget
curl -X PUT https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.put('https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.put 'https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("PUT");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}";



      var result = await PutAsync(id, null, url);

    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /payout/{user_token}/{payout_token}

Commit payout transaction

Commits a previously initiated transaction.

Parameters

Name In Type Required Description
user_token path string true Token representing the user to pay out
payout_token path string true Token representing the trsanaction. Retrieved from /payout/{user_token}
Idempotency-Key header string false Unique key to prevent duplicate processing

Example responses

200 Response

{
  "payout_token": "payout_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "success",
  "pickup_code": "54238173",
  "errors": "Duplicate transfer"
}

Responses

Status Meaning Description Schema
200 OK successful operation PayoutTxnCommitResp
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input Exception

getPayoutStatus

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/payout/{user_token}/{payout_token}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /payout/{user_token}/{payout_token}

Get status of a payout by payout token

Retrieves information including status update for a payout token

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
force_status_update query boolean false Attempts to get an updated status update from the payout destination
user_token path string true Token representing the user to pay out
payout_token path string true Token representing the trsanaction. Retrieved from /payout/{user_token}

Example responses

200 Response

{
  "payout_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "client_transfer_id": "aEjn345",
  "source_currency_code": "USD",
  "destination_currency_code": "MXN",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "d2138fd0-00be-45a8-985f-4f5bde500962",
  "destination_amount": 100.5,
  "source_amount": 100.5,
  "attr_set_token": "b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
  "exchange_rate": 18.55,
  "fee": 2.99,
  "expiration": "2019-06-26T22:32:05",
  "pickup_code": "54238173",
  "status": "PENDING",
  "payer_logo": "...",
  "payer_name": "Elektra",
  "delivery_type": "CASH_PICKUP",
  "country_code": "MEX",
  "metadata": {
    "group_id": 541
  }
}

Responses

Status Meaning Description Schema
200 OK OK PayoutTxnResp
405 Method Not Allowed Method Not Allowed Exception

Load

The load resource describes a load of balance into a user's wallet.

loadUser

Code samples

# You can also use wget
curl -X POST https://{environment}.masspay.io/{VERSION}/load/{user_token} \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.post('https://{environment}.masspay.io/{VERSION}/load/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.post 'https://{environment}.masspay.io/{VERSION}/load/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/load/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/load/{user_token}";

      string json = @"{
  ""client_load_id"": ""aEjn345"",
  ""source_token"": ""ba4275f2-bae1-488d-9d6f-20af1cd83574"",
  ""amount"": 100.5,
  ""source_currency_code"": ""USD"",
  ""notes"": ""Commission payment for July"",
  ""notify_user"": true,
  ""time_to_process"": ""The date/time to process the load. In UTC. 2021-02-25T23:00:00Z"",
  ""metadata"": {
    ""group_id"": 541
  }
}";
      LoadTxn content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(LoadTxn content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(LoadTxn content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /load/{user_token}

Initiate a load transaction

Initiates a load of funds into a user token's wallet.

Body parameter

{
  "client_load_id": "aEjn345",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "amount": 100.5,
  "source_currency_code": "USD",
  "notes": "Commission payment for July",
  "notify_user": true,
  "time_to_process": "The date/time to process the load. In UTC. 2021-02-25T23:00:00Z",
  "metadata": {
    "group_id": 541
  }
}

Parameters

Name In Type Required Description
user_token path string true Token representing the user to load
Idempotency-Key header string false Unique key to prevent duplicate processing
body body LoadTxn true Load information

Example responses

200 Response

{
  "load_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "COMPLETED"
}

Responses

Status Meaning Description Schema
200 OK successful operation LoadTxnResp
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

getUserLoadsByToken

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/load/{user_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/load/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/load/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/load/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/load/{user_token}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /load/{user_token}

Get history of loads by user token

Gets a transaction history of all loads that were made to the provided user token, including scheduled loads.

Parameters

Name In Type Required Description
user_token path string true The user token that needs to be fetched.
Idempotency-Key header string false Unique key to prevent duplicate processing

Example responses

200 Response

[
  {
    "load_token": "ld_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "time_of_load": "2019-07-07T23:03:05",
    "client_load_id": "aEjn345",
    "source_token": "clnt_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "wallet_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "amount": 100.5,
    "source_currency_code": "USD",
    "notes": "Commission payment for July",
    "status": "COMPLETED",
    "metadata": {
      "group_id": 541
    }
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
400 Bad Request Invalid user token supplied None
404 Not Found User not found None

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [Loads] false none none
» load_token string true none Token representing the load token
» time_of_load string(YYYY-MM-DDThh:mm:ss) true none The timestamp the load was processed. If not processed yet, a future date will be returned. Using UTC timestamp.ISO 8601
» client_load_id string true none A client defined load identifier. This is the unique ID assigned to the load on your system. Max 50 characters.
» source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
» wallet_token string(uuid) true none Token that represents the wallet that received the funds. 36 characters long
» amount number true none The amount to credit the user's wallet in source currency
» source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
» notes string true none A description for the load. Will be visible to the user receiving the load
» status string true none Status of the load
» metadata object false none Optional JSON object with attributes that can later be searched to locate this load. Do not include PII as this object is not encrypted.

Enumerated Values

Property Value
status COMPLETED
status CANCELLED
status SCHEDULED

resendLoadNotification

Code samples

# You can also use wget
curl -X PUT https://{environment}.masspay.io/{VERSION}/load/{user_token}?load_token=497f6eca-6276-4993-bfeb-53cbbbba6f08 \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.put('https://{environment}.masspay.io/{VERSION}/load/{user_token}', params={
  'load_token': '497f6eca-6276-4993-bfeb-53cbbbba6f08'
}, headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.put 'https://{environment}.masspay.io/{VERSION}/load/{user_token}',
  params: {
  'load_token' => 'string(uuid)'
}, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/load/{user_token}?load_token=497f6eca-6276-4993-bfeb-53cbbbba6f08");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("PUT");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "https://{environment}.masspay.io/{VERSION}/load/{user_token}";



      var result = await PutAsync(id, null, url);

    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /load/{user_token}

Resend Load Notification

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
load_token query string(uuid) true Load token
user_token path string true Token representing the user to load/fetch loads for

Example responses

200 Response

{
  "success": true
}

Responses

Status Meaning Description Schema
200 OK OK Inline

Response Schema

Status Code 200

True if sent successfully. False if there was an issue

Name Type Required Restrictions Description
» success boolean true none True if notifcation was sent succesfully. False otherwise

cancelUserLoad

Code samples

# You can also use wget
curl -X DELETE https://{environment}.masspay.io/{VERSION}/load/{user_token}?load_token=497f6eca-6276-4993-bfeb-53cbbbba6f08 \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.delete('https://{environment}.masspay.io/{VERSION}/load/{user_token}', params={
  'load_token': '497f6eca-6276-4993-bfeb-53cbbbba6f08'
}, headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.delete 'https://{environment}.masspay.io/{VERSION}/load/{user_token}',
  params: {
  'load_token' => 'string(uuid)'
}, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/load/{user_token}?load_token=497f6eca-6276-4993-bfeb-53cbbbba6f08");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("DELETE");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "https://{environment}.masspay.io/{VERSION}/load/{user_token}";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /load/{user_token}

Reverse a user load

Reverse a load that was already processed. If the load is still in scheduled status, it will mark it as cancelled

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
load_token query string(uuid) true Load token
user_token path string true Token representing the user to load/fetch loads for

Responses

Status Meaning Description Schema
200 OK OK None

Wallet

The wallet resource describes of a user's wallet.

getWallet

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/wallet/{user_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/wallet/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/wallet/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/wallet/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/wallet/{user_token}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /wallet/{user_token}

Retrieve all available wallets for a user

Retrieves all available wallets for a provided user token.

Parameters

Name In Type Required Description
user_token path string true Token representing the user who owns the wallet
Idempotency-Key header string false Unique key to prevent duplicate processing

Example responses

200 Response

[
  {
    "user_token": "usr_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "token": "usr_wlt_8bb3693f-2f98-43dd-a990-615b6a21596d",
    "balance": 100.5,
    "currency_code": "USD",
    "type": "USER_FUNDS",
    "card_type": "VISA",
    "last_4": 1234,
    "active": true,
    "client_paying_fees": true
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input Exception

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [WalletTxnResp] false none none
» user_token string true none Token representing the user
» token string(uuid) true none Token representing the wallet
» balance number true none The wallet's current balance in USD
» currency_code string true none The currency wallet balance is stored in. Using ISO 4217 format. In most cases this value will be USD
» type string true none Type of wallet
» card_type string false none In case type of wallet is MASSPAY_CARD, card_type would be provided with the type of card it is
» last_4 string false none In case type of wallet is MASSPAY_CARD, last_4 would be provided with the last four digits of the card
» active boolean true none An indicator whether the wallet is active. If inactive, can still retrieve historical transactions history
» client_paying_fees boolean false none An indicator whether the fees for payouts using this wallet are paid by the client. If false, the user pays the fees

Enumerated Values

Property Value
type MASSPAY_CARD
type USER_FUNDS
card_type MASTERCARD
card_type VISA
card_type AMEX
card_type DISCOVER
card_type UNIONPAY

getWalletCardInfo

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /wallet/{user_token}/{wallet_token}/card

Get MassPay Card Information

Retrieves MassPay card information that is associated with the provided wallet token

Parameters

Name In Type Required Description
user_token path string true Token representing the user who owns the wallet
wallet_token path string(uuid) true Token representing the wallet

Example responses

200 Response

{
  "card_number": 4016483301928344,
  "cvv": "123",
  "expiration_date": "2020-09-11",
  "pin_number": "1234",
  "balance": 103,
  "type": "VISA",
  "status": "ACTIVE"
}

Responses

Status Meaning Description Schema
200 OK OK Inline
403 Forbidden Forbidden None
405 Method Not Allowed Method not allowed Exception

Response Schema

Status Code 200

MassPay Card Information

Name Type Required Restrictions Description
» card_number integer true none 16 Digits card number
» cvv string true none 3 Digits cvv code
» expiration_date string(date) true none Card expiration date
» pin_number string true none Card pin number (used in ATM machines)
» balance number(float) true none Available balance on the card
» type string true none Card type
» status string true none Status of the card

Enumerated Values

Property Value
type VISA
type MASTERCARD
type DISCOVER
type AMEX
type UNIONPAY
status ACTIVE
status INACTIVE
status CLOSED

getAutopayRules

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /wallet/{user_token}/{wallet_token}/autopay

Get all autopay rules

Obtain list of all autopay rules currently applied to this wallet

Parameters

Name In Type Required Description
user_token path string true Token representing the user who owns the wallet
wallet_token path string true Token representing the wallet

Example responses

200 Response

[
  {
    "token": "autopay_3684cc43-fe3b-4994-8ca1-7dc0db94430f",
    "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
    "percentage": 50
  }
]

Responses

Status Meaning Description Schema
200 OK OK Inline
403 Forbidden Forbidden None
405 Method Not Allowed Method not allowed Exception

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [AutopayResp] false none none
» AutopayResp AutopayResp false none none
»» token string true none Autopay token
»» destination_token string true none The destination_token to autopay (send payout to)
»» percentage number(float) true none The percent of incoming load that should be autopaid to the destination_token

createAutopayRule

Code samples

# You can also use wget
curl -X POST https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.post('https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.post 'https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay";

      string json = @"{
  ""destination_token"": ""dest_d2138fd0-00be-45a8-985f-4f5bde500962"",
  ""percentage"": 50
}";
      AutopayRule content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(AutopayRule content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(AutopayRule content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /wallet/{user_token}/{wallet_token}/autopay

Add autopay rule

Create an autopay rule that will automatically initiate a payout whenever the wallet_token is loaded

Body parameter

{
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "percentage": 50
}

Parameters

Name In Type Required Description
body body AutopayRule false Autopay rule configuration
user_token path string true Token representing the user who owns the wallet
wallet_token path string true Token representing the wallet

Example responses

200 Response

{
  "token": "autopay_3684cc43-fe3b-4994-8ca1-7dc0db94430f",
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "percentage": 50
}

Responses

Status Meaning Description Schema
200 OK OK AutopayResp
403 Forbidden Forbidden None
405 Method Not Allowed Method not allowed Exception

deleteAutopayRule

Code samples

# You can also use wget
curl -X DELETE https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay?token=autopay_3684cc43-fe3b-4994-8ca1-7dc0db94430f \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.delete('https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay', params={
  'token': 'autopay_3684cc43-fe3b-4994-8ca1-7dc0db94430f'
}, headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.delete 'https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay',
  params: {
  'token' => 'string'
}, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay?token=autopay_3684cc43-fe3b-4994-8ca1-7dc0db94430f");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("DELETE");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/autopay";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /wallet/{user_token}/{wallet_token}/autopay

Delete autopay rule

Deletes an autopay rule

Parameters

Name In Type Required Description
token query string true Autopay token to delete
user_token path string true Token representing the user who owns the wallet
wallet_token path string true Token representing the wallet

Example responses

405 Response

{
  "Exception": "string",
  "Errors": [
    "string"
  ]
}

Responses

Status Meaning Description Schema
200 OK OK None
403 Forbidden Forbidden None
405 Method Not Allowed Method not allowed Exception

Attribute

The attribute resource describes attributes of a user. For instance their bank account number, ID number, DOB, etc.

storeAttrs

Code samples

# You can also use wget
curl -X POST https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency} \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.post('https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.post 'https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}";

      string json = @"{
  ""values"": [
    {
      ""token"": ""e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba"",
      ""value"": ""432532532""
    }
  ],
  ""attr_set_token"": ""attr_set_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba""
}";
      AttrTxn content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(AttrTxn content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(AttrTxn content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /attribute/{user_token}/{destination_token}/{currency}

Store user attributes

If existing attributes are already stored, this call will override its values.

Body parameter

{
  "values": [
    {
      "token": "e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
      "value": "432532532"
    }
  ],
  "attr_set_token": "attr_set_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba"
}

Parameters

Name In Type Required Description
user_token path string true Token representing the user to store attributes for
destination_token path string true Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback.
Idempotency-Key header string false Unique key to prevent duplicate processing
body body AttrTxn true Attr parameters to store
currency path string true The destination currency sending funds to. Using ISO 4217 format.

Example responses

405 Response

{
  "Exception": "string",
  "Errors": [
    "string"
  ]
}

Responses

Status Meaning Description Schema
200 OK successful operation None
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input Exception

getAttrs

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/attribute/{user_token}/{destination_token}/{currency}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /attribute/{user_token}/{destination_token}/{currency}

Get user attributes for destination_token

Get all the required attributes for the provided user for a prticular destination token. If any of the attributes already have a stored value, it will be returned as well.

Parameters

Name In Type Required Description
user_token path string true Token representing the user to retrieve attributes for
destination_token path string true Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback.
Idempotency-Key header string false Unique key to prevent duplicate processing
currency path string true The destination currency sending funds to. Using ISO 4217 format.

Example responses

200 Response

[
  {
    "token": "attr_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
    "attr_set_token": "attr_set_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
    "label": "Checking Account Number",
    "validation": "[0-9]{50}",
    "is_optional": true,
    "value": "432532532",
    "expected_value": "Date format MM/DD/YYYY",
    "type": "BankAccountNumber"
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input Exception

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [AttrsRequirement] false none none
» token string true none The token that represents the attribute.
» attr_set_token string false none The token that represents the stored attributes for this payer. You would use this token in attr_set_token of initiatePayout if you have to specify an account number when paying a transaction out.
» label string false none The label that describes that required attribute
» validation string false none RegEx that validates that input
» is_optional boolean false none Flag to indicate whether this field is required or not
» value string true none The existing value that is stored. 'Null' if no existing value is stored.
» expected_value string false none Written explanation of the value that the regex validation requires
» type string false none The type of attribute

Enumerated Values

Property Value
type CardNumber
type BankAccountType
type BankAccountNumber
type BankAccountBranchNumber
type BankName
type PhoneNumber
type Gender
type IdentificationNumber
type BillReferenceNumber
type BankRoutingNumber
type BankAccountName
type MaidenName
type SocialSecurity
type EmploymentName
type EmploymentAddress
type EmploymentPhone
type EmploymentOccupation
type EmploymentSupervisor
type RemittanceReason
type Relationship
type SecondLastName
type SWIFT
type BirthCountry
type SourceOfFunds
type DateOfBirth
type CardExpiration
type CardZip
type IdentificationType
type BankCity
type BankState

Account

The account resource describes your account.

getAccountBalance

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/account/balance \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/account/balance', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/account/balance',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/account/balance");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/account/balance";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /account/balance

Get current available balance

Retrieves the current available balances.

Example responses

200 Response

[
  {
    "token": "8bb3693f-2f98-43dd-a990-615b6a21596d",
    "balance": 100.5,
    "currency_code": "USD"
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [AvailableBalanceTxnResp] false none none
» token string true none Token representing your funding account. You should use this as source_token when paying out transactions.
» balance number true none Your account's current available balance in USD
» currency_code string true none The currency the balance is stored in. Using ISO 4217 format. In most cases this value will be USD

get-account-statement

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/account/statement?start_date=2021-01-01&ending_date=2021-02-01 \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/account/statement', params={
  'start_date': '2021-01-01',  'ending_date': '2021-02-01'
}, headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/account/statement',
  params: {
  'start_date' => 'string(date)',
'ending_date' => 'string(date)'
}, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/account/statement?start_date=2021-01-01&ending_date=2021-02-01");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/account/statement";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /account/statement

Get certified account statement

Retreived a certified PDF ledger statement for a provided timeframe

Parameters

Name In Type Required Description
start_date query string(date) true Starting date of the statement
ending_date query string(date) true Ending date of the statement (not more than 31 days than start_date)

Example responses

200 Response

"Base64 encoded of content of the pdf"

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

Response Schema

Status Code 200

Base64 encoded byte representing the content of the file

Name Type Required Restrictions Description
» content string true read-only Base64 encoded byte representing the content of the file

Catalog

The catalog resource describes the available services and countries.

getCountryList

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/country/list \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/country/list', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/country/list',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/country/list");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/country/list";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /country/list

Gets a list of countries where services offered.

Get a list of all currently available countries of service.

Example responses

200 Response

[
  {
    "code": "MX",
    "name": "Mexico",
    "three_letter_code": "MEX"
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [Country] false none none
» code string true none Country code ISO_3166
» name string true none Name of country
» three_letter_code string true none The user's country code. ISO_3166-1_alpha-3 code

getCountryServices

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/country/{country_code} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/country/{country_code}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/country/{country_code}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/country/{country_code}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/country/{country_code}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /country/{country_code}

Gets a list of Companies and their service offerings for the given country code.

Gets a list of all the available services and pricing for each respected company for a provided country code.

Parameters

Name In Type Required Description
country_code path string true Country code searching services for. 3 letters ISO_3166 code"
amount query string false Returns the results fee based on the given amount, defaults to $200
limit query number(float) false Limit amount for transaction amount + fee. If fee + amount are higher than the limit, the output will automatically adjust to maximize the possible amount sent
Idempotency-Key header string false Unique key to prevent duplicate processing
wallet_token query string(uuid) false Token representing the wallet used. If provided, the results would be custom-tailored to this user. Not necessary if user_token is provided
include_payer_logos query boolean false Whether to include the payers logo in base64 format.
user_token query string false Token representing the user for which we fetch the catalog. If provided, the results would be custom-tailored to this user. Not necessary if wallet_token is provided

Example responses

200 Response

{
  "companies": [
    {
      "company_logo": "...",
      "services": [
        {
          "country_code": "MEX",
          "delivery_type": "CASH_PICKUP",
          "payers": [
            {
              "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
              "payer_logo": "...",
              "payer_name": "Elektra",
              "exchange_rate": [
                {
                  "currency_symbol": "MXN",
                  "exchange_rate": 18.37
                }
              ],
              "fee": 8,
              "max_limit": 10000,
              "min_limit": 0,
              "source_amount": 104.3,
              "number_of_locations": 13007,
              "estimated_availability": "2020-07-21T17:32:28Z",
              "additional_description": "Requires drivers license to pickup funds"
            }
          ]
        }
      ],
      "rating": 4.5,
      "description": "Pontual is a top leading provider with over 10 years of industry experience",
      "company_name": "Pontual"
    }
  ]
}

Responses

Status Meaning Description Schema
200 OK successful operation CompaniesResp
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

getCheapestCountryServices

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/country/{country_code}/cheapest \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/country/{country_code}/cheapest', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/country/{country_code}/cheapest',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/country/{country_code}/cheapest");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/country/{country_code}/cheapest";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /country/{country_code}/cheapest

Gets a list of Companies and their cheapest service offerings for the given country code.

Gets a list of all the available services and pricing for each respected company for a provided country code. If two providers offer similar service, only show the cheapest option

Parameters

Name In Type Required Description
country_code path string true Country code searching services for. 3 letters ISO_3166 code"
amount query string false Returns the results fee based on the given amount, defaults to $200
limit query number(float) false Limit amount for transaction amount + fee. If fee + amount are higher than the limit, the output will automatically adjust to maximize the possible amount sent
Idempotency-Key header string false Unique key to prevent duplicate processing
wallet_token query string(uuid) false Token representing the wallet used. If provided, the results would be custom-tailored to this user.
include_payer_logos query boolean false Whether to include the payers logo in base64 format.
user_token query string false Token representing the user for which we fetch the catalog. If provided, the results would be custom-tailored to this user. Not necessary if wallet_token is provided

Example responses

200 Response

{
  "companies": [
    {
      "company_logo": "...",
      "services": [
        {
          "country_code": "MEX",
          "delivery_type": "CASH_PICKUP",
          "payers": [
            {
              "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
              "payer_logo": "...",
              "payer_name": "Elektra",
              "exchange_rate": [
                {
                  "currency_symbol": "MXN",
                  "exchange_rate": 18.37
                }
              ],
              "fee": 8,
              "max_limit": 10000,
              "min_limit": 0,
              "source_amount": 104.3,
              "number_of_locations": 13007,
              "estimated_availability": "2020-07-21T17:32:28Z",
              "additional_description": "Requires drivers license to pickup funds"
            }
          ]
        }
      ],
      "rating": 4.5,
      "description": "Pontual is a top leading provider with over 10 years of industry experience",
      "company_name": "Pontual"
    }
  ]
}

Responses

Status Meaning Description Schema
200 OK successful operation CompaniesResp
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

getUserAgreement

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/user-agreements?id=2 \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/user-agreements', params={
  'id': '2'
}, headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/user-agreements',
  params: {
  'id' => 'integer'
}, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user-agreements?id=2");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/user-agreements";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /user-agreements

Get User Agreement

Get available user agreements for payout services

Parameters

Name In Type Required Description
id query integer true Id representing user agreement (retrieved from OPTIONS call)

Example responses

200 Response

{
  "name": "MassPay Card Program - USD",
  "content": "string",
  "last_modified": "2020-07-21T17:32:28Z",
  "id": 2,
  "mime_type": "application/pdf"
}

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

Response Schema

Status Code 200

User Agreement

Name Type Required Restrictions Description
» name string true none Name of user agreement
» content string(byte) true read-only Base64 encoded byte representing the content of the file
» last_modified string(date-time) true none Time when the agreement was last updated
» id integer true none Id representing the user agreement
» mime_type string false none Mime type of the user agreement (i.e application/pdf)

getUserAgreementsNames

Code samples

# You can also use wget
curl -X OPTIONS https://{environment}.masspay.io/{VERSION}/user-agreements \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.options('https://{environment}.masspay.io/{VERSION}/user-agreements', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.options 'https://{environment}.masspay.io/{VERSION}/user-agreements',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/user-agreements");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("OPTIONS");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }





    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

OPTIONS /user-agreements

Get Available User Agreements

Get available user agreements for payout services (without content)

Example responses

200 Response

[
  {
    "name": "MassPay Card Program - USD",
    "last_modified": "2020-07-21T17:32:28Z",
    "id": 2,
    "mime_type": "application/pdf"
  }
]

Responses

Status Meaning Description Schema
200 OK successful operation Inline
403 Forbidden You do not have necessary permissions for the resource None
405 Method Not Allowed Invalid input None

Response Schema

Status Code 200

List of user agreements

Name Type Required Restrictions Description
» name string true none Name of user agreement
» last_modified string(date-time) true none Time when the agreement was last updated
» id integer true none Id representing the user agreement (to be used to retrieve it)
» mime_type string true none Mime type of the user agreement (i.e application/pdf)

Spend Back

The spend back resource describes a spend bank from the user's wallet

getUserSpendbacksByToken

Code samples

# You can also use wget
curl -X GET https://{environment}.masspay.io/{VERSION}/spendback/{user_token} \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.get('https://{environment}.masspay.io/{VERSION}/spendback/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.get 'https://{environment}.masspay.io/{VERSION}/spendback/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/spendback/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/spendback/{user_token}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /spendback/{user_token}

Get history of spend backs by user token

Gets a list of all historical spendbacks for a provided user token.

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
user_token path string true Token representing the user to fetch/initiate spend back

Example responses

200 Response

[
  {
    "spendback_token": "spnd_bk_4275f2-bae1-488d-9d6f-20af1cd83574",
    "time_of_spendback": "2019-07-07T23:03:05",
    "client_spendback_id": "aEjn345",
    "source_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "wallet_token": "clnt_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
    "amount": 100.5,
    "source_currency_code": "USD",
    "notes": "Commission payment for July",
    "metadata": {
      "group_id": 541
    }
  }
]

Responses

Status Meaning Description Schema
200 OK OK Inline

Response Schema

Status Code 200

Name Type Required Restrictions Description
anonymous [SpendBacks] false none none
» spendback_token string true none Token representing the load token
» time_of_spendback string(YYYY-MM-DDThh:mm:ss) true none The timestamp the spend back was created in the system. Using UTC timestamp.ISO 8601
» client_spendback_id string true none A client defined spend back identifier. This is the unique ID assigned to the spend back on your system. Max 50 characters.
» source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
» wallet_token string(uuid) true none Token that represents the wallet that received the funds. 36 characters long
» amount number true none The amount to credit the user's wallet in source currency
» source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
» notes string true none A description for the load. Will be visible to the user receiving the load
» metadata string false none Optional JSON object with attributes that can later be searched to locate this spendback. Do not include PII as this object is not encrypted.

initiateSpendback

Code samples

# You can also use wget
curl -X POST https://{environment}.masspay.io/{VERSION}/spendback/{user_token} \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json' \
  -H 'Idempotency-Key: string' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'application/json',
  'Idempotency-Key': 'string',
  'Authorization': 'Bearer {access-token}'
}

r = requests.post('https://{environment}.masspay.io/{VERSION}/spendback/{user_token}', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Content-Type' => 'application/json',
  'Accept' => 'application/json',
  'Idempotency-Key' => 'string',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.post 'https://{environment}.masspay.io/{VERSION}/spendback/{user_token}',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/spendback/{user_token}");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "https://{environment}.masspay.io/{VERSION}/spendback/{user_token}";

      string json = @"{
  ""client_spendback_id"": ""aEjn345"",
  ""source_token"": ""usr_wlt_d2138fd0-00be-45a8-985f-4f5bff500962"",
  ""source_currency_code"": ""USD"",
  ""amount"": 100.5,
  ""notes"": ""Purchase of Candles. Order #14930"",
  ""metadata"": {
    ""group_id"": 541
  }
}";
      SpendBackTxn content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(SpendBackTxn content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(SpendBackTxn content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /spendback/{user_token}

Initiate a spend back transaction

Initiates a spend back transaction to a provided user token.

Body parameter

{
  "client_spendback_id": "aEjn345",
  "source_token": "usr_wlt_d2138fd0-00be-45a8-985f-4f5bff500962",
  "source_currency_code": "USD",
  "amount": 100.5,
  "notes": "Purchase of Candles. Order #14930",
  "metadata": {
    "group_id": 541
  }
}

Parameters

Name In Type Required Description
Idempotency-Key header string false Unique key to prevent duplicate processing
body body SpendBackTxn false Spend back information
user_token path string true Token representing the user to fetch/initiate spend back

Example responses

200 Response

{
  "spendback_token": "spnd_bk_d2138fd0-00be-45a8-985f-4f5bff5e3962",
  "client_spendback_id": "aEjn345",
  "status": "success"
}

Responses

Status Meaning Description Schema
200 OK OK SpendBackTxnResp

Card

The card resource describe your MassPay cards

updateWalletCardInfo

Code samples

# You can also use wget
curl -X PUT https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card \
  -H 'Accept: application/json' \
  -H 'Authorization: Bearer {access-token}'

import requests
headers = {
  'Accept': 'application/json',
  'Authorization': 'Bearer {access-token}'
}

r = requests.put('https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card', headers = headers)

print(r.json())

require 'rest-client'
require 'json'

headers = {
  'Accept' => 'application/json',
  'Authorization' => 'Bearer {access-token}'
}

result = RestClient.put 'https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card',
  params: {
  }, headers: headers

p JSON.parse(result)

URL obj = new URL("https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("PUT");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "https://{environment}.masspay.io/{VERSION}/wallet/{user_token}/{wallet_token}/card";



      var result = await PutAsync(id, null, url);

    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /wallet/{user_token}/{wallet_token}/card

Update MassPay Card Information

Update card pin number or/and status

Parameters

Name In Type Required Description
pin query string false New 4 digit pin number for the card (To be used in ATM machines)
status query string false New status for the card
user_token path string true Token representing the user who owns the wallet
wallet_token path string(uuid) true Token representing the wallet

Enumerated Values

Parameter Value
status SUSPEND
status UNSUSPEND
status CLOSE

Example responses

405 Response

{
  "Exception": "string",
  "Errors": [
    "string"
  ]
}

Responses

Status Meaning Description Schema
200 OK OK None
403 Forbidden Forbidden None
405 Method Not Allowed Method Not Allowed Exception

Schemas

User

{
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "date_of_birth": "1975-03-24",
  "metadata": {"group_id":541},
  "notify_user": false
}

Properties

Name Type Required Restrictions Description
internal_user_id string true none A client-defined identifier for the user. This is the unique ID assigned to the user on your system. Max 75 characters. Allows letters, numbers, and + , - . / _ ~
address1 string false none The user's street address.
address2 string false none The user's street address, line 2.
city string false none The user's city.
state_province string false none The user's state/province.
postal_code string false none The user's postal code.
country string false none The user's country code. ISO_3166 code
first_name string true none The user's first name. (If Business account, the first name of the representative)
middle_name string false none The user's middle name. (If Business account, the middle name of the representative)
last_name string true none The user's last name. (If Business account, the last name of the representative)
email string true none The user's e-mail address. Must be unique. Cannot have two users with the same e-mail address.
language string false none The user's preferred language of communication. If not provided, defaults to English (en)
mobile_number string false none (Optional) Mobile number of user. Allows for SMS notifications upon availability of funds
business_name string false none Company legal name (Only if Business account)
date_of_birth string(date) false none Date of birth. (optional). Minimum 18 years old
metadata object false none Optional JSON object with attributes that can later be searched to locate this user. Do not include PII as this object is not encrypted.
notify_user boolean false none Should we notify the user via email that their user has been created in the system? They will receive instructions to establish such account.

Loads

{
  "load_token": "ld_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "time_of_load": "2019-07-07T23:03:05",
  "client_load_id": "aEjn345",
  "source_token": "clnt_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "wallet_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "amount": 100.5,
  "source_currency_code": "USD",
  "notes": "Commission payment for July",
  "status": "COMPLETED",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
load_token string true none Token representing the load token
time_of_load string(YYYY-MM-DDThh:mm:ss) true none The timestamp the load was processed. If not processed yet, a future date will be returned. Using UTC timestamp.ISO 8601
client_load_id string true none A client defined load identifier. This is the unique ID assigned to the load on your system. Max 50 characters.
source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
wallet_token string(uuid) true none Token that represents the wallet that received the funds. 36 characters long
amount number true none The amount to credit the user's wallet in source currency
source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
notes string true none A description for the load. Will be visible to the user receiving the load
status string true none Status of the load
metadata object false none Optional JSON object with attributes that can later be searched to locate this load. Do not include PII as this object is not encrypted.

Enumerated Values

Property Value
status COMPLETED
status CANCELLED
status SCHEDULED

StoredUser

{
  "user_token": "usr_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "ACTIVE",
  "created_on": "2019-07-07T23:03:05",
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "timezone": "America/Los_Angeles",
  "date_of_birth": "1975-03-24",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
user_token string(uuid) true none Token representing the user that was just created
status string true none The status of the user
created_on string(YYYY-MM-DDThh:mm:ss) true none The timestamp the user was created in the system. Using UTC timestamp.ISO 8601
internal_user_id string true none A client-defined identifier for the user. This is the unique ID assigned to the user on your system. Max 75 characters. Allows letters, numbers, and + , - . / _ ~
address1 string false none The user's street address.
address2 string false none The user's street address, line 2.
city string false none The user's city.
state_province string false none The user's state/province.
postal_code string false none The user's postal code.
country string false none The user's country code. ISO_3166-1_alpha-3 code
first_name string true none The user's first name. (If Business account, the first name of the representative)
middle_name string false none The user's middle name. (If Business account, the middle name of the representative)
last_name string true none The user's last name. (If Business account, the last name of the representative)
email string true none The user's e-mail address. Must be unique. Cannot have two users with the same e-mail address.
language string false none The user's preferred language of communication. If not provided, defaults to English (en)
mobile_number string false none (Optional) Mobile number of user. Allows for SMS notifications upon availability of funds
business_name string false none Company legal name (Only if Business account)
timezone string true none User's computed timezone
date_of_birth string(date) false none Date of birth. (optional). Minimum 18 years old
metadata string false none Optional JSON object with attributes that can later be searched to locate this user. Do not include PII as this object is not encrypted.

Enumerated Values

Property Value
status ACTIVE
status LOCKED
status DEACTIVE

UpdateUser

{
  "status": "ACTIVE",
  "created_on": "2019-07-07T23:03:05",
  "internal_user_id": "4324-rOzk",
  "address1": "2000 main st",
  "address2": "apt D",
  "city": "Santa Monica",
  "state_province": "CA",
  "postal_code": "90405",
  "country": "USA",
  "first_name": "John",
  "middle_name": "",
  "last_name": "Doe",
  "email": "jdoe@gmail.com",
  "language": "en",
  "mobile_number": "16502000226",
  "business_name": "ABC Company",
  "date_of_birth": "1975-03-24",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
status string true none The status of the user, if set to ACTIVE when current status is DEACTIVE, reactivation fee will incur
created_on string(YYYY-MM-DDThh:mm:ss) false none The timestamp the user was created in the system. Using UTC timestamp.ISO 8601
internal_user_id string true none A client-defined identifier for the user. This is the unique ID assigned to the user on your system. Max 75 characters. Allows letters, numbers, and + , - . / _ ~
address1 string true none The user's street address.
address2 string false none The user's street address, line 2.
city string true none The user's city.
state_province string true none The user's state/province.
postal_code string true none The user's postal code.
country string true none The user's country code. ISO_3166-1_alpha-3 code
first_name string true none The user's first name.
middle_name string false none The user's middle name.
last_name string true none The user's last name.
email string true none The user's e-mail address. Must be unique. Cannot have two users with the same e-mail address.
language string false none The user's preferred language of communication. If not provided, defaults to English (en)
mobile_number string false none (Optional) Mobile number of user. Allows for SMS notifications upon availability of funds
business_name string false none Company legal name (Only if Business account)
date_of_birth string(date) false none Date of birth. (optional). Minimum 18 years old
metadata object false none Optional JSON object with attributes that can later be searched to locate this user. Do not include PII as this object is not encrypted.

Enumerated Values

Property Value
status ACTIVE
status DEACTIVE

WalletTxnResp

{
  "user_token": "usr_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "token": "usr_wlt_8bb3693f-2f98-43dd-a990-615b6a21596d",
  "balance": 100.5,
  "currency_code": "USD",
  "type": "USER_FUNDS",
  "card_type": "VISA",
  "last_4": 1234,
  "active": true,
  "client_paying_fees": true
}

Properties

Name Type Required Restrictions Description
user_token string true none Token representing the user
token string(uuid) true none Token representing the wallet
balance number true none The wallet's current balance in USD
currency_code string true none The currency wallet balance is stored in. Using ISO 4217 format. In most cases this value will be USD
type string true none Type of wallet
card_type string false none In case type of wallet is MASSPAY_CARD, card_type would be provided with the type of card it is
last_4 string false none In case type of wallet is MASSPAY_CARD, last_4 would be provided with the last four digits of the card
active boolean true none An indicator whether the wallet is active. If inactive, can still retrieve historical transactions history
client_paying_fees boolean false none An indicator whether the fees for payouts using this wallet are paid by the client. If false, the user pays the fees

Enumerated Values

Property Value
type MASSPAY_CARD
type USER_FUNDS
card_type MASTERCARD
card_type VISA
card_type AMEX
card_type DISCOVER
card_type UNIONPAY

AvailableBalanceTxnResp

{
  "token": "8bb3693f-2f98-43dd-a990-615b6a21596d",
  "balance": 100.5,
  "currency_code": "USD"
}

Properties

Name Type Required Restrictions Description
token string true none Token representing your funding account. You should use this as source_token when paying out transactions.
balance number true none Your account's current available balance in USD
currency_code string true none The currency the balance is stored in. Using ISO 4217 format. In most cases this value will be USD

AttrTxn

{
  "values": [
    {
      "token": "e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
      "value": "432532532"
    }
  ],
  "attr_set_token": "attr_set_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba"
}

Properties

Name Type Required Restrictions Description
values [AttrValue] true none none
attr_set_token string false none The token that represents a set of attributes for a specific payer. Optional, specify the value if you're trying to update a value of a specific attributes set.

AttrValue

{
  "token": "e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
  "value": "432532532"
}

Properties

Name Type Required Restrictions Description
token string true none The token that represents the attribute that needs to be updated.
value string true none The value that needs to be stored for the associated token

AttrsRequirement

{
  "token": "attr_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
  "attr_set_token": "attr_set_e2ca24e9-c546-4c64-90d2-cb8e70e7c9ba",
  "label": "Checking Account Number",
  "validation": "[0-9]{50}",
  "is_optional": true,
  "value": "432532532",
  "expected_value": "Date format MM/DD/YYYY",
  "type": "BankAccountNumber"
}

Properties

Name Type Required Restrictions Description
token string true none The token that represents the attribute.
attr_set_token string false none The token that represents the stored attributes for this payer. You would use this token in attr_set_token of initiatePayout if you have to specify an account number when paying a transaction out.
label string false none The label that describes that required attribute
validation string false none RegEx that validates that input
is_optional boolean false none Flag to indicate whether this field is required or not
value string true none The existing value that is stored. 'Null' if no existing value is stored.
expected_value string false none Written explanation of the value that the regex validation requires
type string false none The type of attribute

Enumerated Values

Property Value
type CardNumber
type BankAccountType
type BankAccountNumber
type BankAccountBranchNumber
type BankName
type PhoneNumber
type Gender
type IdentificationNumber
type BillReferenceNumber
type BankRoutingNumber
type BankAccountName
type MaidenName
type SocialSecurity
type EmploymentName
type EmploymentAddress
type EmploymentPhone
type EmploymentOccupation
type EmploymentSupervisor
type RemittanceReason
type Relationship
type SecondLastName
type SWIFT
type BirthCountry
type SourceOfFunds
type DateOfBirth
type CardExpiration
type CardZip
type IdentificationType
type BankCity
type BankState

LoadTxn

{
  "client_load_id": "aEjn345",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "amount": 100.5,
  "source_currency_code": "USD",
  "notes": "Commission payment for July",
  "notify_user": true,
  "time_to_process": "The date/time to process the load. In UTC. 2021-02-25T23:00:00Z",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
client_load_id string true none A client defined load identifier. This is the unique ID assigned to the load on your system. Max 50 characters.
source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
amount number true none The amount to credit the user's wallet in source currency
source_currency_code string false none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
notes string false none A description for the load. Will be visible to the user receiving the load
notify_user boolean false none Should we notify the user via email that they've received a load? If the user has no existing account, they will receive instructions to establish such account.
time_to_process string(YYYY-MM-DDThh:mm:ss) false none Future date/time to process the load on. If none is provided, it is processed right away. Time to be provided in UTC ISO 8601
metadata object false none Optional JSON object with attributes that can later be searched to locate this load. Do not include PII as this object is not encrypted.

LoadTxnResp

{
  "load_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "COMPLETED"
}

Properties

Name Type Required Restrictions Description
load_token string(uuid) true none Token that represents the load that was just created.
status string true none Status that indicates whether the transaction was successfully processed. If COMPLETED, the load was successfully processed. CANCELLED indicates a generic error. and SCHEDULED means the load was successfully scheduled

Enumerated Values

Property Value
status COMPLETED
status CANCELLED
status SCHEDULED

PayoutTxn

{
  "client_transfer_id": "aEjn345",
  "source_currency_code": "USD",
  "destination_currency_code": "MXN",
  "source_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "destination_amount": 100.5,
  "source_amount": 100.5,
  "attr_set_token": "attr_set_b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
client_transfer_id string false none A client defined transfer identifier. This is the unique ID assigned to the transfer on your system. Max 50 characters.
source_currency_code string false none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
destination_currency_code string true none The currency the funds will be deposited into. Using ISO 4217 format
source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
destination_token string(uuid) true none Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback. If not provided, the last destination that was used for this user will be used. 36 characters long
destination_amount number(float) false none The amount to be sent for payout in source currency. i.e USD. Must be provided if source_amount is empty
source_amount number(float) false none The amount to be received by the payout in source currency. i.e USD. Must be provided if destination_amount is empty
attr_set_token string(uuid) false none Token that represents set of attributes that associated with destination_token. For example, bank account, mobile account, wallet id, etc. If not provided, uses the last one used. 36 characters long
metadata string false none Optional JSON object with attributes that can later be searched to locate this payout. Do not include PII as this object is not encrypted.

PayoutTxnResp

{
  "payout_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "client_transfer_id": "aEjn345",
  "source_currency_code": "USD",
  "destination_currency_code": "MXN",
  "source_token": "ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "d2138fd0-00be-45a8-985f-4f5bde500962",
  "destination_amount": 100.5,
  "source_amount": 100.5,
  "attr_set_token": "b1a867c1-6e36-4525-b6d5-a20bac80e3b0",
  "exchange_rate": 18.55,
  "fee": 2.99,
  "expiration": "2019-06-26T22:32:05",
  "pickup_code": "54238173",
  "status": "PENDING",
  "payer_logo": "...",
  "payer_name": "Elektra",
  "delivery_type": "CASH_PICKUP",
  "country_code": "MEX",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
payout_token string(uuid) true none Token that represents the transaction that was just created. Need to be used to commit the transaction in /payout/{user_token}/{payout_token}. Value would be NSF if there are not enough funds in the source_token. Value would be DUPLICATE if there is a duplicate client_transfer_id.
client_transfer_id string true none A client defined transfer identifier. This is the unique ID assigned to the transfer on your system. Max 50 characters.
source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
destination_currency_code string true none The currency the funds will be deposited into. Using ISO 4217 format
source_token string(uuid) true none Token that represents the funding source i.e. your bank account, user's wallet. 36 characters long
destination_token string(uuid) true none Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback. If not provided, the last destination that was used for this user will be used. 36 characters long
destination_amount number(float) true none The amount to be sent for payout in source currency. i.e USD. Must be provided if source_amount is empty
source_amount number(float) true none The amount to be received by the payout in source currency. i.e USD. Must be provided if destination_amount is empty
attr_set_token string(uuid) true none Token that represents set of attributes that associated with destination_token. For example, bank account, mobile account, wallet id, etc. If not provided, uses the last one used. 36 characters long
exchange_rate number(float) true none The exchange rate to convert source_amount to destination_amount
fee number(float) true none Fee to be charged for the transaction
expiration string(YYYY-MMDDThh:mm:ss) true none The time and date at which the transaction will expire. The transaction has to be finalized before this time. Transactions are valid for 2 minutes from creation time. If expired, a new transaction has to be created.
pickup_code string true none Code/pin that is required when collecting the money. Should be provided to the recipient to present to payout location.
status string true none The status of the transaction
payer_logo string(byte) false none base64 representation of the payer logo
payer_name string false none Name of payer
delivery_type string false none none
country_code string false none Country code ISO_3166
metadata string false none Optional JSON object with attributes that can later be searched to locate this payout. Do not include PII as this object is not encrypted.

Enumerated Values

Property Value
status PENDING
status PROCESSING
status COMPLETED
status CANCELLED
status SCHEDULED
status READY_FOR_PICKUP
status HOLD
status ERROR
delivery_type CASH_PICKUP
delivery_type BANK_DEPOSIT
delivery_type HOME_DELIVERY
delivery_type MOBILE_WALLET
delivery_type MASSPAY_CARD
delivery_type PAPER_CHECK
delivery_type BILL
delivery_type CRYPTOCURRENCY

PayoutTxnCommitResp

{
  "payout_token": "payout_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "status": "success",
  "pickup_code": "54238173",
  "errors": "Duplicate transfer"
}

Properties

Name Type Required Restrictions Description
payout_token string(uuid) true none Token that represents the transaction that was just created.
status string true none Status that indicates whether the transaction was successfully processed. If success, everything was processed correctly. failure indicates a generic error. addtl_attr_req indicates that in order to process this transaction, additional attributes are required to be updated for this customer. ex_rate_expired indicates that the transaction exchange rate has expired and a new transaction has to be created.
pickup_code string false none Code/pin that is required when collecting the money. Should be provided to the recipient to present to payout location.
errors string false none Description of errors preventing transfer from being injected.

Enumerated Values

Property Value
status success
status failure
status addtl_attr_req
status ex_rate_expired
status nsf

Country

{
  "code": "MX",
  "name": "Mexico",
  "three_letter_code": "MEX"
}

Properties

Name Type Required Restrictions Description
code string true none Country code ISO_3166
name string true none Name of country
three_letter_code string true none The user's country code. ISO_3166-1_alpha-3 code

CompaniesResp

{
  "companies": [
    {
      "company_logo": "...",
      "services": [
        {
          "country_code": "MEX",
          "delivery_type": "CASH_PICKUP",
          "payers": [
            {
              "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
              "payer_logo": "...",
              "payer_name": "Elektra",
              "exchange_rate": [
                {
                  "currency_symbol": "MXN",
                  "exchange_rate": 18.37
                }
              ],
              "fee": 8,
              "max_limit": 10000,
              "min_limit": 0,
              "source_amount": 104.3,
              "number_of_locations": 13007,
              "estimated_availability": "2020-07-21T17:32:28Z",
              "additional_description": "Requires drivers license to pickup funds"
            }
          ]
        }
      ],
      "rating": 4.5,
      "description": "Pontual is a top leading provider with over 10 years of industry experience",
      "company_name": "Pontual"
    }
  ]
}

Properties

Name Type Required Restrictions Description
companies [Company] true none none

Company

{
  "company_logo": "...",
  "services": [
    {
      "country_code": "MEX",
      "delivery_type": "CASH_PICKUP",
      "payers": [
        {
          "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
          "payer_logo": "...",
          "payer_name": "Elektra",
          "exchange_rate": [
            {
              "currency_symbol": "MXN",
              "exchange_rate": 18.37
            }
          ],
          "fee": 8,
          "max_limit": 10000,
          "min_limit": 0,
          "source_amount": 104.3,
          "number_of_locations": 13007,
          "estimated_availability": "2020-07-21T17:32:28Z",
          "additional_description": "Requires drivers license to pickup funds"
        }
      ]
    }
  ],
  "rating": 4.5,
  "description": "Pontual is a top leading provider with over 10 years of industry experience",
  "company_name": "Pontual"
}

Properties

Name Type Required Restrictions Description
company_logo string(byte) true none base64 representation of the company logo
services [Service] true none none
rating number true none Overall rating of provider calculated from feedback provided by users from previous trasnactions
description string true none A short description of the company
company_name string true none The company name

Service

{
  "country_code": "MEX",
  "delivery_type": "CASH_PICKUP",
  "payers": [
    {
      "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
      "payer_logo": "...",
      "payer_name": "Elektra",
      "exchange_rate": [
        {
          "currency_symbol": "MXN",
          "exchange_rate": 18.37
        }
      ],
      "fee": 8,
      "max_limit": 10000,
      "min_limit": 0,
      "source_amount": 104.3,
      "number_of_locations": 13007,
      "estimated_availability": "2020-07-21T17:32:28Z",
      "additional_description": "Requires drivers license to pickup funds"
    }
  ]
}

Properties

Name Type Required Restrictions Description
country_code string true none Country code ISO_3166
delivery_type string true none The type of service. I.e. cash pickup, home delivery, etc.
payers [object] true none none
» destination_token string(uuid) true none Token that represents the payout destination. 36 characters long
» payer_logo string(byte) true none base64 representation of the payer logo
» payer_name string true none Name of payer
» exchange_rate [object] true none Lists all available currencies and their estimated rates
»» currency_symbol string true none Using ISO 4217 format.
»» exchange_rate number(double) true none Estimated rate
» fee number(double) true none Service fee
» max_limit number(double) true none The maximum amount the user can send with this service. 0 if no upper limit
» min_limit number(double) true none The minimum amount the user can send with this service. 0 if no lower limit
» source_amount number(double) false none Optional return field. Will only show if limit parameter is provided
» number_of_locations integer(int32) false none Total number of locations. Mostly relevant for cash pickup services. 0 if unknown or irrelevant
» estimated_availability string(date-time) false none Estimated availability of funds. When funds would be available to pickup/deposited
» additional_description string false none When available, additional description that explains the service offered or requirements for funds delivery.

Enumerated Values

Property Value
delivery_type CASH_PICKUP
delivery_type BANK_DEPOSIT
delivery_type HOME_DELIVERY
delivery_type MOBILE_WALLET
delivery_type MASSPAY_CARD
delivery_type PAPER_CHECK
delivery_type BILL
delivery_type CRYPTOCURRENCY

ApiResponse

{
  "code": 0,
  "type": "string",
  "message": "string"
}

Properties

Name Type Required Restrictions Description
code integer(int32) false none none
type string false none none
message string false none none

FoundUser

{
  "user_token": "usr_f4741aa2-9f39-4358-8247-2409e3fc2715",
  "first_name": "string",
  "last_name": "string",
  "internal_user_id": "4324-rOzk"
}

FoundUser

Properties

Name Type Required Restrictions Description
user_token string true none The token of the found user
first_name string true none First name of the user
last_name string true none Last name of the user
internal_user_id string true none A client-defined identifier for the user. This is the unique ID assigned to the user on your system. Max 75 characters. Allows letters, numbers, and + , - . / _ ~

SpendBackTxnResp

{
  "spendback_token": "spnd_bk_d2138fd0-00be-45a8-985f-4f5bff5e3962",
  "client_spendback_id": "aEjn345",
  "status": "success"
}

SpendBackTxnResp

Properties

Name Type Required Restrictions Description
spendback_token string(uuid) true none Token that represents the spend back that was just created.
client_spendback_id string true none A client defined spend back identifier. This is the unique ID assigned to the load on your system. Max 50 characters.
status string true none Status that indicates whether the transaction was successfully processed. If success, everything was processed correctly. failure indicates a generic error.

Enumerated Values

Property Value
status success
status failure

SpendBackTxn

{
  "client_spendback_id": "aEjn345",
  "source_token": "usr_wlt_d2138fd0-00be-45a8-985f-4f5bff500962",
  "source_currency_code": "USD",
  "amount": 100.5,
  "notes": "Purchase of Candles. Order #14930",
  "metadata": {
    "group_id": 541
  }
}

SpendBackTxn

Properties

Name Type Required Restrictions Description
client_spendback_id string true none A client defined spend back identifier. This is the unique ID assigned to the load on your system. Max 50 characters.
source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
amount number true none The amount to debit the user's wallet in source currency
notes string false none A description for the spend back
metadata string false none Optional JSON object with attributes that can later be searched to locate this spendback. Do not include PII as this object is not encrypted.

TxnHistoryResp

{
  "token": "payout_d2138fd0-00be-45a8-985f-4f5b87500962",
  "type": "payout",
  "time_of_txn": "2020-09-11T04:07:10Z",
  "source_amount": 50.1,
  "source_currency_code": "USD",
  "destination_amount": 44.99,
  "destination_currency_code": "str",
  "fee": 2.98,
  "status": "READY_FOR_PICKUP",
  "notes": "Purchase of Candles. Order #14930",
  "payer_name": "Elektra",
  "pickup_code": "343432",
  "source_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "delivery_type": "CASH_PICKUP",
  "client_transfer_id": "string"
}

TxnHistoryResp

Properties

Name Type Required Restrictions Description
token string(uuid) true none Token represnting the transaction
type string true none Type of transaction
time_of_txn string(date-time) true none Time the transaction was created. In UTC
source_amount number(float) true none Source amount
source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
destination_amount number(float) true none The amount that was received in destination_currency_code
destination_currency_code string true none The currency of the funds received. Using ISO 4217 format
fee number(float) true none Fee of the transaction
status string true none Status of the transaction
notes string false none Notes of the transaction when load or spend back
payer_name string false none Name of the payer when payout transaction
pickup_code string false none Code/pin that is required when collecting the money when payout transaction
source_token string(uuid) false none Token that represents the funding source i.e. bank account, wallet. 36 characters long
destination_token string(uuid) true none Token that represents the payout destination i.e. Omnex->Brazil->Bank Deposit->Itau. To be retrieved from the #pricing callback. If not provided, the last destination that was used for this user will be used. 36 characters long
delivery_type string false none The type of service. I.e. cash pickup, home delivery, etc. Only provided for payouts
client_transfer_id string false none A client defined transfer identifier. This is the unique ID assigned to the transfer on your system. Max 50 characters.

Enumerated Values

Property Value
type load
type payout
type spend back
type info
status PENDING
status PROCESSING
status COMPLETED
status CANCELLED
status SCHEDULED
status READY_FOR_PICKUP
status HOLD
status ERROR
delivery_type CASH_PICKUP
delivery_type BANK_DEPOSIT
delivery_type HOME_DELIVERY
delivery_type MOBILE_WALLET
delivery_type MASSPAY_CARD
delivery_type PAPER_CHECK
delivery_type BILL
delivery_type CRYPTOCURRENCY

SpendBacks

{
  "spendback_token": "spnd_bk_4275f2-bae1-488d-9d6f-20af1cd83574",
  "time_of_spendback": "2019-07-07T23:03:05",
  "client_spendback_id": "aEjn345",
  "source_token": "usr_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "wallet_token": "clnt_wlt_ba4275f2-bae1-488d-9d6f-20af1cd83574",
  "amount": 100.5,
  "source_currency_code": "USD",
  "notes": "Commission payment for July",
  "metadata": {
    "group_id": 541
  }
}

Properties

Name Type Required Restrictions Description
spendback_token string true none Token representing the load token
time_of_spendback string(YYYY-MM-DDThh:mm:ss) true none The timestamp the spend back was created in the system. Using UTC timestamp.ISO 8601
client_spendback_id string true none A client defined spend back identifier. This is the unique ID assigned to the spend back on your system. Max 50 characters.
source_token string(uuid) true none Token that represents the funding source i.e. bank account, wallet. 36 characters long
wallet_token string(uuid) true none Token that represents the wallet that received the funds. 36 characters long
amount number true none The amount to credit the user's wallet in source currency
source_currency_code string true none The currency originating balance is stored in. Using ISO 4217 format. In most cases this value will be USD, and therefore the defaut value if none is provided
notes string true none A description for the load. Will be visible to the user receiving the load
metadata string false none Optional JSON object with attributes that can later be searched to locate this spendback. Do not include PII as this object is not encrypted.

Exception

{
  "Exception": "string",
  "Errors": [
    "string"
  ]
}

Exception

Properties

Name Type Required Restrictions Description
Exception string true none Type of exception
Errors [string] true none List of errors

AutopayRule

{
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "percentage": 50
}

AutopayRule

Properties

Name Type Required Restrictions Description
destination_token string true none The destination_token to autopay (send payout to)
percentage number(float) true none The percent of incoming load that should be autopaid to the destination_token

AutopayResp

{
  "token": "autopay_3684cc43-fe3b-4994-8ca1-7dc0db94430f",
  "destination_token": "dest_d2138fd0-00be-45a8-985f-4f5bde500962",
  "percentage": 50
}

AutopayResp

Properties

Name Type Required Restrictions Description
token string true none Autopay token
destination_token string true none The destination_token to autopay (send payout to)
percentage number(float) true none The percent of incoming load that should be autopaid to the destination_token