OPay E-Wallet Payments API

In this page, you will learn how to use E-Wallet payments with a QR code and R2P request.

  • Collect your client's payment Information.
  • Trigger E-Wallet payment API with your collected information.
  • Handle the API Response.
  • Redirect your client to scan QR code.
  • After payment successfully, redirect your client to successful page.

How it works?

  1. Merchant will send E-Wallet Payment request with client information to OPay.
  2. OPay will respond to the merchant with QR code and send request to pay (R2P) to client wallet
  3. Merchant query order status through OPay Query Payment Status API or waiting for the callback notification
  4. Merchant redirect your client to the merchant successful or failure page

QR Code Payment

To test QR Code Payment, you need to request using the POST method in our sandbox environment.
-Here is the request URL:

                  
                        https://sandboxapi.opaycheckout.com/api/v1/international/payment/create
                  
                

-Once you have a fully tested payment flow and you are ready for production, use the following production API endpoint URL instead

                            
                                https://api.opaycheckout.com/api/v1/international/payment/create
                            
                        

-Request Parameters:

  1. Header: Authorization(API Calls Signature), MerchantId
  2.                         
                                Authorization    : Bearer {signature}
                                MerchantId       : 256612345678901
                            
                        
  3. Json object containing the transaction information:
  4.                                 
                                        {
                                            "country":"EG",
                                            "reference":"202111300001",
                                            "amount":{
                                                "currency":"EGP",
                                                "total":1000
                                            },
                                            "callbackUrl":"https://your-call-back-url",
                                            "product":{
                                                "name":"product name",
                                                "description":"product description"
                                            },
                                            "userInfo":{
                                                "userName":"OPay Test Name",
                                                "userMobile":"201066668888",
                                                "userEmail":"customer@email.com"
                                            },
                                            "userClientIP":"100.123.10.66",
                                            "expireAt":30,
                                            "payMethod":"MWALLET",
                                            "walletAccount":"01066668888",
                                        }
                                    
                                

HTTP POST Parameters

-Here is a detailed description for the parameters you need to complete the POST request:

Parameter type required Description
country String required Country Code. See full list here
reference String required The unique merchant payment Order Number
amount
total Long required Amount (cent unit)
currency String required Currency type. e.g. EGP
callbackUrl String optional If you have sent callbackUrl through API, OPay will send callback notification to this callbackUrl. If you didn't send callbackUrl through API, you need to configure webhook url on the merchant dashboard, and OPay will send callback notification to this webhook url. See callback here
product
name String required product name.
description String required Product description.
productList
JSON Array
productId String optional Merchant Product ID
name String optional product name
description String optional Product description
price Integer optional Product price
quantity Integer optional Product quantity
imageUrl String optional Product image URL
userInfo
JSON Array
userName String required The customer name in merchant system.
userMobile String required The customer mobile in merchant system. e.g. 201066668888.
userEmail String required The customer e-mail in merchant system:customer@email.com.
userClientIP String optional IP address of customer's device. IPv4 or IPv6.
expireAt Integer optional Payment expiration time in minutes.(default 30)
payMethod String required E-wallet Payment Method: MWALLET
walletAccount String required Customer wallet account, it should be an 11-digit phone number in Egypt. e.g. 01066668888

-An example of E-Wallet payment request for an amount of 400 EGP is as follows :

                                    
                                        class MwalletController
                                        {
                                            private $secretkey;
                                            private $merchantId;
                                            private $url;

                                            public function __construct() {
                                                $this->merchantId = '281821110129700';
                                                $this->secretkey = 'OPAYPRV*******0187828';
                                                $this->url = 'https://sandboxapi.opaycheckout.com/api/v1/international/payment/create';
                                            }

                                            public function test(){
                                                $data = [
                                                    'amount' => [
                                                        'currency' => 'EGP',
                                                        'total' => 400
                                                    ],
                                                    'callbackUrl' => 'https://your-call-back-url.com',
                                                    'country' => 'EG',
                                                    'payMethod' => 'MWALLET',
                                                    'product' => [
                                                        'description' => 'description',
                                                        'name' => 'product-name-one'
                                                    ],
                                                    'reference' => '04145678905677',
                                                    'userInfo' => [
                                                        'userEmail' => 'customer@email.com',
                                                        'userMobile' => '201066668888',
                                                        'userName' => 'OPay Test Name'
                                                    ],
                                                    'walletAccount' => '01066668888'
                                                ];
                                                $data2 = (string) json_encode($data,JSON_UNESCAPED_SLASHES);
                                                $auth = $this->auth($data2);
                                                $header = ['Content-Type:application/json', 'Authorization:Bearer '. $auth, 'MerchantId:'.$this->merchantId];
                                                $response = $this->http_post($this->url, $header, json_encode($data));
                                                $result = $response?$response:null;
                                                return $result;
                                            }

                                            private function http_post ($url, $header, $data) {
                                                if (!function_exists('curl_init')) {
                                                    throw new Exception('php not found curl', 500);
                                                }
                                                $ch = curl_init();
                                                curl_setopt($ch, CURLOPT_TIMEOUT, 60);
                                                curl_setopt($ch, CURLOPT_URL, $url);
                                                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
                                                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
                                                curl_setopt($ch, CURLOPT_HEADER, false);
                                                curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                                                curl_setopt($ch, CURLOPT_POST, true);
                                                curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
                                                curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
                                                $response = curl_exec($ch);
                                                $httpStatusCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
                                                $error=curl_error($ch);
                                                curl_close($ch);
                                                if (200 != $httpStatusCode) {
                                                    print_r("invalid httpstatus:{$httpStatusCode} ,response:$response,detail_error:" . $error, $httpStatusCode);
                                                }
                                                return $response;
                                            }
                                            public function auth ( $data ) {
                                                $secretKey = $this->secretkey;
                                                $auth = hash_hmac('sha512', $data, $secretKey);
                                                return $auth;
                                            }

                                        }
                                    
                                
                                        
                                            # importing the requests library
                                            import requests
                                            # API Endpoint
                                            URL = "https://sandboxapi.opaycheckout.com/api/v1/international/payment/create"

                                            # defining a params dict for the parameters to be sent to the API
                                            PaymentData = {
                                                'reference'    : '12312321324',
                                                'amount': {
                                                    "total": '400',
                                                    "currency": 'EGP',
                                                },
                                                'product': {
                                                    "name": 'Iphone X',
                                                    "description": 'xxxxxxxxxxxxxxxxx',
                                                },
                                                'callbackUrl'  : 'your callbackUrl',
                                                'country' : 'EG',
                                                'expireAt' : ':30',
                                                'payMethod' : 'MWALLET',
                                                'walletAccount':'01066668888',
                                                'userInfo': {
                                                        "userName": 'your customer name',
                                                        "userMobile": '201312312xxx',
                                                        "userEmail": 'xxx@xxx.com',
                                                },
                                            }
                                            # sending post request and saving the response as response object
                                            status_request = requests.post(url = URL, params = json.dumps(PaymentData))

                                            # extracting data in json format
                                            status_response = status_request.json()
                                        
                                    
                                        
                                            const request = require('request');
                                            var sha512 = require('js-sha512');
                                            const formData = {
                                                "amount":{
                                                    "currency":"EGP",
                                                    "total":400
                                                },
                                                "callbackUrl":"https://your-call-back-url.com",
                                                "country":"EG",
                                                "payMethod":"MWALLET",
                                                "product":{
                                                    "description":"description",
                                                    "name":"product-name-one"
                                                },
                                                "reference":"04122345678964",
                                                "userInfo":{
                                                    "userEmail":"customer@email.com",
                                                    "userMobile":"201066668888",
                                                    "userName":"OPay Test Name"
                                                },
                                                "walletAccount":"01066668888"
                                            };

                                            var privateKey = "OPAYPRV*******0187828"

                                            var hash = sha512.hmac.create(privateKey);
                                            hash.update(JSON.stringify(formData));
                                            hmacsignature = hash.hex();
                                            console.log(hmacsignature)
                                            request({
                                                url: 'https://sandboxapi.opaycheckout.com/api/v1/international/payment/create',
                                                method: 'POST',
                                                headers: {
                                                  'MerchantId': '256621051120756',
                                                  'Authorization': 'Bearer '+hmacsignature
                                                },
                                                json: true,
                                                body: formData
                                              }, function (error, response, body) {
                                                console.log('body: ')
                                                console.log(body)
                                              }
                                            )

                                        
                                    
                                        
                                            curl --location --request POST 'https://sandboxapi.opaycheckout.com/api/v1/international/payment/create' \
                                            --header 'MerchantId: 256621051120756' \
                                            --header 'Authorization: Bearer 38017496e*******2ab0297d1de8905cb7d85a043d9084254e61a8da6093b6f155550ff51891dca9f9889a' \
                                            --header 'Content-Type: application/json' \
                                            --data-raw '{
                                                "amount":{
                                                    "currency":"EGP",
                                                    "total":400
                                                },
                                                "callbackUrl":"https://your-call-back-url.com",
                                                "country":"EG",
                                                "payMethod":"MWALLET",
                                                "product":{
                                                    "description":"description",
                                                    "name":"name"
                                                },
                                                "reference":"041233981111",
                                                "userInfo":{
                                                    "userEmail":"customer@email.com",
                                                    "userMobile":"201066668888",
                                                    "userName":"OPay Test Name"
                                                    },
                                                "walletAccount":"01066668888"
                                            }'
                                        
                                    
                                    
                                        import com.google.gson.Gson;
                                        import org.apache.commons.codec.binary.Hex;
                                        import javax.crypto.Mac;
                                        import javax.crypto.spec.SecretKeySpec;
                                        import java.io.BufferedReader;
                                        import java.io.InputStreamReader;
                                        import java.io.OutputStream;
                                        import java.net.HttpURLConnection;
                                        import java.net.URL;
                                        import java.nio.charset.StandardCharsets;
                                        import java.util.TreeMap;
                                        import java.util.UUID;

                                        public class Mwallet {

                                            private static final String privateKey = "OPAYPRV*******0187828";

                                            private static final String endpoint = "https://sandboxapi.opaycheckout.com";

                                            private static final String merchantId = "256621051120756";

                                            public static void main(String[] args) throws Exception {
                                                String addr = endpoint + "/api/v1/international/payment/create";
                                                Gson gson = new Gson();
                                                TreeMap order = new TreeMap<>();
                                                TreeMap amount = new TreeMap<>();
                                                amount.put("currency","EGP");
                                                amount.put("total",new Integer(400));
                                                order.put("amount",amount);
                                                order.put("callbackUrl","https://your-call-back-url.com");
                                                order.put("country","EG");
                                                order.put("payMethod","MWALLET");
                                                TreeMap product = new TreeMap<>();
                                                product.put("description","description");
                                                product.put("name","name");
                                                order.put("product",product);
                                                order.put("reference", UUID.randomUUID().toString());
                                                TreeMap userInfo = new TreeMap<>();
                                                userInfo.put("userEmail","customer@email.com");
                                                userInfo.put("userMobile","201066668888");
                                                userInfo.put("userName","OPay Test Name");
                                                order.put("userInfo",userInfo);
                                                order.put("walletAccount","01066668888");

                                                String requestBody = gson.toJson(order);
                                                System.out.println("--request:");
                                                System.out.println(requestBody);
                                                String oPaySignature = hmacSHA512(requestBody, privateKey);
                                                System.out.println("--signature:");
                                                System.out.println(oPaySignature);

                                                URL url = new URL(addr);
                                                HttpURLConnection con = (HttpURLConnection)url.openConnection();
                                                con.setRequestMethod("POST");
                                                con.setRequestProperty("Content-Type", "application/json; utf-8");
                                                con.setRequestProperty("Authorization", "Bearer "+oPaySignature);
                                                con.setRequestProperty("MerchantId", merchantId);
                                                con.setDoOutput(true);
                                                OutputStream os = con.getOutputStream();
                                                byte[] input = requestBody.getBytes(StandardCharsets.UTF_8);
                                                os.write(input, 0, input.length);
                                                BufferedReader br = new BufferedReader(new InputStreamReader(con.getInputStream(), StandardCharsets.UTF_8));
                                                StringBuilder response = new StringBuilder();
                                                String responseLine = null;
                                                while ((responseLine = br.readLine()) != null) {
                                                    response.append(responseLine.trim());
                                                }

                                                System.out.println("--response:");
                                                System.out.println(response.toString());
                                                //close your stream and connection
                                            }

                                            public static String hmacSHA512(final String data, final String secureKey) throws Exception{
                                                byte[] bytesKey = secureKey.getBytes();
                                                final SecretKeySpec secretKey = new SecretKeySpec(bytesKey, "HmacSHA512");
                                                Mac mac = Mac.getInstance("HmacSHA512");
                                                mac.init(secretKey);
                                                final byte[] macData = mac.doFinal(data.getBytes());
                                                byte[] hex = new Hex().encode(macData);
                                                return new String(hex, StandardCharsets.UTF_8);
                                            }
                                        }

                                    
                                
                                    
                                        using System;
                                        using System.IO;
                                        using System.Linq;
                                        using System.Net;
                                        using System.Text;
                                        using Newtonsoft.Json;
                                        namespace OPayRequest
                                        {
                                            public class Program
                                            {
                                                static void Main(string[] args)
                                                {
                                                    PostJson("https://sandboxapi.opaycheckout.com/api/v1/international/payment/create", new opay_request
                                                    {
                                                        reference    = '12312321324',
                                                        amount= {
                                                            "total"= '400',
                                                            "currency"= 'EGP',
                                                        },
                                                        product= {
                                                            "name"= 'Iphone X',
                                                            "description"= 'xxxxxxxxxxxxxxxxx',
                                                        },
                                                        callbackUrl  = 'your callbackUrl',
                                                        country = 'EG';
                                                        expireAt = ':30';
                                                        merchantName = 'your merchant name';
                                                        payMethod = 'MWALLET';
                                                        walletAccount = '01066668888';
                                                        userInfo = {
                                                                    "userName": 'your customer name',
                                                                    "userMobile": '201312312xxx',
                                                                    "userEmail": 'xxx@xxx.com',
                                                            },
                                                    });
                                                }

                                                private static void PostJson(string uri, opay_request postParameters)
                                                {
                                                    string postData = JsonConvert.SerializeObject(postParameters);
                                                    byte[] bytes = Encoding.UTF8.GetBytes(postData);
                                                    var httpWebRequest = (HttpWebRequest) WebRequest.Create(uri);
                                                    httpWebRequest.Method = "POST";
                                                    httpWebRequest.ContentLength = bytes.Length;
                                                    httpWebRequest.ContentType = "text/json";
                                                    using (Stream requestStream = httpWebRequest.GetRequestStream())
                                                    {
                                                        requestStream.Write(bytes, 0, bytes.Count());
                                                    }
                                                    var httpWebResponse = (HttpWebResponse) httpWebRequest.GetResponse();
                                                    if (httpWebResponse.StatusCode != HttpStatusCode.OK)
                                                    {
                                                        string message = String.Format("GET failed. Received HTTP {0}", httpWebResponse.StatusCode);
                                                        throw new ApplicationException(message);
                                                    }
                                                }
                                            }

                                            public class opay_request
                                            {
                                                public string reference { get; set; }
                                                public string callbackUrl { get; set; }
                                                public string expireAt { get; set; }
                                                public string country { get; set; }
                                                public string expireAt { get; set; }
                                                public string merchantName { get; set; }
                                                public string payMethod { get; set; }
                                                public string walletAccount { get; set; }
                                                public product product;
                                                public amount amount;
                                                public userInfo userInfo;

                                            }
                                            public class amount
                                            {
                                                 public string total { get; set; }
                                                 public string currency { get; set; }
                                            }
                                        public class product
                                            {
                                                 public string name { get; set; }
                                                 public string description { get; set; }
                                            }
                                        public class userInfo
                                            {
                                                 public string userName { get; set; }
                                                 public string userEmail { get; set; }
                                                 public string userMobile { get; set; }
                                            }
                                        }

                                    
                                

E-Wallet Payment Response

-Response Parameters:

the parameters contained in the response received whenever you call the E-Wallet payment API as a JSON Object.

                    
                        {
                            "code": "00000",
                            "message": "SUCCESSFUL",
                            "data": {
                                "reference": "202111300001",
                                "orderNo": "211130144654879720",
                                "nextAction": {
                                    "actionType": "SCAN_QR_CODE",
                                    "qrCode":"…="
                                },
                                "status": "PENDING",
                                "amount": {
                                    "total": 0,
                                    "currency": "EGP"
                                },
                                "vat": {
                                    "total": 0,
                                    "currency": "EGP"
                                }
                            }
                        }

                    
                

-Here is a detailed description for the parameters received in the response:

Parameter type Description example
reference String The unique merchant payment order number. 202111300001
orderNo String OPay transaction number 211130148131809099
nextAction
Json Object
actionType String The next action type.Waiting for customer scan QR code SCAN_QR_CODE
qrCode String The QR code formatted in ISO. "0002010102120216…"
status String E-Wallet order status PENDING
amount
Json Object
total Long Transaction amount 1000 (cent unit)
currency String currency type. EGP
vat
Json Object
total String Value Added Tax Amount 0
currency String currency type. EGP

Error Handling

After submitting an API call to OPay, you receive a response back to inform you that your request was received and processed. A successful OPay API should return a status code 00, meanwhile, in a situation where any payment processing error occurred, you will receive an error code with a message to describe the reason of the error. A sample error response can be found below.

                                
                                    {
                                        "code": "20000",
                                        "message": "Duplicate merchant order number",
                                        "data": null
                                    }
                                
                            

Depending on the HTTP status code of the response, you should build some logic to handle any errors that a request or the system may return. A list of possible potential error codes that you may receive can be found below. A full list of all possible error codes can be found in the Error Codes section.

Error Code Error Message
02000 Time out.
02001 authentication failed.
50003 request parameters not valid.

What's Next?

User Profile 12 messages

James Jones
Application Developer
Recent Notifications
Another purpose persuade Due in 2 Days
+28%
Would be to people Due in 2 Days
+50%
-27%
The best product Due in 2 Days
+8%