import * as asn1js from "asn1js"; import * as pvutils from "pvutils"; import { AlgorithmIdentifier, AlgorithmIdentifierJson, AlgorithmIdentifierSchema } from "./AlgorithmIdentifier"; import { EncryptedData, EncryptedDataEncryptParams } from "./EncryptedData"; import { EncryptedContentInfo } from "./EncryptedContentInfo"; import { PrivateKeyInfo } from "./PrivateKeyInfo"; import * as Schema from "./Schema"; import { AsnError } from "./errors"; import { PkiObject, PkiObjectParameters } from "./PkiObject"; import { EMPTY_STRING } from "./constants"; import * as common from "./common";
type PKCS8ShroudedKeyBagMakeInternalValuesParams = Omit<EncryptedDataEncryptParams, "contentToEncrypt">;
/** * Represents the PKCS8ShroudedKeyBag structure described in [RFC7292](https://datatracker.ietf.org/doc/html/rfc7292)
*/
export class PKCS8ShroudedKeyBag extends PkiObject implements IPKCS8ShroudedKeyBag {
public encryptionAlgorithm!: AlgorithmIdentifier; public encryptedData!: asn1js.OctetString; public parsedValue?: PrivateKeyInfo;
/** * Initializes a new instance of the {@link PKCS8ShroudedKeyBag} class * @param parameters Initialization parameters
*/
constructor(parameters: PKCS8ShroudedKeyBagParameters = {}) { 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 ENCRYPTION_ALGORITHM): AlgorithmIdentifier; publicstatic override defaultValues(memberName: typeof ENCRYPTED_DATA): asn1js.OctetString; publicstatic override defaultValues(memberName: typeof PARSED_VALUE): PrivateKeyInfo; publicstatic override defaultValues(memberName: string): any { switch (memberName) { case ENCRYPTION_ALGORITHM: return (new AlgorithmIdentifier()); case ENCRYPTED_DATA: return (new asn1js.OctetString()); case PARSED_VALUE: return {}; 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 ENCRYPTION_ALGORITHM: return ((AlgorithmIdentifier.compareWithDefault("algorithmId", memberValue.algorithmId)) &&
(("algorithmParams" in memberValue) === false)); case ENCRYPTED_DATA: return (memberValue.isEqual(PKCS8ShroudedKeyBag.defaultValues(memberName))); case PARSED_VALUE: return ((memberValue instanceof Object) && (Object.keys(memberValue).length === 0)); default: returnsuper.defaultValues(memberName);
}
}
public async makeInternalValues(parameters: PKCS8ShroudedKeyBagMakeInternalValuesParams): Promise<void> { //#region Check that we do have PARSED_VALUE if (!this.parsedValue) { thrownew Error("Please initialize \"parsedValue\" first");
} //#endregion
//#region Initial variables const cmsEncrypted = new EncryptedData(); //#endregion
await cmsEncrypted.encrypt(encryptParams); if (!cmsEncrypted.encryptedContentInfo.encryptedContent) { thrownew Error("The filed `encryptedContent` in EncryptedContentInfo is empty");
}
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.