UNPKG

cadesjs

Version:

CAdESjs gives you an ability to make CAdES signatures on pure JavaScript. The libray made with latest CAdES standards in mind

200 lines (187 loc) 5.84 kB
import * as asn1js from "asn1js"; import { getParametersValue } from "pvutils"; import { PolicyInformation } from "pkijs"; import OtherCertID from "./OtherCertID.js"; //************************************************************************************** // noinspection JSUnusedGlobalSymbols export default class OtherSigningCertificate { //********************************************************************************** /** * Constructor for OtherSigningCertificate class * @param {Object} [parameters={}] * @property {Object} [schema] asn1js parsed value */ constructor(parameters = {}) { //region Internal properties of the object /** * @type {Array.<OtherCertID>} * @description certs */ this.certs = getParametersValue(parameters, "certs", OtherSigningCertificate.defaultValues("certs")); if("policies" in parameters) /** * @type {Array.<PolicyInformation>} * @description policies */ this.policies = getParametersValue(parameters, "policies", OtherSigningCertificate.defaultValues("policies")); //endregion //region If input argument array contains "schema" for this object if("schema" in parameters) this.fromSchema(parameters.schema); //endregion } //********************************************************************************** /** * Return default values for all class members * @param {string} memberName String name for a class member */ static defaultValues(memberName) { switch(memberName) { case "certs": case "policies": return []; default: throw new Error(`Invalid member name for OtherSigningCertificate class: ${memberName}`); } } //********************************************************************************** /** * Compare values with default values for all class members * @param {string} memberName String name for a class member * @param {*} memberValue Value to compare with default value */ static compareWithDefault(memberName, memberValue) { switch(memberName) { case "certs": case "policies": return (memberValue.length === 0); default: throw new Error(`Invalid member name for OtherSigningCertificate class: ${memberName}`); } } //********************************************************************************** /** * Return value of asn1js schema for current class * @param {Object} parameters Input parameters for the schema * @returns {Object} asn1js schema object */ static schema(parameters = {}) { // OtherSigningCertificate ::= SEQUENCE { // certs SEQUENCE OF OtherCertID, // policies SEQUENCE OF PolicyInformation OPTIONAL // -- NOT USED IN THE PRESENT DOCUMENT } /** * @type {Object} * @property {string} [blockName] * @property {string} [type] * @property {string} [setName] * @property {string} [values] */ const names = getParametersValue(parameters, "names", {}); return (new asn1js.Sequence({ name: (names.blockName || ""), value: [ new asn1js.Sequence({ value: [ new asn1js.Repeated({ name: (names.certs || ""), value: OtherCertID.schema() }) ] }), new asn1js.Sequence({ value: [ new asn1js.Repeated({ name: (names.policies || ""), value: PolicyInformation.schema() }) ] }) ] })); } //********************************************************************************** /** * Convert parsed asn1js object into current class * @param {!Object} schema */ fromSchema(schema) { //region Check the schema is valid const asn1 = asn1js.compareSchema(schema, schema, OtherSigningCertificate.schema({ names: { certs: "certs", policies: "policies" } }) ); if(asn1.verified === false) throw new Error("Object's schema was not verified against input data for OtherSigningCertificate"); //endregion //region Get internal properties from parsed schema //region certs // noinspection JSUnusedGlobalSymbols this.certs = Array.from(asn1.result.certs, element => new OtherCertID({ schema: element })); //endregion //region policies if("policies" in asn1.result) this.policies = Array.from(asn1.result.policies, element => new PolicyInformation({ schema: element })); //endregion //endregion } //********************************************************************************** /** * Convert current object to asn1js object and set correct values * @returns {Object} asn1js object */ toSchema() { //region Create array for output sequence const outputArray = [ new asn1js.Sequence({ value: Array.from(this.certs, element => element.toSchema()) }) ]; //region policies if("policies" in this) { outputArray.push(new asn1js.Sequence({ value: Array.from(this.policies, element => element.toSchema()) })); } //endregion //endregion //region Construct and return new ASN.1 schema for this object return (new asn1js.Sequence({ value: outputArray })); //endregion } //********************************************************************************** /** * Convertion for the class to JSON object * @returns {Object} */ toJSON() { const _object = { certs: Array.from(this.certs, element => element.toJSON()) }; //region policies if("policies" in this) _object.policies = Array.from(this.policies, element => element.toJSON()); //endregion return _object; } //********************************************************************************** } //**************************************************************************************