paypro: allow identification of root certs.

This commit is contained in:
Christopher Jeffrey 2014-07-24 17:23:06 -07:00
parent 078d85ea19
commit 0020e289d8
2 changed files with 336 additions and 163 deletions

View File

@ -24,28 +24,43 @@ var certUrl = 'https://raw.githubusercontent.com/joyent/node/master/src/node_roo
function getRootCerts(callback) {
return request(certUrl, function(err, res, body) {
if (err) return callback(err);
body = body.replace(/,$/, '');
body = 'var RootCerts = [\n' + body + '\n];\n';
body = body.replace(/,\s*$/, '');
body = 'var certs = {\n' + body + '\n};\n';
body = body.replace(/^"/gm, '+ "');
body = body.replace(/^\+ "-----B/gm, '"-----B');
body = body.replace(/\/\*([^*]+)\*\/\n(?=")/g, function(_, name) {
var key = name.trim();
return '// ' + key + '\n'
+ '"' + key + '":\n';
});
body += ''
+ '\n'
+ '// Use hash table for efficiency:\n'
+ 'RootCerts = RootCerts.reduce(function(trusted, cert) {\n'
+ ' cert = cert.replace(/\\s+/g, "");\n'
+ ' trusted[cert] = true;\n'
+ 'var trusted = Object.keys(certs).reduce(function(trusted, key) {\n'
+ ' var pem = certs[key];\n'
+ ' pem = pem.replace(/-----BEGIN CERTIFICATE-----/g, "");\n'
+ ' pem = pem.replace(/-----END CERTIFICATE-----/g, "");\n'
+ ' pem = pem.replace(/\\s+/g, "");\n'
+ ' trusted[pem] = key;\n'
+ ' return trusted;\n'
+ '}, {});\n'
+ '\n'
+ 'function isTrusted(pem) {\n'
+ ' pem = pem + "";\n'
+ ' pem = pem.replace(/-----BEGIN CERTIFICATE-----/g, "");\n'
+ ' pem = pem.replace(/-----END CERTIFICATE-----/g, "");\n'
+ ' pem = pem.replace(/\\s+/g, "");\n'
+ ' return !!RootCerts[pem];\n'
+ ' return certs[pem];\n'
+ '}\n'
+ '\n'
+ 'exports = RootCerts;\n'
+ 'function getCert(name) {\n'
+ ' return trusted[name.replace(/^\s+|\s+$/g, "")];\n'
+ '}\n'
+ '\n'
+ 'exports.certs = certs;\n'
+ 'exports.trusted = trusted;\n'
+ 'exports.isTrusted = isTrusted;\n'
+ 'module.exports = exports;\n';
+ 'exports.getCert = getCert;\n';
return callback(null, body);
});
}
@ -181,9 +196,14 @@ function main(argv, callback) {
callback = argv;
argv = null;
}
console.log('Retrieving root certs from: %s', certUrl);
return getRootCerts(function(err, certs) {
var file = path.resolve(__dirname, '..', 'lib', 'common', 'RootCerts.js');
return fs.writeFile(file, certs, callback);
return fs.writeFile(file, certs, function(err) {
if (err) return callback(err);
console.log('Root cert code generated at: %s.', file);
return callback();
});
});
}

File diff suppressed because it is too large Load Diff