Payments API (v2)

Download OpenAPI description
Languages
Servers
Staging URL
https://apis.spotnana.com/
Spotnana mock server
https://developer.spotnana.com/_mock/openapi/paymentsapi/

Payments

APIs related to Cards, Payments and Fees.

Service Charge

Operations

Personal Payment Sources

Operations

List personal payment sources for a User

Request

Path
userIdstring(uuid)required

Identifier for User Profile

Example: 4974a66b-7493-4f41-908c-58ba81093947
Query
offsetinteger>= 0

Indicates from where in the list of Payment Sources the server should start.

Default 0
limitinteger[ 0 .. 10 ]

Maximum number of results to be fetched for the query.

Default 10
curl -i -X GET \
  'https://apis.spotnana.com/v2/payment/users/4974a66b-7493-4f41-908c-58ba81093947/payment-sources?limit=10&offset=0' \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>'

Responses

OK

Bodyapplication/json
paymentSourceInfosArray of objects(PaymentSourceInfoV2)

List of payment sources

paginationParamsobject(OffsetBasedPaginationResponseParams)

Pagination parameters for response.

Response
application/json
{ "paymentSourceInfos": [ {} ], "paginationParams": { "totalNumResults": 0 } }

Create Personal Payment Source.

Request

Path
userIdstring(uuid)required

Identifier for User Profile

Example: 4974a66b-7493-4f41-908c-58ba81093947
Bodyapplication/json
paymentSourceInfoobject(PaymentSourceInfoV2)required

Detailed information about the payment source to be created.

paymentSourceInfo.​paymentSourcePaymentSourceDetails (object)(PaymentSourceDetails)required
One of:

Details of the payment source

paymentSourceInfo.​paymentSource.​typestringrequired
Example: "CARD"
paymentSourceInfo.​paymentSource.​cardobject(CardV2)required

Card Details

paymentSourceInfo.​paymentSource.​card.​companystring(CardCompany)required

The issuing company of card

Enum"NONE""VISA""MASTERCARD""AMEX""DISCOVER""AIR_TRAVEL_UATP""CARTE_BLANCHE""DINERS_CLUB""JCB""BREX"
paymentSourceInfo.​paymentSource.​card.​namestringrequired

Name on card

Example: "Harrison Schwartz"
paymentSourceInfo.​paymentSource.​card.​addressobject(PostalAddress)required

Billing address

paymentSourceInfo.​paymentSource.​card.​address.​addressLinesArray of stringsrequired

Address lines

Example: ["Golden Gate Bridge"]
paymentSourceInfo.​paymentSource.​card.​address.​administrativeAreastring

Code of administrative area. For example: DL for Delhi, India. Highest administrative subdivision which is used for postal addresses of a country or region. For example, this can be a state, a province, an oblast, or a prefecture. Specifically, for Spain this is the province and not the autonomous community (e.g. "Barcelona" and not "Catalonia"). Many countries don't use an administrative area in postal addresses. E.g. in Switzerland this should be left unpopulated.

Example: "CA"
paymentSourceInfo.​paymentSource.​card.​address.​administrativeAreaNamestring

Name of administrative area. This is full name corresponding to administrativeArea. Like Delhi for DL area code. For some places, code and name maybe same as well like Tokyo.

Example: "California"
paymentSourceInfo.​paymentSource.​card.​address.​descriptionstring

Address description

Example: "San Francisco Home"
paymentSourceInfo.​paymentSource.​card.​address.​isDefaultboolean

Whether this address is default address in case multiple addresses are specified.

Example: true
paymentSourceInfo.​paymentSource.​card.​address.​languageCodestring

BCP-47 language code of the contents of this address (if known). This is often the UI language of the input form or is expected to match one of the languages used in the address' country/region, or their transliterated equivalents. This can affect formatting in certain countries, but is not critical to the correctness of the data and will never affect any validation or other non-formatting related operations. Examples: "zh-Hant", "ja", "ja-Latn", "en".

Example: "en"
paymentSourceInfo.​paymentSource.​card.​address.​localitystring

Generally refers to the city/town portion of the address.

Example: "San Francisco"
paymentSourceInfo.​paymentSource.​card.​address.​locationCodestring

IATA 3-letter location code. See https://www.iata.org/en/services/codes.

Example: "LAX"
paymentSourceInfo.​paymentSource.​card.​address.​organizationstring

The name of the organization at the address.

Example: "Spotnana"
paymentSourceInfo.​paymentSource.​card.​address.​postalCodestring

Postal code of the address. This is a required field when setting for a user/legal entity/company etc.

Example: "94130"
paymentSourceInfo.​paymentSource.​card.​address.​continentCodestring

2 letter continent code of the continent this address falls in.

Example: "AF"
paymentSourceInfo.​paymentSource.​card.​address.​recipientsArray of strings

The recipient at the address.

paymentSourceInfo.​paymentSource.​card.​address.​regionCodestringrequired

Region code of the country/region of the address.

Example: "US"
paymentSourceInfo.​paymentSource.​card.​address.​regionNamestring

Region name of the country/region of the address.

Example: "America"
paymentSourceInfo.​paymentSource.​card.​address.​revisioninteger(int32)
Example: 1
paymentSourceInfo.​paymentSource.​card.​address.​sortingCodestring

Additional, country-specific, sorting code. This is not used in most regions. Where it is used, the value is either a string like "CEDEX", optionally followed by a number (e.g. "CEDEX 7"), or just a number alone, representing the "sector code" (Jamaica), "delivery area indicator" (Malawi) or "post office indicator" (e.g. Côte d'Ivoire).

Example: "Jamaica"
paymentSourceInfo.​paymentSource.​card.​address.​sublocalitystring

Sublocality of the address. This can be neighborhoods, boroughs, districts.

paymentSourceInfo.​paymentSource.​card.​address.​timezonestring

Time zone of the address.

Example: "America/Los_Angeles"
paymentSourceInfo.​paymentSource.​card.​address.​coordinatesobject(Latlng)

Map coordinates of the address.

paymentSourceInfo.​paymentSource.​card.​numberstringrequired

Card number

Example: "4111111111111111"
paymentSourceInfo.​paymentSource.​card.​cvvstring

Card cvv number

Example: "012"
paymentSourceInfo.​paymentSource.​card.​labelstringrequired

Card Label

Example: "Label amex"
paymentSourceInfo.​paymentSource.​card.​expiryobject(Expiry)required

Card Expiry.

paymentSourceInfo.​paymentSource.​card.​expiry.​expiryMonthinteger(int32)[ 1 .. 12 ]required

Expiry month

Example: 1
paymentSourceInfo.​paymentSource.​card.​expiry.​expiryYearinteger(int32)>= 2000required

Expiry year

Example: 2010
paymentSourceInfo.​paymentSource.​card.​ownershipLabelstring(OwnershipLabel)

Ownership label of the card whether it is personal, corporate or central.

Enum"CORPORATE""PERSONAL""CENTRAL"
Example: "PERSONAL"
paymentSourceInfo.​filterUsagePaymentFilter (object)(UsagePaymentFilter)required
One of:

Applicable Filters i.e. access level, travel type information etc.

paymentSourceInfo.​filter.​typestringrequired
Example: "PERSONAL"
paymentSourceInfo.​filter.​travelTypesArray of strings(TravelType)[ 1 .. 6 ] itemsrequired

Applicable payment source travel types

Items Enum"AIR""HOTEL""CAR""RAIL""LIMO""MISC""ALL"
Example: ["AIR"]
paymentSourceInfo.​filter.​managedTravelerAccessobject(ManagedTravelerPaymentAccess)

Config for providing the access to Managed Travelers if any.

paymentSourceInfo.​externalIdstring

An identifier assigned by a partner system. Once attached to a payment source, it remains unique per user and cannot be reassigned to another payment source.

Example: "bxt_RNGsNfzgJDaTstKIKqK4xEuhGYAnMdYK8T40"
curl -i -X POST \
  https://apis.spotnana.com/v2/payment/users/4974a66b-7493-4f41-908c-58ba81093947/payment-sources \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "paymentSourceInfo": {
      "paymentSource": {
        "type": "CARD",
        "card": {
          "company": "VISA",
          "name": "Harrison Schwartz",
          "address": {
            "addressLines": [
              "Golden Gate Bridge"
            ],
            "administrativeArea": "CA",
            "administrativeAreaName": "California",
            "description": "San Francisco Home",
            "isDefault": true,
            "languageCode": "en",
            "locality": "San Francisco",
            "locationCode": "LAX",
            "organization": "Spotnana",
            "postalCode": "94130",
            "continentCode": "AF",
            "recipients": [
              "string"
            ],
            "regionCode": "US",
            "regionName": "America",
            "revision": 1,
            "sortingCode": "Jamaica",
            "sublocality": "string",
            "timezone": "America/Los_Angeles",
            "coordinates": {
              "latitude": 77.1025,
              "longitude": 28.7041
            }
          },
          "number": "4111111111111111",
          "cvv": "012",
          "label": "Label amex",
          "expiry": {
            "expiryMonth": 1,
            "expiryYear": 2010
          },
          "ownershipLabel": "CORPORATE"
        }
      },
      "filter": {
        "type": "PERSONAL",
        "travelTypes": [
          "AIR"
        ],
        "managedTravelerAccess": {
          "enabled": false,
          "visibility": {
            "showToTravelers": false
          }
        }
      },
      "externalId": "bxt_RNGsNfzgJDaTstKIKqK4xEuhGYAnMdYK8T40"
    }
  }'

Responses

OK

Bodyapplication/json
idstring(uuid)

Unique identifier identifying the created payment source, if created.

Example: "f49d00fe-1eda-4304-ba79-a980f565281d"
statusstring(PaymentSourceStatus)read-only

Current status of the payment source.

Enum"ACTIVE""INCOMPLETE"
authenticationInfoobject(AuthenticationInfo)

Information required for additional authentication steps, such as 3D Secure verification.

Response
application/json
{ "id": "f49d00fe-1eda-4304-ba79-a980f565281d", "status": "ACTIVE", "authenticationInfo": { "authUrl": "string" } }

Fetch a personal payment source

Request

Path
userIdstring(uuid)required

Identifier for User Profile

Example: 4974a66b-7493-4f41-908c-58ba81093947
paymentSourceIdstring(uuid)required

Identifier for personal paymentSource.

Example: 4974a66b-7493-4f41-908c-58ba81093947
curl -i -X GET \
  https://apis.spotnana.com/v2/payment/users/4974a66b-7493-4f41-908c-58ba81093947/payment-sources/4974a66b-7493-4f41-908c-58ba81093947 \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>'

Responses

OK

Bodyapplication/json
paymentSourceobject(PaymentSourceInfoV2)

Details of the payment source

Response
application/json
{ "paymentSource": { "id": "497f6eca-6276-4993-bfeb-53cbbbba6f08", "paymentSource": {}, "filter": {}, "status": "ACTIVE", "externalId": "bxt_RNGsNfzgJDaTstKIKqK4xEuhGYAnMdYK8T40" } }

Delete a Personal Payment Source.

Request

Path
userIdstring(uuid)required

Identifier for User Profile

Example: 4974a66b-7493-4f41-908c-58ba81093947
paymentSourceIdstring(uuid)required

Identifier for personal paymentSource.

Example: 4974a66b-7493-4f41-908c-58ba81093947
curl -i -X DELETE \
  https://apis.spotnana.com/v2/payment/users/4974a66b-7493-4f41-908c-58ba81093947/payment-sources/4974a66b-7493-4f41-908c-58ba81093947 \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>'

Responses

OK

Response
No content

Update a Personal Payment Source.

Request

Path
userIdstring(uuid)required

Identifier for User Profile

Example: 4974a66b-7493-4f41-908c-58ba81093947
paymentSourceIdstring(uuid)required

Identifier for personal paymentSource.

Example: 4974a66b-7493-4f41-908c-58ba81093947
Bodyapplication/json
paymentSourceInfoPaymentSourceUpdateDetails (object)(PaymentSourceUpdateDetails)required
One of:

Details of the payment source to be updated

paymentSourceInfo.​paymentTypestringrequired
Example: "CARD"
paymentSourceInfo.​cardobject(CardUpdate)required

Card Details to be updated

paymentSourceInfo.​card.​addressobject(PostalAddress)

Billing address

paymentSourceInfo.​card.​labelstring

Card Label

Example: "Label amex"
paymentSourceInfo.​card.​ownershipLabelstring(OwnershipLabel)

Ownership label of the card whether it is personal, corporate or central.

Enum"CORPORATE""PERSONAL""CENTRAL"
filterUsagePaymentFilter (object)(UsagePaymentFilter)
One of:

Applicable Filters i.e. access level, travel type information etc.

curl -i -X PATCH \
  https://apis.spotnana.com/v2/payment/users/4974a66b-7493-4f41-908c-58ba81093947/payment-sources/4974a66b-7493-4f41-908c-58ba81093947 \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Content-Type: application/json' \
  -d '{
    "paymentSourceInfo": {
      "paymentType": "CARD",
      "card": {
        "address": {
          "addressLines": [
            "Golden Gate Bridge"
          ],
          "administrativeArea": "CA",
          "administrativeAreaName": "California",
          "description": "San Francisco Home",
          "isDefault": true,
          "languageCode": "en",
          "locality": "San Francisco",
          "locationCode": "LAX",
          "organization": "Spotnana",
          "postalCode": "94130",
          "continentCode": "AF",
          "recipients": [
            "string"
          ],
          "regionCode": "US",
          "regionName": "America",
          "revision": 1,
          "sortingCode": "Jamaica",
          "sublocality": "string",
          "timezone": "America/Los_Angeles",
          "coordinates": {
            "latitude": 77.1025,
            "longitude": 28.7041
          }
        },
        "label": "Label amex",
        "ownershipLabel": "CORPORATE"
      }
    },
    "filter": {
      "type": "PERSONAL",
      "travelTypes": [
        "AIR"
      ],
      "managedTravelerAccess": {
        "enabled": false,
        "visibility": {
          "showToTravelers": false
        }
      }
    }
  }'

Responses

OK

Response
No content