Skip to content

Commit

Permalink
Merge pull request #42 from slogsdon/master
Browse files Browse the repository at this point in the history
fix incompatibility with certain browser extensions
  • Loading branch information
securesubmit-buildmaster authored Aug 25, 2022
2 parents fd2c30a + 511c5ff commit 80cc3c2
Show file tree
Hide file tree
Showing 8 changed files with 371 additions and 25 deletions.
171 changes: 161 additions & 10 deletions dist/rxp-js.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/*! rxp-js - v1.5.0 - 2021-07-27
/*! rxp-js - v1.5.1 - 2021-09-07
* The official Realex Payments JS Library
* https://github.com/realexpayments/rxp-js
* Licensed MIT
Expand Down Expand Up @@ -49,8 +49,16 @@ var RealexHpp = (function () {

var redirectUrl;

/**
* Shared functionality across lightbox, embedded, and redirect display modes.
*/
var internal = {
evtMsg: [],
/**
* Adds a new window message event listener and tracks it for later removal
*
* @param {Function} evtMsgFct
*/
addEvtMsgListener: function(evtMsgFct) {
this.evtMsg.push({ fct: evtMsgFct, opt: false });
if (window.addEventListener) {
Expand All @@ -59,6 +67,9 @@ var RealexHpp = (function () {
window.attachEvent('message', evtMsgFct);
}
},
/**
* Removes a previously set window message event listener
*/
removeOldEvtMsgListener: function () {
if (this.evtMsg.length > 0) {
var evt = this.evtMsg.pop();
Expand All @@ -69,6 +80,9 @@ var RealexHpp = (function () {
}
}
},
/**
* Shimmed base64 encode/decode support
*/
base64:{
encode:function(input) {
var keyStr = "ABCDEFGHIJKLMNOP" +
Expand Down Expand Up @@ -159,10 +173,26 @@ var RealexHpp = (function () {
return unescape(output);
}
},
/**
* Converts an HPP message to a developer-friendly version.
*
* The decode process has two steps:
*
* 1. Attempt to parse the string as JSON. If this fails, an error response
* is provided as we expect that the HPP has errored out to the cardholder
* 2. Attempt to base64 decode the data to cover both HPP versions 1 and 2.
*
* @param {any} answer
* @returns null if answer is not a string, otherwise the data from the HPP
*/
decodeAnswer:function(answer){ //internal.decodeAnswer

var _r;

if (typeof answer !== "string") {
return null;
}

try {
_r=JSON.parse(answer);
} catch (e) {
Expand All @@ -178,6 +208,13 @@ var RealexHpp = (function () {
} catch (e) { /** */ }
return _r;
},
/**
* Creates a new input of type `hidden`. Does not append to DOM.
*
* @param {string} name Name for the new input
* @param {string} value Value for the new input
* @returns the created input
*/
createFormHiddenInput: function (name, value) {
var el = document.createElement("input");
el.setAttribute("type", "hidden");
Expand All @@ -186,6 +223,11 @@ var RealexHpp = (function () {
return el;
},

/**
* Determines a mobile device's orientation for width calculation
*
* @returns true if in landscape
*/
checkDevicesOrientation: function () {
if (window.orientation === 90 || window.orientation === -90) {
return true;
Expand All @@ -194,6 +236,12 @@ var RealexHpp = (function () {
}
},

/**
* Creates a semi-transparent overlay with full width/height to serve as
* a background for the lightbox modal
*
* @returns the created overlay
*/
createOverlay: function () {
var overlay = document.createElement("div");
overlay.setAttribute("id", "rxp-overlay-" + randomId);
Expand Down Expand Up @@ -221,6 +269,14 @@ var RealexHpp = (function () {
return overlay;
},

/**
* Closes a lightbox modal and all associated elements
*
* @param {HTMLImageElement} closeButton
* @param {HTMLIFrameElement} iFrame
* @param {HTMLImageElement} spinner
* @param {HTMLDivElement} overlayElement
*/
closeModal: function (closeButton, iFrame, spinner, overlayElement) {
if (closeButton && closeButton.parentNode) {
closeButton.parentNode.removeChild(closeButton);
Expand All @@ -246,6 +302,11 @@ var RealexHpp = (function () {
}, 300);
},

/**
* Creates a close button for the lightbox modal
*
* @returns the created element
*/
createCloseButton: function (overlayElement) {
if (document.getElementById("rxp-frame-close-" + randomId) !== null) {
return;
Expand All @@ -272,6 +333,19 @@ var RealexHpp = (function () {
return closeButton;
},

/**
* Creates a form and appends the HPP request data as hidden input elements to
* POST to the defined HPP URL.
*
* The created form is not appended to the DOM and is not submitted at this time.
*
* @param {Document} doc
* @param {object} token HPP request data
* @param {bool} ignorePostMessage If true, the HPP will redirect to the defined
* defined redirect URL. If false, the HPP will send a postMessage
* to the parent window to be handled by this library.
* @returns the created form
*/
createForm: function (doc, token, ignorePostMessage) {
var form = document.createElement("form");
form.setAttribute("method", "POST");
Expand Down Expand Up @@ -302,6 +376,12 @@ var RealexHpp = (function () {
return form;
},

/**
* Creates a visual spinner element to be shown with the lightbox overlay while the
* HPP's iframe loads
*
* @returns the created spinner element
*/
createSpinner: function () {
var spinner = document.createElement("img");
spinner.setAttribute("src", "");
Expand All @@ -317,6 +397,14 @@ var RealexHpp = (function () {
return spinner;
},

/**
* Creates the HPP's form, spinner, iframe, and close button, appends them
* to the DOM, and submits the form to load the HPP
*
* @param {HTMLDivElement} overlayElement
* @param {object} token The HPP request data
* @returns an object with the created spinner, iframe, and close button
*/
createIFrame: function (overlayElement, token) {
//Create the spinner
var spinner = internal.createSpinner();
Expand Down Expand Up @@ -397,6 +485,18 @@ var RealexHpp = (function () {
};
},

/**
* Opens the HPP in a new window
*
* Used in some mobile scenarios or when the browser viewport is
* smaller than the HPP's inner width.
*
* Will automatically post the request data to the defined HPP
* URL to load the HPP.
*
* @param {object} token The HPP request data
* @returns the created window
*/
openWindow: function (token) {
//open new window
var tabWindow = window.open();
Expand Down Expand Up @@ -427,28 +527,71 @@ var RealexHpp = (function () {
return tabWindow;
},

/**
* Creates a rudimentary URL parser using an anchor element
*
* @param {string} url
* @returns the created anchor element
*/
getUrlParser: function (url) {
var parser = document.createElement('a');
parser.href = url;
return parser;
},

/**
* Gets the hostname/origin from a URL. Used for origin checks
*
* @param {string} url
* @returns the hostname/origin of the URL
*/
getHostnameFromUrl: function (url) {
return internal.getUrlParser(url).hostname;
return internal.getUrlParser(url).hostname;
},

/**
* Compares the origins from both arguments to validate we have received a postMessage
* from the expected source
*
* @param {string} origin The origin attached to the recieved message
* @param {string} hppUrl Our expected source origin
* @returns true if the origins match
*/
isMessageFromHpp: function (origin, hppUrl) {
return internal.getHostnameFromUrl(origin) === internal.getHostnameFromUrl(hppUrl);
},

/**
* Handles messages from the HPP
*
* Messages from the HPP are one of:
*
* - iframe resize event
* - transaction response
* - error information
*
* @param {MessageEvent} e
*/
receiveMessage: function (e) {
//Check the origin of the response comes from HPP
if (!internal.isMessageFromHpp(e.event.origin, hppUrl)) {
return;
}

if (!e.event.data) {
return;
}

var evtdata = internal.decodeAnswer(e.event.data);

// we received an invalid message from the HPP iframe (e.g. from a browser plugin)
// return early to prevent invalid processing
if (evtdata === null) {
return;
}

// check for iframe resize values
var evtdata;
if (e.event.data && (evtdata=internal.decodeAnswer(e.event.data)).iframe) {
if (evtdata.iframe) {
if (!isMobileNewTab()) {
var iframeWidth = evtdata.iframe.width;
var iframeHeight = evtdata.iframe.height;
Expand Down Expand Up @@ -514,9 +657,8 @@ var RealexHpp = (function () {
};
var response = e.event.data;
//allow the script to intercept the answer, instead of redirecting to another page. (which is really a 90s thing)
if(typeof e.url==='function'){
var answer=internal.decodeAnswer(response);
e.url(answer,_close);
if (typeof e.url === 'function'){
e.url(evtdata, _close);
return;
}
_close();
Expand All @@ -531,7 +673,9 @@ var RealexHpp = (function () {
}
};

// Initialising some variables used throughout this file.
/**
* Public interface for the lightbox display mode
*/
var RxpLightbox = (function () {
var instance;

Expand Down Expand Up @@ -610,7 +754,9 @@ var RealexHpp = (function () {
};
})();

// Initialising some variables used throughout this file.
/**
* Public interface for the embedded display mode
*/
var RxpEmbedded = (function () {
var instance;

Expand Down Expand Up @@ -689,6 +835,9 @@ var RealexHpp = (function () {
};
})();

/**
* Public interface for the redirect display mode
*/
var RxpRedirect = (function () {
var instance;

Expand Down Expand Up @@ -755,7 +904,9 @@ var RealexHpp = (function () {
};
}());

// RealexHpp
/**
* Public interface for the Realex HPP library
*/
return {
init: RxpLightbox.init,
lightbox: {
Expand Down
4 changes: 2 additions & 2 deletions dist/rxp-js.min.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion examples/hpp/process-a-payment-embedded-autoload.html
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
RealexHpp.embedded.init(
"autoload",
"targetIframe",
"https://dev.rlxcarts.com/mobileSDKsV2/response.php",
"/examples/hpp/response.php",
jsonFromServerSdk,
{
onResize:function(data){
Expand Down
2 changes: 1 addition & 1 deletion examples/hpp/process-a-payment-embedded.html
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
RealexHpp.embedded.init(
"payButtonId",
"targetIframe",
"https://dev.rlxcarts.com/mobileSDKsV2/response.php", // merchant url
"/examples/hpp/response.php", // merchant url
jsonFromServerSdk, // form data
{ // options
onResize:function(data){
Expand Down
2 changes: 1 addition & 1 deletion examples/hpp/process-a-payment-lightbox.html
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
$.getJSON("/examples/hpp/proxy-request.php?slug=process-a-payment", function (jsonFromServerSdk) {
RealexHpp.lightbox.init(
"payButtonId",
"https://dev.rlxcarts.com/mobileSDKsV2/response.php", // merchant url
"/examples/hpp/response.php", // merchant url
jsonFromServerSdk //form data
);
$('body').addClass('loaded');
Expand Down
Loading

0 comments on commit 80cc3c2

Please sign in to comment.