paypro: convert root certs to hash table in build file.

This commit is contained in:
Christopher Jeffrey 2014-07-17 17:20:03 -07:00
parent cc7657d843
commit 8725516afb
3 changed files with 17 additions and 21 deletions

View File

@ -14,10 +14,20 @@ pushd lib &> /dev/null
sed -i '$s/,$//g' RootCerts.js sed -i '$s/,$//g' RootCerts.js
echo "module.exports = ["$'\n'"$(cat RootCerts.js)" > RootCerts.js echo "var RootCerts = ["$'\n'"$(cat RootCerts.js)" > RootCerts.js
echo "];" >> RootCerts.js echo "];" >> RootCerts.js
sed -i 's/^"/+ "/g' RootCerts.js sed -i 's/^"/+ "/g' RootCerts.js
sed -i 's/^+ "-----B/"-----B/g' RootCerts.js sed -i 's/^+ "-----B/"-----B/g' RootCerts.js
cat <<EOF > RootCerts.js
// Use hash table for efficiency:
RootCerts = RootCerts.reduce(function(trusted, cert) {
cert = cert.replace(/\s+/g, '');
trusted[cert] = true;
return trusted;
}, {});
module.exports = RootCerts;
EOF
popd &> /dev/null popd &> /dev/null

View File

@ -3,14 +3,7 @@ var protobufjs = protobufjs || require('protobufjs/dist/ProtoBuf');
var Message = Message || require('./Message'); var Message = Message || require('./Message');
var KJUR = require('jsrsasign'); var KJUR = require('jsrsasign');
var Trusted = require('./RootCerts'); var RootCerts = require('./RootCerts');
// Use hash table for efficiency:
Trusted = Trusted.reduce(function(trusted, cert) {
cert = cert.replace(/\s+/g, '');
trusted[cert] = true;
return trusted;
}, {});
// BIP 70 - payment protocol // BIP 70 - payment protocol
function PayPro() { function PayPro() {
@ -227,7 +220,7 @@ PayPro.prototype.sign = function(key) {
var trusted = [].concat(pki_data).every(function(cert) { var trusted = [].concat(pki_data).every(function(cert) {
var der = cert.toString('hex'); var der = cert.toString('hex');
var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE'); var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE');
return !!Trusted[pem.replace(/\s+/g, '')]; return !!RootCerts[pem.replace(/\s+/g, '')];
}); });
if (!trusted) { if (!trusted) {
@ -272,7 +265,7 @@ PayPro.prototype.verify = function() {
var der = cert.toString('hex'); var der = cert.toString('hex');
var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE'); var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE');
if (!Trusted[pem.replace(/\s+/g, '')]) { if (!RootCerts[pem.replace(/\s+/g, '')]) {
// throw new Error('Unstrusted certificate.'); // throw new Error('Unstrusted certificate.');
} }

View File

@ -4,14 +4,7 @@ var Key = require('./Key');
var KJUR = require('./x509'); var KJUR = require('./x509');
var assert = require('assert'); var assert = require('assert');
var PayPro = require('../PayPro'); var PayPro = require('../PayPro');
var Trusted = require('../RootCerts'); var RootCerts = require('../RootCerts');
// Use hash table for efficiency:
Trusted = Trusted.reduce(function(trusted, cert) {
cert = cert.replace(/\s+/g, '');
trusted[cert] = true;
return trusted;
}, {});
PayPro.sign = function(key) { PayPro.sign = function(key) {
if (this.messageType !== 'PaymentRequest') if (this.messageType !== 'PaymentRequest')
@ -32,7 +25,7 @@ PayPro.sign = function(key) {
var trusted = [].concat(pki_data).every(function(cert) { var trusted = [].concat(pki_data).every(function(cert) {
var der = cert.toString('hex'); var der = cert.toString('hex');
var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE'); var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE');
return !!Trusted[pem.replace(/\s+/g, '')]; return !!RootCerts[pem.replace(/\s+/g, '')];
}); });
if (!trusted) { if (!trusted) {
@ -82,7 +75,7 @@ PayPro.verify = function() {
var der = cert.toString('hex'); var der = cert.toString('hex');
var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE'); var pem = KJUR.asn1.ASN1Util.getPEMStringFromHex(der, 'CERTIFICATE');
if (!Trusted[pem.replace(/\s+/g, '')]) { if (!RootCerts[pem.replace(/\s+/g, '')]) {
// throw new Error('Unstrusted certificate.'); // throw new Error('Unstrusted certificate.');
} }