import * as asn1js from "asn1js"; import * as pvutils from "pvutils"; import { AlgorithmIdentifier, AlgorithmIdentifierJson, AlgorithmIdentifierSchema } from "./AlgorithmIdentifier"; import { EMPTY_STRING } from "./constants"; import { AsnError } from "./errors"; import { PkiObject, PkiObjectParameters } from "./PkiObject"; import * as Schema from "./Schema";
export type PBKDF2ParamsParameters = PkiObjectParameters & Partial<IPBKDF2Params>;
/** * Represents the PBKDF2Params structure described in [RFC2898](https://www.ietf.org/rfc/rfc2898.txt)
*/
export class PBKDF2Params extends PkiObject implements IPBKDF2Params {
public salt: any; public iterationCount!: number; public keyLength?: number; public prf?: AlgorithmIdentifier;
/** * Initializes a new instance of the {@link PBKDF2Params} class * @param parameters Initialization parameters
*/
constructor(parameters: PBKDF2ParamsParameters = {}) { super();
this.salt = pvutils.getParametersValue(parameters, SALT, PBKDF2Params.defaultValues(SALT)); this.iterationCount = pvutils.getParametersValue(parameters, ITERATION_COUNT, PBKDF2Params.defaultValues(ITERATION_COUNT)); if (KEY_LENGTH in parameters) { this.keyLength = pvutils.getParametersValue(parameters, KEY_LENGTH, PBKDF2Params.defaultValues(KEY_LENGTH));
} if (PRF in parameters) { this.prf = pvutils.getParametersValue(parameters, PRF, PBKDF2Params.defaultValues(PRF));
}
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 SALT): any; publicstatic override defaultValues(memberName: typeof ITERATION_COUNT): number; publicstatic override defaultValues(memberName: typeof KEY_LENGTH): number; publicstatic override defaultValues(memberName: typeof PRF): AlgorithmIdentifier; publicstatic override defaultValues(memberName: string): any { switch (memberName) { case SALT: return {}; case ITERATION_COUNT: return (-1); case KEY_LENGTH: return0; case PRF: returnnew AlgorithmIdentifier({
algorithmId: "1.3.14.3.2.26", // SHA-1
algorithmParams: new asn1js.Null()
}); default: returnsuper.defaultValues(memberName);
}
}
// Get internal properties from parsed schema this.salt = asn1.result.salt; this.iterationCount = asn1.result.iterationCount.valueBlock.valueDec; if (KEY_LENGTH in asn1.result) this.keyLength = asn1.result.keyLength.valueBlock.valueDec; if (PRF in asn1.result) this.prf = new AlgorithmIdentifier({ schema: asn1.result.prf });
}
public toSchema(): asn1js.Sequence { //#region Create array for output sequence const outputArray = [];
if (KEY_LENGTH in this) { if (PBKDF2Params.defaultValues(KEY_LENGTH) !== this.keyLength)
outputArray.push(new asn1js.Integer({ value: this.keyLength }));
}
if (this.prf) { if (PBKDF2Params.defaultValues(PRF).isEqual(this.prf) === false)
outputArray.push(this.prf.toSchema());
} //#endregion
//#region Construct and return new ASN.1 schema for this object return (new asn1js.Sequence({
value: outputArray
})); //#endregion
}
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.