public void ReceiptInResponseSuccess() { string rawRealexResponse = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" + "<response timestamp=\"20160701060517\">" + " <merchantid>unittest</merchantid>" + " <account>theheightsrec</account>" + " <orderid>f20c8e3d-31b9-4164-a7a5-f1685665b574</orderid>" + " <authcode>005804</authcode>" + " <result>00</result>" + " <cvnresult>U</cvnresult>" + " <avspostcoderesponse>U</avspostcoderesponse>" + " <avsaddressresponse>U</avsaddressresponse>" + " <batchid>2126483</batchid>" + " <message>AUTH CODE:005804</message>" + " <pasref>14673495159568662</pasref>" + " <timetaken>1</timetaken>" + " <authtimetaken>0</authtimetaken>" + " <cardissuer>" + " <bank>HSBC</bank>" + " <country>UNITED KINGDOM</country>" + " <countrycode>GB</countrycode>" + " <region>EUR</region>" + " </cardissuer>" + " <sha1hash>d2bd3d3f6bd4736d03f285e11f1728cd722fae99</sha1hash>" + " </response>"; ReceiptInResponse parsedResponse = RealAuthResponseParser <ReceiptInResponse> .DeserializeFromString(rawRealexResponse, System.Net.HttpStatusCode.OK, null); Assert.IsNotNull(parsedResponse); Assert.AreEqual("20160701060517", parsedResponse.Timestamp); Assert.AreEqual("unittest", parsedResponse.MerchantId); Assert.AreEqual("theheightsrec", parsedResponse.Account); Assert.AreEqual("f20c8e3d-31b9-4164-a7a5-f1685665b574", parsedResponse.OrderId); Assert.AreEqual("005804", parsedResponse.AuthCode); Assert.AreEqual("00", parsedResponse.ResultString); Assert.AreEqual(0, parsedResponse.Result); Assert.AreEqual("U", parsedResponse.CvnResult); Assert.AreEqual("U", parsedResponse.AvsPostcodeResponse); Assert.AreEqual("U", parsedResponse.AvsAddressResponse); Assert.AreEqual("2126483", parsedResponse.BatchId); Assert.AreEqual("AUTH CODE:005804", parsedResponse.Message); Assert.AreEqual("14673495159568662", parsedResponse.PasRef); Assert.AreEqual("1", parsedResponse.TimeTaken); Assert.AreEqual("0", parsedResponse.AuthTimeTaken); // Assert.IsNotNull(parsedResponse.CardIssuer, "CardIssuer"); // Assert.AreEqual("HSBC", parsedResponse.CardIssuer.Bank); // Assert.AreEqual("UNITED KINGDOM", parsedResponse.CardIssuer.Country); // Assert.AreEqual("GBC", parsedResponse.CardIssuer.CountryCode); // Assert.AreEqual("EUR", parsedResponse.CardIssuer.Region); Assert.AreEqual("d2bd3d3f6bd4736d03f285e11f1728cd722fae99", parsedResponse.Sha1Hash); string secretKey = "test1234"; string correctExpectedHash = parsedResponse.CalculateExpectedSha1Hash(secretKey); Assert.AreEqual(correctExpectedHash, parsedResponse.Sha1Hash, "SHA signature"); Assert.IsTrue(parsedResponse.IsSha1HashCorrect(secretKey)); Assert.IsFalse(parsedResponse.IsSha1HashCorrect("wrongkey"), "expected mismatch Sha1Hash if the wrong key is used"); }
/// <remarks> /// Wraps calls to Realex's ReceiptIn API function /// </remarks> public async Task <ReceiptInResponse> RealexReceiptIn( PaymentProviderConfiguration configuration, string realexPayerRef, decimal amount, string subAccount, string cardName, RealexTssInfo additionalInfo, IEnumerable <string> optionalComments) { ReceiptInRequest req = new ReceiptInRequest( merchantId: configuration.AccountIdentifer, payerRef: realexPayerRef, paymentMethod: cardName, amount: amount); req.Account = subAccount; if (RealEx.Default.RealVaultRemoteUrl.ToLower().Contains("sandbox")) { req.Account = req.Account + "test"; } req.Comments = RealexComment.CreateCommentList(optionalComments); if (null != additionalInfo) { additionalInfo.TruncateAndStripDisallowed(); req.TssInfo = additionalInfo; } ReceiptInResponse response = await PostXmlToRealex <ReceiptInResponse, ReceiptInRequest>( req, configuration.SharedSecret, logLevelForSuccess : LogLevel.Audit); return(response); }