| 
 | Wero, a key initiative of the European Payments Initiative (EPI), is an innovative payment solution crafted to address the evolving needs of Europe today and tomorrow. The members of EPI are Europe’s biggest banks and financial institutions. Wero is designed to become the preferred standard payment solution for European merchants and consumers. Wero offers a secure, user-centric digital wallet. It simplifies payments to and from customers eligible bank accounts while providing greater transparency and control than ever before, delivering an enhanced and seamless digital payment experience. This integration guide offers a detailed overview and clear, step-by-step instructions to help developers effortlessly connect the Wero Digital Wallet with their online shops, ensuring smooth and efficient payment processing for users across Europe and beyond. | 
The Wero E- and M-Commerce solution is currently available in Belgium and Germany, with plans to expand to France, the Netherlands and Luxembourg soon.
More countries are expected to join the European payment system, which aims to provide a unified alternative to international payment providers.
Paying with WERO will be possible in
Testing WERO doesn't involve end consumer or test WERO Digital app. To enable completing step required for the consent approval, follow the below steps:
|  | 
|  | 
POST Request - Pre-/ Authorization
| request required | Fixed Value: preauthorisation/authorization | 
| mid required | your merchant ID, 5-digit numeric | 
| aid required | your subaccount ID, 5-digit numeric | 
| portalId required | your Portal ID, 7-digit numeric | 
| key required | your key value, alpha-numeric | 
Indicates whether customer is “present” and can enter their data in the shop (=yes). Or customer is not present and can not enter any data (=no).
| clearingtype required | Fixed Value: wlt | 
| mode required | Fixed Value: test/live Can be either test environment (test) or live environment (live) | 
| reference optional | Format CHAR(2..255) A unique ID that will be displayed in your shop backend and for the customer | 
| amount required | Format NUMERIC(1..10) Permitted values max. +/- 19 999 999 99 Specifies the total gross amount of a payment transaction. Value is given in smallest currency unit, e.g. Cent of Euro. The amount must be less than or equal to the amount of the corresponding booking. | 
| currency required | Format LIST Permitted values ISO 4217 (currencies) 3-letter-codes Samples EUR USD GBP | 
| param optional | Format CHAR(1..255) Individual parameter (per payment process) | 
| narrative_text optional | Format CHAR(1..81) Dynamic text element on account statements (3 lines with 27 characters each) and credit card statements. | 
| customer_is_present optional | Format LIST yes/no | 
| transaction_param optional | Format CHAR(1..50) Permitted Symbols [0-9][A-Z][a-z][.-_/] Optional parameter for merchant information (per payment request) | 
| customerid optional | Format CHAR(1..20) Permitted Symbols [0-9, a-z, A-Z, .,-,_,/] Merchant's customer ID, defined by you / merchant to refer to the customer record. "customerid" can be used to identify a customer record. If "customerid" is used then stored customer data are loaded automatically. | ||||||
| userid optional | Format NUMERIC(6..12) PAYONE User ID, defined by PAYONE | ||||||
| businessrelation optional | Format LIST 
 Value specifies business relation between merchant and customer | ||||||
| salutation optional | Format CHAR(1..10) The customer's salutation | ||||||
| title optional | Format CHAR(1..20) Samples Dr. Prof. Dr.-Ing. Title of the customer | ||||||
| firstname optional | Format CHAR(1..50) First name of customer; optional if company is used, i.e.: you may use "company" or "lastname" or "firstname" plus "lastname" | ||||||
| lastname required | Format CHAR(2..50) Last name of customer; optional if company is used, i.e.: you may use "company" or "lastname" or "firstname" plus "lastname" | ||||||
| company optional | Format CHAR(2..50) Comany name of customer; optional if company is used, i.e.: you may use "company" or "lastname" or "firstname" plus "lastname" | ||||||
| street optional | Format CHAR(1..50) Street number and name (required: at least one character) | ||||||
| addressaddition optional | Format CHAR(1..50) Samples 7th floor c/o Maier Specifies an additional address line for the invoice address of the customer. | ||||||
| zip optional | Format CHAR(2..50) Permitted Symbols [0-9][A-Z][a-z][_.-/ ] Postcode | ||||||
| city optional | Format CHAR(2..50) City of customer | ||||||
| country required | Format LIST Permitted values: ISO 3166 2-letter-codes | ||||||
| state optional | Format LIST Permitted values: ISO 3166-2 States (regions) 2-letter-codes 
 Specifies state / region of country for the customer.  | ||||||
| email optional | Format CHAR(5..254) Mandatory if "add_paydata[shopping_cart_type]=DIGITAL" Permitted Symbols RFC 5322 Special Remark email validation: Max. length for email is 254 characters. Validation is set up in the following way: Username = Max. 63 characters Domain Name = Max. 63 characters  "@" and "." is counted as a character as well; in case of a total of three suffixes, this would allow a total of 254 characters. email-address of customer | ||||||
| telephonenumber optional | Format CHAR(1..30) Phone number of customer | ||||||
| birthday optional | Format DATE(8), YYYYMMDD Samples 20190101 19991231 Date of birth of customer | ||||||
| language optional | Format LIST Permitted values ISO 639-1 (Language)2-letter-codes Language indicator (ISO 639) to specify the language that should be presented to the customer (e.g. for error messages, frontend display). If the language is not transferred, the browser language will be used. For a non-supported language English will be used. | ||||||
| vatid optional | Format CHAR(1..50) VAT identification number. Used for b2b transactions to indicate VAT number of customer. | ||||||
| gender optional | Format LIST Permitted values f/ m/  d Gender of customer (female / male / diverse* ) * currently not in use | ||||||
| personalid optional | Format CHAR(1..32) Permitted Symbols [0-9][A-Z][a-z][+-./()] Person specific numbers or characters, e.g. number of passport / ID card | ||||||
| ip optional | Format CHAR(1..39) Customer's IP-V4-address (123.123.123.123) or IP-V6-address | 
| shipping_firstname required | Format CHAR(1..50) First name of delivery address | ||||||
| shipping_lastname required | Format CHAR(1..50) Surname of delivery address | ||||||
| shipping_company optional | Format CHAR(2..50) Company name of delivery address | ||||||
| shipping_street optional | Format CHAR(2..50) Street number and name of delivery address | ||||||
| shipping_zip required | Format CHAR(2..50) Postcode of delivery address | ||||||
| shipping_addressaddition optional | Format CHAR(1..50) Specifies an additional address line for the delivery address of the customer, e.g. "7th floor", "c/o Maier". | ||||||
| shipping_country optional | Format LIST Permitted values ISO 3166 2-letter-codes Samples DE GB US Specifies country of address for the customer. Some countries require additional information in parameter "state" | ||||||
| shipping_state optional | Format LIST Permitted values ISO 3166-2 States (regions) 2-letter-codes 
 Specifies state / region of country for the customer.  | 
| wallettype required | Fixed Value WRO | 
| successurl required | Format CHAR(2..255) Scheme <scheme>://<host>/<path> <scheme>://<host>/<path>?<query> scheme-pattern: [a-zA-Z]{1}[a-zA-Z0-9]{1,9} URL for "payment successful" | 
| errorurl required | Format CHAR(2..255) Scheme <scheme>://<host>/<path> <scheme>://<host>/<path>?<query> scheme-pattern: [a-zA-Z]{1}[a-zA-Z0-9]{1,9} URL for "faulty payment" | 
| backurl required | Format CHAR(2..255) Scheme <scheme>://<host>/<path> <scheme>://<host>/<path>?<query> scheme-pattern: [a-zA-Z]{1}[a-zA-Z0-9]{1,9} URL for "Back" or "Cancel" | 
| it[n] optional | 
 | ||||||||||
| id[n] optional | Format CHAR(1..32) Array elements [n] starting with [1]; serially numbered; max [400] Permitted Symbols [0-9][a-z][A-Z], .,-,_,/ International Article Number (EAN bzw. GTIN) Product number, SKU, etc. of this item | ||||||||||
| pr[n] optional | Format NUMERIC(10) max. 19 999 999 99 Array elements [n] starting with [1]; serially numbered; max [400] Unit gross price of the item in smallest unit! e.g. cent | ||||||||||
| no[n] optional | Format NUMERIC(6) Array elements [n] starting with [1]; serially numbered; max [400] Quantity of this item | ||||||||||
| de[n] optional | Format CHAR(1..255) Array elements [n] starting with [1]; serially numbered; max [400] Description of this item. Will be printed on documents to customer. | ||||||||||
| va[n] optional | Format NUMERIC(4) VAT rate (% or bp) Array elements [n] starting with [1]; serially numbered; max [400] | 
| status | Permitted Values  REDIRECT ERROR | 
| txid | Format NUMERIC(9..12) The txid specifies the payment process within the PAYONE platform | 
| userid | Format NUMERIC(6..12) PAYONE User ID, defined by PAYONE | 
| redirecturl | Format CHAR(2..2000) Redirect URL → Merchant system has to redirect customer to this URL to complete payment | 
| errorcode | Format NUMERIC(1..6) In case of error the PAYONE Platform returns an error code for your internal usage. | 
| errormessage | Format CHAR(1..1024) In case of error the PAYONE Platform returns an error message for your internal usage. | 
| customermessage | Format CHAR(1..1024) The customermessage is returned to your system in order to be displayed to the customer. (Language selection is based on the end customer's language, parameter "language") | 
Host: api.pay1.de
Content-Type: application/x-www-form-urlencoded
Payload
    
mid=23456
portalid=12345123
key=abcdefghijklmn123456789
api_version=3.10
mode=test
request=preauthorization
encoding=UTF-8
aid=12345
clearingtype=wlt
wallettype=WRO
reference=Ref123456
amount=300
currency=EUR
lastname=Peeters
country=BE
successurl=http://www.your-success.url
errorurl=http://www.your-error.url
backurl=http://www.your-back.url             
RESPONSE
                        
status=REDIRECT
redirecturl=http://www.aliasweropage.com
txid=345678901
userid=123456789                     
POST Request - Capture
| request required | Fixed Value: capture | 
| mid required | your merchant ID, 5-digit numeric | 
| aid required | your subaccount ID, 5-digit numeric | 
| portalId required | your Portal ID, 7-digit numeric | 
| key required | your key value, alpha-numeric | 
| txid required | Format NUMERIC(9..12) The txid specifies the payment process within the PAYONE platform | 
| sequencenumber optional | Format NUMERIC(1..3) Permitted values 0..127 Sequence number for this transaction within the payment process (1..n), e.g. PreAuthorization: 0, 1. Capture: 1, 2. Capture: 2 Required for multi partial capture (starting with the 2nd capture) | 
| amount required | Format NUMERIC(1..10) Permitted values max. +/- 19 999 999 99 Specifies the total gross amount of a payment transaction. Value is given in smallest currency unit, e.g. Cent of Euro; Pence of Pound sterling; Öre of Swedish krona. The amount must be less than or equal to the amount of the corresponding booking. | 
| currency required | Fixed Value EUR | 
| narrative_text optional | Format CHAR(1..81) Dynamic text element on account statements (3 lines with 27 characters each) and credit card statements. | 
| status | Permitted Values  APPROVED PENDING ERROR | 
| txid | Format NUMERIC(9..12) The txid specifies the payment process within the PAYONE platform | ||||||
| settleaccount | Format LIST 
 Provides information about whether a settlement of balances has been carried out. For this payment type the settlement of balances will be always carried out. | 
| txid | Format NUMERIC(9..12) The txid specifies the payment process within the PAYONE platform | 
| userid | Format NUMERIC(6..12) PAYONE User ID, defined by PAYONE | 
| errorcode | Format NUMERIC(1..6) In case of error the PAYONE Platform returns an error code for your internal usage. | 
| errormessage | Format CHAR(1..1024) In case of error the PAYONE Platform returns an error message for your internal usage. | 
Host: api.pay1.de
Content-Type: application/x-www-form-urlencoded
Payload
mid=23456 portalid=12345123 key=abcdefghijklmn123456789 api_version=3.10 mode=test request=capture encoding=UTF-8 txid=345678901 amount=300 currency=EUR
RESPONSE
status=APPROVED txid=345678901 settleaccount=yes
POST Request - Debit
| request required | Fixed Value: debit | 
| mid required | your merchant ID, 5-digit numeric | 
| aid required | your subaccount ID, 5-digit numeric | 
| portalId required | your Portal ID, 7-digit numeric | 
| key required | your key value, alpha-numeric | 
| txid required | Format NUMERIC(9..12) The txid specifies the payment process within the PAYONE platform | ||||||
| sequencenumber required | Format NUMERIC(1..3) Permitted values 0..127 Sequence number for this transaction within the payment process (1..n), e.g. PreAuthorization: 0, 1. Capture: 1, 2. Capture: 2 Required for multi partial capture (starting with the 2nd capture) | ||||||
| amount required | Format NUMERIC(1..10) Permitted values max. +/- 19 999 999 99 Specifies the total gross amount of a payment transaction. Value is given in smallest currency unit, e.g. Cent of Euro; Pence of Pound sterling; Öre of Swedish krona. The amount must be less than or equal to the amount of the corresponding booking. | ||||||
| currency required | Fixed Value EUR | ||||||
| narrative_text optional | Format CHAR(1..81) Dynamic text element on account statements (3 lines with 27 characters each) and credit card statements. | ||||||
| clearingtype optional | Fixed Value wlt | ||||||
| use_customerdata optional | Format LIST 
 Use account details from debtor's master data | ||||||
| transaction_param optional | Format CHAR(1..50) Permitted Symbols [0-9][A-Z][a-z][.-_/] Optional parameter for merchant information (per payment request) | 
| status | Permitted Values APPROVED ERROR | 
| txid | Format NUMERIC(9..12) The txid specifies the payment process within the PAYONE platform | ||||||
| settleaccount | Format LIST  
 Provides information about whether a settlement of balances has been carried out. | 
| errorcode | Format NUMERIC(1..6) In case of error the PAYONE Platform returns an error code for your internal usage. | 
| errormessage | Format CHAR(1..1024) In case of error the PAYONE Platform returns an error message for your internal usage. | 
| customermessage | Format CHAR(1..1024) The customermessage is returned to your system in order to be displayed to the customer. (Language selection is based on the end customer's language, parameter "language") | 
Host: api.pay1.de
Content-Type: application/x-www-form-urlencoded
Payload
                    
mid=23456
portalid=12345123
key=abcdefghijklmn123456789
api_version=3.10
mode=test
request=debit
encoding=UTF-8
txid=345678901
sequencenumber=1
amount=1000
currency=EUR       
RESPONSE
status=APPROVED txid=345678901 settleaccount=yes