Last active
February 13, 2019 02:36
Revisions
-
Mozu-CS revised this gist
Feb 13, 2019 . 1 changed file with 0 additions and 172 deletions.There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,172 +0,0 @@ -
Mozu-CS renamed this gist
Feb 13, 2019 . 1 changed file with 0 additions and 0 deletions.There are no files selected for viewing
File renamed without changes. -
Mozu-CS revised this gist
Feb 13, 2019 . No changes.There are no files selected for viewing
-
Mozu-CS revised this gist
Feb 12, 2019 . No changes.There are no files selected for viewing
-
Mozu-CS revised this gist
Feb 12, 2019 . 2 changed files with 172 additions and 0 deletions.There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,172 @@ /** * Implementation for embedded.commerce.payments.action.before * This custom function will receive the following context object: { "exec": { "setActionAmount": { "parameters": [ { "name": "amount", "type": "number" } ], "return": { "type": "mozu.commerceRuntime.contracts.payments.paymentAction" } }, "setPaymentData": { "parameters": [ { "name": "key", "type": "string" }, { "name": "value", "type": "object" } ] }, "removePaymentData": { "parameters": [ { "name": "key", "type": "string" } ] }, "setActionPreAuthFlag": { "parameters": [ { "name": "isPreAuth", "type": "bool" } ] } }, "setPaymentTerm": { "parameters": [ { "name": "purchaseOrderPaymentTermObject", "type": "object" } ], "return": { "type": "mozu.commerceRuntime.contracts.payments.purchaseorderpaymentterm" } }, "get": { "payment": { "parameters": [], "return": { "type": "mozu.commerceRuntime.contracts.payments.payment" } }, "paymentAction": { "parameters": [], "return": { "type": "mozu.commerceRuntime.contracts.payments.paymentAction" } } } } */ var constants = require("../../constants"); var softdecline = require("../../softdecline"); var _ = require("underscore"); module.exports = function(context, callback) { var paymentAction = context.get.paymentAction(); var payment = context.get.payment(); var order = context.get.order(); var cardsFor1DollarAuth = context.configuration.cardType1$; console.log('entering softdecline.'); console.log("Payment Action", paymentAction); console.log("Payment", payment); console.log("Order", order); console.log("apiContext", context.apiContext); console.log("configuration", context.configuration); console.log("CardTypes", cardsFor1DollarAuth); var isStorefrontInitiated = context.get.isStorefrontInitiated(); console.log('isStorefrontInitiated = ' + isStorefrontInitiated); if (!isStorefrontInitiated) { console.log('This is not storefront initiated.'); return callback(); } if (!softdecline.isSoftDeclinePayment(payment, paymentAction)) { console.log('not a softdecline payment.'); return callback(); } if (!softdecline.shouldSoftDecline(payment)) { console.log('cannot softdecline because retries exceeded.'); return callback(); } var originalAuthAmount = softdecline.getOriginalAuthAmount(payment); if (!originalAuthAmount) { console.log('saving original authorize amount.'); context.exec.setPaymentData(constants.ORIGINAL_AUTH_AMOUNT_KEY, paymentAction.amount); } // set 1 dollar as the amount for Auth for cards other than Visa. Visa is 0 dollar. /*var authAmount =1; if (payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "AMEX" && payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "DISCOVER") { authAmount = 0; } */ var authAmount; if (cardsFor1DollarAuth.indexOf(payment.billingInfo.card.paymentOrCardType.toUpperCase()) > -1) { console.log('Performing $1 Auth'); authAmount = 1; console.log('Auth Amount : ', authAmount); } else { console.log('Not Performing $1 Auth'); authAmount = 0; } if (softdecline.getSoftDeclineCount(payment) >= 3) { console.log('setting original amount for auth.'); authAmount = softdecline.getOriginalAuthAmount(payment); // since this is no longer a pre auth, if it's the fourth time round. context.exec.setActionPreAuthFlag(false); } else { context.exec.setActionPreAuthFlag(true); } // testmode if (context.configuration && context.configuration.isTestMode && context.configuration.zeroDollarAuthAmount) { console.log('App is running in TestMode'); // in test mode, pass in the configured amount. if (softdecline.getSoftDeclineCount(payment) < 3) { authAmount = Number(context.configuration.zeroDollarAuthAmount); /*if (payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "AMEX" && payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "DISCOVER") { authAmount = authAmount + 1; }*/ if (cardsFor1DollarAuth.indexOf(payment.billingInfo.card.paymentOrCardType.toUpperCase()) > -1) { } else { authAmount = authAmount + 1; } } } console.log('setting auth amount to ' + authAmount); context.exec.setPaymentData(constants.PRE_AUTH_AMOUNT_KEY, authAmount); context.exec.setActionAmount(authAmount); context.exec.setPaymentData("DoSubscriptionAuth","true"); console.log('exiting softdecline.'); return callback(); }; File renamed without changes. -
Mozu-CS created this gist
Feb 8, 2019 .There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,172 @@ /** * Implementation for embedded.commerce.payments.action.before * This custom function will receive the following context object: { "exec": { "setActionAmount": { "parameters": [ { "name": "amount", "type": "number" } ], "return": { "type": "mozu.commerceRuntime.contracts.payments.paymentAction" } }, "setPaymentData": { "parameters": [ { "name": "key", "type": "string" }, { "name": "value", "type": "object" } ] }, "removePaymentData": { "parameters": [ { "name": "key", "type": "string" } ] }, "setActionPreAuthFlag": { "parameters": [ { "name": "isPreAuth", "type": "bool" } ] } }, "setPaymentTerm": { "parameters": [ { "name": "purchaseOrderPaymentTermObject", "type": "object" } ], "return": { "type": "mozu.commerceRuntime.contracts.payments.purchaseorderpaymentterm" } }, "get": { "payment": { "parameters": [], "return": { "type": "mozu.commerceRuntime.contracts.payments.payment" } }, "paymentAction": { "parameters": [], "return": { "type": "mozu.commerceRuntime.contracts.payments.paymentAction" } } } } */ var constants = require("../../constants"); var softdecline = require("../../softdecline"); var _ = require("underscore"); module.exports = function(context, callback) { var paymentAction = context.get.paymentAction(); var payment = context.get.payment(); var order = context.get.order(); var cardsFor1DollarAuth = context.configuration.cardType1$; console.log('entering softdecline.'); console.log("Payment Action", paymentAction); console.log("Payment", payment); console.log("Order", order); console.log("apiContext", context.apiContext); console.log("configuration", context.configuration); console.log("CardTypes", cardsFor1DollarAuth); var isStorefrontInitiated = context.get.isStorefrontInitiated(); console.log('isStorefrontInitiated = ' + isStorefrontInitiated); if (!isStorefrontInitiated) { console.log('This is not storefront initiated.'); return callback(); } if (!softdecline.isSoftDeclinePayment(payment, paymentAction)) { console.log('not a softdecline payment.'); return callback(); } if (!softdecline.shouldSoftDecline(payment)) { console.log('cannot softdecline because retries exceeded.'); return callback(); } var originalAuthAmount = softdecline.getOriginalAuthAmount(payment); if (!originalAuthAmount) { console.log('saving original authorize amount.'); context.exec.setPaymentData(constants.ORIGINAL_AUTH_AMOUNT_KEY, paymentAction.amount); } // set 1 dollar as the amount for Auth for cards other than Visa. Visa is 0 dollar. /*var authAmount =1; if (payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "AMEX" && payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "DISCOVER") { authAmount = 0; } */ var authAmount; if (cardsFor1DollarAuth.indexOf(payment.billingInfo.card.paymentOrCardType.toUpperCase()) > -1) { console.log('Performing $1 Auth'); authAmount = 1; console.log('Auth Amount : ', authAmount); } else { console.log('Not Performing $1 Auth'); authAmount = 0; } if (softdecline.getSoftDeclineCount(payment) >= 3) { console.log('setting original amount for auth.'); authAmount = softdecline.getOriginalAuthAmount(payment); // since this is no longer a pre auth, if it's the fourth time round. context.exec.setActionPreAuthFlag(false); } else { context.exec.setActionPreAuthFlag(true); } // testmode if (context.configuration && context.configuration.isTestMode && context.configuration.zeroDollarAuthAmount) { console.log('App is running in TestMode'); // in test mode, pass in the configured amount. if (softdecline.getSoftDeclineCount(payment) < 3) { authAmount = Number(context.configuration.zeroDollarAuthAmount); /*if (payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "AMEX" && payment.billingInfo.card.paymentOrCardType.toUpperCase() !== "DISCOVER") { authAmount = authAmount + 1; }*/ if (cardsFor1DollarAuth.indexOf(payment.billingInfo.card.paymentOrCardType.toUpperCase()) > -1) { } else { authAmount = authAmount + 1; } } } console.log('setting auth amount to ' + authAmount); context.exec.setPaymentData(constants.PRE_AUTH_AMOUNT_KEY, authAmount); context.exec.setActionAmount(authAmount); context.exec.setPaymentData("DoSubscriptionAuth","true"); console.log('exiting softdecline.'); return callback(); }; This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,202 @@ /** * Implementation for embedded.commerce.payments.action.after * This custom function will receive the following context object: { "exec": { "setActionAmount": { "parameters": [ { "name": "amount", "type": "number" } ], "return": { "type": "mozu.commerceRuntime.contracts.payments.paymentAction" } }, "setFailedStateName": { "parameters": [ { "name": "stateName", "type": "string" } ] }, "setSuccessFlag": { "parameters": [ { "name": "isSuccess", "type": "bool" } ] }, "setNewStateName": { "parameters": [ { "name": "stateName", "type": "string" } ] }, "setPaymentData": { "parameters": [ { "name": "key", "type": "string" }, { "name": "value", "type": "object" } ] }, "removePaymentData": { "parameters": [ { "name": "key", "type": "string" } ] }, "setRetryFlag": { "parameters": [ { "name": "shouldRetry", "type": "bool" } ] }, "setActionPreAuthFlag": { "parameters": [ { "name": "isPreAuth", "type": "bool" } ] } }, "get": { "payment": { "parameters": [], "return": { "type": "mozu.commerceRuntime.contracts.payments.payment" } }, "paymentAction": { "parameters": [], "return": { "type": "mozu.commerceRuntime.contracts.payments.paymentAction" } } } } */ var constants = require("../../constants"); var softdecline = require("../../softdecline"); var _ = require("underscore"); function gatewayInteractionIsSoftDecline(paymentInteraction) { var result = _.contains(constants.SOFTDECLINE_CODES, paymentInteraction.gatewayResponseCode); return result; } function clearSoftDeclineCount(context, payment) { if (payment.Data && _.has(payment.Data, constants.SOFTDECLINECOUNT_KEY)) { context.exec.removePaymentData(constants.SOFTDECLINECOUNT_KEY); } } function getLatestPaymentInteraction(payment) { var orderedPaymentInteractions = _.sortBy(payment.interactions, function(i) { return i.interactionDate; }); var latestPaymentInteraction = _.last(orderedPaymentInteractions); return latestPaymentInteraction; } module.exports = function(context, callback) { var paymentAction = context.get.paymentAction(); var payment = context.get.payment(); var order = context.get.order(); console.log("Payment Action", paymentAction); console.log("Payment", payment); console.log("Order", order); console.log("apiContext", context.apiContext); var isStorefrontInitiated = context.get.isStorefrontInitiated(); console.log('isStorefrontInitiated = ' + isStorefrontInitiated); if (!isStorefrontInitiated) { console.log('This is not storefront initiated.'); return callback(); } // not a soft decline payment type .. we don't do anything. if (!softdecline.isSoftDeclinePayment(payment, paymentAction)) { console.log('not a softdecline payment.'); return callback(); } var latestPaymentInteraction = getLatestPaymentInteraction(payment); // success, clear the softdecline count, and indicate we need a retry, with the original auth amount. if (latestPaymentInteraction.status.toUpperCase() === "AUTHORIZED") { console.log('interaction was AUTHORIZED, so nothing to do.'); clearSoftDeclineCount(context, payment); var preAuthAmount = (!payment.Data || !_.has(payment.Data, constants.PRE_AUTH_AMOUNT_KEY)) ? 0 : payment.Data[constants.PRE_AUTH_AMOUNT_KEY]; console.log('Pre auth amount was - ' + preAuthAmount); if (paymentAction.amount === preAuthAmount) { console.log('interaction amount was less than 1, so get the original auth amount.'); var originalAuthAmount = softdecline.getOriginalAuthAmount(payment); context.exec.setActionAmount(originalAuthAmount); context.exec.setRetryFlag(false); context.exec.setActionPreAuthFlag(false); } return callback(); } // hard decline, clear the softdecline count, nothing else to do. if (latestPaymentInteraction.status.toUpperCase() === "DECLINED" && !gatewayInteractionIsSoftDecline(latestPaymentInteraction)) { console.log('interaction was hard DECLINED, so nothing to do.'); clearSoftDeclineCount(context, payment); return callback(); } // soft decline. if (latestPaymentInteraction.status.toUpperCase() === "DECLINED" && gatewayInteractionIsSoftDecline(latestPaymentInteraction) && softdecline.shouldSoftDecline(payment)) { var retryCount = (!payment.Data || !_.has(payment.Data, constants.SOFTDECLINECOUNT_KEY)) ? 0 : payment.Data[constants.SOFTDECLINECOUNT_KEY]; var newRetryCount = retryCount + 1; context.exec.setPaymentData(constants.SOFTDECLINECOUNT_KEY, newRetryCount); // soft decline if (retryCount < constants.RETRYCOUNT) { console.log('interaction is a soft decline with retryCount=' + newRetryCount); context.exec.setFailedStateName("New"); return callback(); } // soft decline 4th time if (retryCount == constants.RETRYCOUNT) { console.log('interaction is a soft decline, but treating as a successful Auth.'); context.exec.setSuccessFlag(true); context.exec.setNewStateName("Authorized"); return callback(); } } context.exec.removePaymentData("DoSubscriptionAuth"); return callback(); };