diff --git a/lib/PayPro.js b/lib/PayPro.js index 4812f14..5a073c3 100644 --- a/lib/PayPro.js +++ b/lib/PayPro.js @@ -11,6 +11,8 @@ PayPro.prototype.x509Sign = function(key) { var crypto = require('crypto'); var pki_type = this.get('pki_type'); var pki_data = this.get('pki_data'); // contains one or more x509 certs + pki_data = PayPro.X509Certificates.decode(pki_data); + pki_data = pki_data.certificate; var details = this.get('serialized_payment_details'); var type = pki_type.split('+')[1].toUpperCase(); @@ -38,6 +40,8 @@ PayPro.prototype.x509Verify = function() { var pki_type = this.get('pki_type'); var sig = this.get('signature'); var pki_data = this.get('pki_data'); + pki_data = PayPro.X509Certificates.decode(pki_data); + pki_data = pki_data.certificate; var details = this.get('serialized_payment_details'); var buf = this.serializeForSig(); var type = pki_type.split('+')[1].toUpperCase(); diff --git a/lib/browser/PayPro.js b/lib/browser/PayPro.js index 253d6ba..e41a8e0 100644 --- a/lib/browser/PayPro.js +++ b/lib/browser/PayPro.js @@ -13,6 +13,8 @@ var RootCerts = require('../common/RootCerts'); PayPro.prototype.x509Sign = function(key) { var pki_type = this.get('pki_type'); var pki_data = this.get('pki_data'); // contains one or more x509 certs + pki_data = PayPro.X509Certificates.decode(pki_data); + pki_data = pki_data.certificate; var type = pki_type.split('+')[1].toUpperCase(); var buf = this.serializeForSig(); @@ -51,6 +53,8 @@ PayPro.prototype.x509Verify = function(key) { var sig = this.get('signature'); var pki_type = this.get('pki_type'); var pki_data = this.get('pki_data'); + pki_data = PayPro.X509Certificates.decode(pki_data); + pki_data = pki_data.certificate; var buf = this.serializeForSig(); var type = pki_type.split('+')[1].toUpperCase(); diff --git a/test/test.PayPro.js b/test/test.PayPro.js index dd943ed..70969c5 100644 --- a/test/test.PayPro.js +++ b/test/test.PayPro.js @@ -353,7 +353,13 @@ describe('PayPro', function() { paypro.makePaymentRequest(); paypro.set('serialized_payment_details', pdbuf); paypro.set('pki_type', 'x509+sha256'); - paypro.set('pki_data', x509.der); + + var cr = new PayPro(); + cr = cr.makeX509Certificates(); + cr.set('certificate', [x509.der]); + + paypro.set('pki_data', cr.serialize()); // contains one or more x509 certs + paypro.sign(x509.priv); x509.sig1 = paypro.get('signature'); x509.sig1.length.should.be.greaterThan(0); @@ -388,7 +394,13 @@ describe('PayPro', function() { paypro.set('serialized_payment_details', pdbuf); paypro.set('pki_type', 'x509+sha256'); paypro.set('signature', x509.sig1); // sig buffer - paypro.set('pki_data', x509.der); // contains one or more x509 certs + + var cr = new PayPro(); + cr = cr.makeX509Certificates(); + cr.set('certificate', [x509.der]); + + paypro.set('pki_data', cr.serialize()); // contains one or more x509 certs + var verify = paypro.verify(); verify.should.equal(true); }); @@ -446,7 +458,12 @@ describe('PayPro', function() { paypro.set('serialized_payment_details', pdbuf); paypro.set('pki_type', 'x509+sha256'); - paypro.set('pki_data', x509.der); + + var cr = new PayPro(); + cr = cr.makeX509Certificates(); + cr.set('certificate', [x509.der]); + + paypro.set('pki_data', cr.serialize()); // contains one or more x509 certs var sig = paypro.x509Sign(x509.priv); paypro.set('signature', sig); @@ -470,7 +487,12 @@ describe('PayPro', function() { paypro.set('pki_type', 'x509+sha256'); paypro.set('signature', x509.sig2); // sig buffer - paypro.set('pki_data', x509.der); // contains one or more x509 certs + + var cr = new PayPro(); + cr = cr.makeX509Certificates(); + cr.set('certificate', [x509.der]); + + paypro.set('pki_data', cr.serialize()); // contains one or more x509 certs var verify = paypro.x509Verify(); verify.should.equal(true); @@ -489,7 +511,12 @@ describe('PayPro', function() { paypro.set('serialized_payment_details', pdbuf); paypro.set('pki_type', 'x509+sha1'); - paypro.set('pki_data', x509.der); + + var cr = new PayPro(); + cr = cr.makeX509Certificates(); + cr.set('certificate', [x509.der]); + + paypro.set('pki_data', cr.serialize()); // contains one or more x509 certs var sig = paypro.x509Sign(x509.priv); paypro.set('signature', sig); @@ -513,7 +540,12 @@ describe('PayPro', function() { paypro.set('pki_type', 'x509+sha1'); paypro.set('signature', x509.sig3); // sig buffer - paypro.set('pki_data', x509.der); // contains one or more x509 certs + + var cr = new PayPro(); + cr = cr.makeX509Certificates(); + cr.set('certificate', [x509.der]); + + paypro.set('pki_data', cr.serialize()); // contains one or more x509 certs var verify = paypro.x509Verify(); verify.should.equal(true);