I'm getting a 550 error in the Chrome network monitor. It was working earlier today.
XMLHttpRequest cannot load https://apitest.authorize.net/xml/v1/request.api. Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'https://localhost:5000' is therefore not allowed access. The response had HTTP status code 550.
Here's the extract Curl command
curl "https://apitest.authorize.net/xml/v1/request.api" -X OPTIONS -H "Pragma: no-cache" -H "Access-Control-Request-Method: POST" -H "Origin: https://localhost:5000" -H "Accept-Encoding: gzip, deflate, sdch, br" -H "Accept-Language: en-US,en;q=0.8" -H "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36" -H "Accept: */*" -H "Cache-Control: no-cache" -H "Referer: https://localhost:5000/" -H "Connection: keep-alive" -H "Access-Control-Request-Headers: content-type" --compressed
is also showing 550
โ10-12-2016 11:29 AM
There's 3 things I'd like to see after the service is restored:
1) What happened? There was some event yesterday which caused the service to stop working. If there was an update there should be better notification and smoke testing to ensure us consumers aren't affected as well as reliable rollback procedures (A/B swtich, etc.).
2) Add better monitoring so excessive downtime can be avoided. Also add a service dashboard (e.g. http://open.concur.com/) for greater transparency.
3) Make sure that the JS 'responseHandler' callback function is called from Accept.dispatchData when ANY error happens so it can be notified there was a problem. For example in our application we are displaying a busy indicator until the call returns, which it never does because it eats the exception, so our application appears stuck in a loop.
We also have a critical hot fix that is delayed due to this.
Thanks
โ10-13-2016 08:40 AM
The issue has been resolved, and HTTP OPTIONS calls should return the appropriate CORS headers. We apologize for the inconvenience.
โ10-13-2016 11:43 AM
Our issue wasn't "accept.js" per se. It was generally that the sandbox was timing out for us suddenly. It is now working for us.
โ10-13-2016 12:13 PM
We have simply added https://jstest.authorize.net/v1/Accept.js in oue page and hit sendPaymentDataToAnet function. We have cheked if this function working or not with alert message and its working. After that we have set creditdata and authdata in secureData variable and also checked securedata variable with alert and all values set in this variable. But when it comes to execute function Accept.dispatchData(secureData, 'responseHandler'), it will give us above error i.e Uncaught TypeError: window[c] is not a function in https://jstest.authorize.net/v1/AcceptCore.js.
We haven't yet find this issue to be fixed.
Please fix this issue.
Thanks
โ10-14-2016 07:29 AM - edited โ10-14-2016 07:40 AM
@lovely
There is NOT a problem right now. It sounds like a programming error on your side. I would still like answers to the 3 issues I raised however
โ10-14-2016 08:32 AM
@lovey Here's a fully functional test you can use to verify it works. All you need to do is update the apiKey/publicKey (marked TODO in the code). This MUST be served from an HTTPS server to work (e.g. I used Node.js). Visit the page and hit Pay button and you will get a nonce displayed in alert and console.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Payment Screen using Accept.js POC</title>
<script src="jquery.min.js"></script>
<script src="https://jstest.authorize.net/v1/Accept.js"></script>
</head>
<body>
<div class="">
<fieldset>
<fieldset>
<label for="cardNumber">Card Number</label>
<input id="cardNumber" value="370000000000002"/>
<label for="securityCode">CVV/CVD</label>
<input id="securityCode" value="900"/>
</fieldset>
<fieldset>
<legend>Card Expiration</legend>
<input id="expirationMonth" value="08" />
<label for="expirationMonth">Month</label>
<input id="expirationYear" value="2022"/>
<label for="expirationYear">Year</label>
</fieldset>
</fieldset>
<button type="submit" onclick="sendPaymentDataToAnet()">Pay</button>
</div>
<script>
'use strict';
var config = {
apiLoginID: 'TODO',
clientKey: 'TODO'
};
function sendPaymentDataToAnet() {
var secureData = {}, authData = {}, cardData = {};
cardData.cardNumber = document.getElementById('cardNumber').value;
cardData.cardCode = document.getElementById('securityCode').value;
cardData.month = document.getElementById('expirationMonth').value;
cardData.year = document.getElementById('expirationYear').value;
secureData.cardData = cardData;
authData.clientKey = config.clientKey;
authData.apiLoginID = config.apiLoginID;
secureData.authData = authData;
Accept.dispatchData(secureData, 'responseHandler');
}
function responseHandler(response) {
if (response.messages.resultCode === 'Error') {
for (var i = 0; i < response.messages.message.length; i++) {
console.log(response.messages.message[i].code + ':' + response.messages.message[i].text);
}
} else {
useOpaqueData(response.opaqueData)
}
}
function useOpaqueData(responseData) {
// This is where you would set the data descriptor & data value to be posted back to your server
console.log(responseData.dataDescriptor);
console.log(responseData.dataValue);
alert(responseData.dataValue);
}
</script>
</body>
</html>
โ10-14-2016 08:36 AM
I just stumbled upon this:
However it is not accurate as there no mention of this outage.
โ10-14-2016 09:04 AM
Can you please comment out how responsehandler can be defined on ReactJS application
<form id="paymentForm" method="POST" action=""> <input type="hidden" name="dataValue" id="dataValue" /> <input type="hidden" name="dataDescriptor" id="dataDescriptor" /> <InputDiv id="proceed"> <Button type="button" id="paymentButton" className="AcceptUI" data-billingAddressOptions='{"show":true, "required":false}' data-apiLoginID={ process.env.REACT_APP_AUTHORIZE_NET_LOGIN_ID } data-clientKey={ process.env.REACT_APP_AUTHORIZE_NET_TRANSITION_KEY } data-acceptUIFormBtnTxt="Pay now" data-acceptUIFormHeaderTxt="Card Information" data-paymentOptions='{"showCreditCard": true, "showBankAccount": true}' data-responseHandler={(response) => { this.handleSendPaymentInformationToAuthorizeNet(response); }} > Proceed </Button> </InputDiv> </form>
handleSendPaymentInformationToAuthorizeNet = (response) => { console.log('response is', response); };
โ07-01-2019 10:46 PM