Create a Config object and set API configuration parameters

Note that ipcApiUrl is different for sandbox and production environment

You can set RSA keys for request signatures by setting key content using loadPrivateKeyFromString and loadPublicKeyFromString or by setting file path using loadPrivateKeyFromFile and loadPublicKeyFromFile

For more information please refer to myPOS Checkout API Documentation

import java.net.MalformedURLException; 
import java.net.URL; 

import com.mypos.myposcheckout.ipc.Config; 
import com.mypos.myposcheckout.ipc.IPCException; 

// ... 

Config cnf = new Config(); 

URL ipcApiUrl = null; 
try { 
    ipcApiUrl = new URL("https://mypos.com/vmp/checkout-test/"); 
} catch (MalformedURLException ex) { 
    // Handle the malformed URL exception 
} 

cnf.setIpcUrl(ipcApiUrl); 
cnf.setLang("en"); 
cnf.loadPrivateKeyFromFile("path_to_directory/storePrivateKey.pem"); // Replace `path_to_directory` with the actual file path 
cnf.loadPublicKeyFromFile("path_to_directory/apiPublicKey.pem"); // Replace `path_to_directory` with the actual file path 
cnf.setKeyIndex(1); 
cnf.setSid("000000000000010"); 
cnf.setVersion("1.4"); 
cnf.setWalletNumber("61938166610");


Create a Refund object with the created Config object

import com.mypos.myposcheckout.ipc.request.Refund; 

// ... 

Refund refund = new Refund(cnf);


Set Refund parameters

import com.mypos.myposcheckout.ipc.enumerable.CommunicationFormat; 
import com.mypos.myposcheckout.ipc.enumerable.Currency; 

// ... 

refund.setAmount(10); 
refund.setCurrency(Currency.EUR); 
refund.setOrderId("123456"); 
refund.setTrnRef("654321"); 
refund.setOutputFormat(CommunicationFormat.XML);


Send Refund request

import com.mypos.myposcheckout.ipc.IPCException; 

// ... 

if (refund.process()) { 
    // Refund was successful! Do something. 
} else { 
    // Refund was not successful! Do something else. 
}