import * as asn1js from "asn1js"; import * as pvutils from "pvutils"; import { KEKIdentifier, KEKIdentifierJson, KEKIdentifierSchema } from "./KEKIdentifier"; import { AlgorithmIdentifier, AlgorithmIdentifierJson, AlgorithmIdentifierSchema } from "./AlgorithmIdentifier"; import * as Schema from "./Schema"; import { PkiObject, PkiObjectParameters } from "./PkiObject"; import { AsnError } from "./errors"; import { EMPTY_BUFFER, EMPTY_STRING } from "./constants";
export type KEKRecipientInfoParameters = PkiObjectParameters & Partial<IKEKRecipientInfo>;
/** * Represents the KEKRecipientInfo structure described in [RFC5652](https://datatracker.ietf.org/doc/html/rfc5652)
*/
export class KEKRecipientInfo extends PkiObject implements IKEKRecipientInfo {
public version!: number; public kekid!: KEKIdentifier; public keyEncryptionAlgorithm!: AlgorithmIdentifier; public encryptedKey!: asn1js.OctetString; public preDefinedKEK!: ArrayBuffer;
/** * Initializes a new instance of the {@link KEKRecipientInfo} class * @param parameters Initialization parameters
*/
constructor(parameters: KEKRecipientInfoParameters = {}) { super();
if (parameters.schema) { this.fromSchema(parameters.schema);
}
}
/** * Returns default values for all class members * @param memberName String name for a class member * @returns Default value
*/ publicstatic override defaultValues(memberName: typeof VERSION): number; publicstatic override defaultValues(memberName: typeof KEK_ID): KEKIdentifier; publicstatic override defaultValues(memberName: typeof KEY_ENCRYPTION_ALGORITHM): AlgorithmIdentifier; publicstatic override defaultValues(memberName: typeof ENCRYPTED_KEY): asn1js.OctetString; publicstatic override defaultValues(memberName: typeof PER_DEFINED_KEK): ArrayBuffer; publicstatic override defaultValues(memberName: string): any { switch (memberName) { case VERSION: return0; case KEK_ID: returnnew KEKIdentifier(); case KEY_ENCRYPTION_ALGORITHM: returnnew AlgorithmIdentifier(); case ENCRYPTED_KEY: returnnew asn1js.OctetString(); case PER_DEFINED_KEK: return EMPTY_BUFFER; default: returnsuper.defaultValues(memberName);
}
}
/** * Compare values with default values for all class members * @param memberName String name for a class member * @param memberValue Value to compare with default value
*/ publicstatic compareWithDefault(memberName: string, memberValue: any): boolean { switch (memberName) { case"KEKRecipientInfo": return (memberValue === KEKRecipientInfo.defaultValues(VERSION)); case KEK_ID: return ((memberValue.compareWithDefault("keyIdentifier", memberValue.keyIdentifier)) &&
(("date" in memberValue) === false) &&
(("other" in memberValue) === false)); case KEY_ENCRYPTION_ALGORITHM: return ((memberValue.algorithmId === EMPTY_STRING) && (("algorithmParams" in memberValue) === false)); case ENCRYPTED_KEY: return (memberValue.isEqual(KEKRecipientInfo.defaultValues(ENCRYPTED_KEY))); case PER_DEFINED_KEK: return (memberValue.byteLength === 0); default: returnsuper.defaultValues(memberName);
}
}
// Get internal properties from parsed schema this.version = asn1.result.version.valueBlock.valueDec; this.kekid = new KEKIdentifier({ schema: asn1.result.kekid }); this.keyEncryptionAlgorithm = new AlgorithmIdentifier({ schema: asn1.result.keyEncryptionAlgorithm }); this.encryptedKey = asn1.result.encryptedKey;
}
public toSchema(): asn1js.Sequence { // Construct and return new ASN.1 schema for this object return (new asn1js.Sequence({
value: [ new asn1js.Integer({ value: this.version }), this.kekid.toSchema(), this.keyEncryptionAlgorithm.toSchema(), this.encryptedKey
]
}));
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.