Transmit a Receipt

This document covers the three easy steps to deliver a Receipt with wunderbon

๐Ÿ‘

TL;DR

What we are about to do ...

  • Tokenize an Identifier
  • Receive a Transmission Token
  • Transmit a Receipt using Transmission Token

In this short How-To we will show you how easy it is to transmit a Receipt using wunderbon and how we ensure strong privacy for all parties at the same time. Enjoy!

64

Requirements

We will go through this How-To without requiring a wunderbon account (real Authentication or Id Token). If you have an account already and want to walk through this How-To using your account and the Testnet (0xFF) then feel free to do so. For this, you just need to exchange the URL from playground-api.wunderbon.io to testnet-api.wunderbon.io.

Beside the Access Token you will need the following tools to get through this guide:

  • some kind of Shell (whatever you prefer)
  • cURL

๐Ÿ“˜

OAS for other Cients

We assume that you have cURL in place. All our examples are based on cURL as client.

If you like to use Postman or Stoplight Studio instead checkout the latest OpenAPI specification to load the wunderbon API.

Authentication

With your registration as Merchant you received your Client-Id and your Client-Secret. We need to receive an Authentication Token (Id Token) to be able to authenticate against the wunderbon API. You can try the following recipe if you don't know already how to login and exchange credentials with an Authentication Token.

For all further access to the protected wunderbon API endpoints, we make use of the following Authentication Parameters:

๐Ÿ‘

Authentication Parameters

Authentication-Type: http
Authentication-Scheme: bearer
Bearer-Format: JWT
Transportation-Method: Header

Recipient

For testing purposes or for evaluating the wunderbon API, we provide a set of test data. Almost any operation within the wunderbon network requires a reference to a user. So to transmit a Receipt, you need to identify the customer as a wunderbon user. The following set of data is used in this How-To:

๐Ÿ‘

Official Test User

For testing purposes and demonstration of the network functionality (Testnet) we provide the following user entity:

  • Id: c1de9956-9fca-42aa-87ef-a90a48c9d112

๐Ÿ‘

Official Test Identifiers

wunderbon Account Number
Provider Id: 0x01
Identifier: Random Tokenized
Sequence: null
Expires: null

Primary Account Number (ISO/IEC 7812)
Provider Id: 0x02
Identifier: 5168 4412 2363 0339 ยน
Sequence: 01
Expires (month/year): 06/2026

The wunderbon Account Number will be provided from Consumers smartphone display at the POS. The token will be either shown as QR Code or fallback as Code 128. The Code128 will require an additional step to receive the real tokenized cryptogram. This may depend on the capabilities of the scanning device (POS-System).

315
eyJpdiI6IjdpWjljalVuUm5Nb25KNG1tM3NFREE9PSIsImVwaGVtUHVibGljS2V5IjoiQkhEdj \ 
BKb3U4L281bC9sM0w4OC8zNU1JRVQvdFdJN0NzMkFlRTVQWDR6bDJuRVNkdmxxamduQWJIY2g3 \
MkRoVFpNZ3hMbkFyMWppei96YS9oQTFWcjJ3PSIsImNpcGhlcnRleHQiOiJJaitjK0tsbC9FQm \
c2eGZRTU1Hb1dQaGQ5TE9TVy9Ua2VpV0ZxZTZLRzR1cG1ZN0VLS1N6RGZ1WExtUks4Qmg3NWJJ \
UVlaYUsrdWZ6MDdjbS9hSGJDL2dIZVNlc0NycklwTGxUajAyUnFISnZWZnhqSElweFM4cUhKSG \
hOVXNwQ1BHK1NxbE9MZWFiKytUTXQ4bExPWGc9PSIsIm1hYyI6InE5bkFQTCtJNzlJSnhieTlv \
eURzSGZpR1U1aXkvOHRkL0pWeit6TjVxV2M9Iiwic2lnIjoiYTM2ZjMzNTc5ZWQzZTczZmI3OW \
VlZTRjMmJjNGE0MGVkOGVlMDRjYTUxMGU3ZjYyYjhjZmE4ZGFmZjZlNmE1ZDk0ZDI5Nzc4MTZm \
MTA2YjIzODE0YWNlNWE1NGNkODc3MTgxY2Q1NGY5ODA4ZTk5NmQyZmQ1OWE3M2Q5Nzk2NmFhYj \
gyMjQ4NjUyMjU5MzBhNmY5NmI5MGVkY2E4N2VjYmVhMGUzODBmODhmODBkOGQxNzI2NjhlNWNm \
OTkwNGQzIn0=

Identifier

In this How-To we will use make use of the user's Primary Account Number (ISO/IEC 7812). ยน The following Cardholder Data is provided only for testing/demonstration purposes. wunderbon DOES NEVER STORE ANY PAYMENT OR OTHER SENSITIVE INFORMATION!

Cardholder Data

Issuing network: Mastercard
Name: Jane Doe
Address: 1600 Amphitheatre Parkway, Mountain View, CA 94043
Country: USA
Bank: Bank of America
CVV: 202
Expires: 06/2026
Sequence: 1

Tokenization

๐Ÿšง

Tokenization

The implementation is currently only available to registered partners. If you are a registered partner and would like to transmit receipts using Provider Id 2 contact us at [email protected] for more details.

Registered users can make use of the /tokens/identifiers endpoint of the API to tokenize an Identifier. We recommend this endpoint for testing purposes only! We recommend implementing the whole tokenization on client side. Furthermore, we do not want any payment data on our platform, neither in the database nor in log files or similar. So the endpoint does not log any data.

In this step, you would tokenize the Identifier from the previous step. But this step is a bit more complex and currently only available to certified partners. We can go on using the tokenized representation of the Identifier we created for you: 2mdkUcY1XRGA2TBJW7wzto6niwipLhqz9fc. This one is calculated from Primary Account Number PAN (ISO/IEC 7812) and Provider Id 0x02.

Transmission Token

With the tokenized representation of the users Identifier we can go over to receive a Transmission Token from it. We need this token for transmitting a Receipt.

The recipe consists of the following steps:

curl -L --request POST \
  --url https://playground-api.wunderbon.io/tokens/transmissions \
  --header 'Content-Type: application/vnd.api+json' \
  --header 'Authorization: Bearer ${YOUR-TOKEN}'
  --data '{"network": 2, "token": "2mdkUcY1XRGA2TBJW7wzto6niwipLhqz9fc"}'

You will receive a response which looks similar to the following one:

{
  "meta": {
    "success": true
  },
  "data": {
    "type": "Tokens",
    "attributes": {
      "token": "ac15d9238c384695901667433e7c3dc0c6231e2d",
      "expiresIn": 60,
      "created": "2022-01-10T22:09:34.053Z"
    }
  }
}

The token is linked to a dummy account of a user with Id c1de9956-9fca-42aa-87ef-a90a48c9d112 named Mrs. Jane Doe. This is the default Test User described above. If you submitted an unknown Identifier you would receive a 404 response instead of a successful one.

Transmit a Receipt

Now we go to deliver a receipt to the user using the token ac15d9238c384695901667433e7c3dc0c6231e2d ...

curl -L --request POST \
  --url https://playground-api.wunderbon.io/receipts \ 
  --header 'Content-Type: application/vnd.api+json' \
  --header 'Authorization: Bearer ${YOUR-TOKEN}'
  --data '{"header":["..."], ...}'

If you would like to see more of the receipt data, have a look here.

{
  "meta": {
    "success": true
  },    
  "data": {
    "type": "Receipts",
    "id": "c29041a5-038e-4e44-8b3b-745a929721a5"
  }
}

You receive the id of the receipt created. The hash of the receipt as persisted in Blockchain is added asynchronous. You will receive it with the receipt data from the API using entities id (e.g. c29041a5-038e-4e44-8b3b-745a929721a5).

Hooray!

It is so easy to deliver secure GDPR-compliant digital smart receipts by just using our 2-step protocol as seen here.

๐Ÿ“˜

Are you a POS Software Provider?

We are looking for strong partnerships in EMEA and worldwide. If you are developing POS-Software and/or providing hardware to Retailers/Merchants, then get in contact with our Revenue-Team and start providing additional high quality and stable encrypted value added services (VAS) by just partnering with us.

Earn fair by subscription share of aggregated clients. Find out more.


Whatโ€™s Next

Continue with our guided tour. Now we would like to tell some more about how we handle different Environments in our wunderbon network ...