node/lib/internal/crypto/certificate.js

54 lines
1.5 KiB
JavaScript

'use strict';
const {
certExportChallenge,
certExportPublicKey,
certVerifySpkac,
} = internalBinding('crypto');
const {
getArrayBufferOrView,
} = require('internal/crypto/util');
// The functions contained in this file cover the SPKAC format
// (also referred to as Netscape SPKI). A general description of
// the format can be found at https://en.wikipedia.org/wiki/SPKAC
function verifySpkac(spkac, encoding) {
return certVerifySpkac(
getArrayBufferOrView(spkac, 'spkac', encoding));
}
function exportPublicKey(spkac, encoding) {
return certExportPublicKey(
getArrayBufferOrView(spkac, 'spkac', encoding));
}
function exportChallenge(spkac, encoding) {
return certExportChallenge(
getArrayBufferOrView(spkac, 'spkac', encoding));
}
// The legacy implementation of this exposed the Certificate
// object and required that users create an instance before
// calling the member methods. This API pattern has been
// deprecated, however, as the method implementations do not
// rely on any object state.
// For backwards compatibility reasons, this cannot be converted into a
// ES6 Class.
function Certificate() {
if (!(this instanceof Certificate))
return new Certificate();
}
Certificate.prototype.verifySpkac = verifySpkac;
Certificate.prototype.exportPublicKey = exportPublicKey;
Certificate.prototype.exportChallenge = exportChallenge;
Certificate.exportChallenge = exportChallenge;
Certificate.exportPublicKey = exportPublicKey;
Certificate.verifySpkac = verifySpkac;
module.exports = Certificate;