UNPKG

@wildboar/pkcs

Version:
123 lines (122 loc) 4.37 kB
import { ASN1Element as _Element, OBJECT_IDENTIFIER, OPTIONAL } from "asn1-ts"; import * as $ from "asn1-ts/dist/node/functional"; import { ContentEncryptionAlgorithmIdentifier } from "../PKCS7/ContentEncryptionAlgorithmIdentifier.ta"; import { ENCRYPTED } from "../PKCS7/ENCRYPTED.ta"; export { ContentEncryptionAlgorithmIdentifier, _decode_ContentEncryptionAlgorithmIdentifier, _encode_ContentEncryptionAlgorithmIdentifier, } from "../PKCS7/ContentEncryptionAlgorithmIdentifier.ta"; export { ENCRYPTED, _get_decoder_for_ENCRYPTED, _get_encoder_for_ENCRYPTED, } from "../PKCS7/ENCRYPTED.ta"; export { PKCS7_CONTENT_TYPE } from "../PKCS7/PKCS7-CONTENT-TYPE.oca"; export { PKCS7ContentTable } from "../PKCS7/PKCS7ContentTable.osa"; /** * @summary EncryptedContentInfo * @description * * ### ASN.1 Definition: * * ```asn1 * EncryptedContentInfo ::= SEQUENCE { * contentType PKCS7-CONTENT-TYPE.&id({PKCS7ContentTable}), * contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier, * encryptedContent * [0] ENCRYPTED{PKCS7-CONTENT-TYPE.&Type * ({PKCS7ContentTable}{@.contentType})} OPTIONAL * } * ``` * * @class */ export declare class EncryptedContentInfo { /** * @summary `contentType`. * @public * @readonly */ readonly contentType: OBJECT_IDENTIFIER; /** * @summary `contentEncryptionAlgorithm`. * @public * @readonly */ readonly contentEncryptionAlgorithm: ContentEncryptionAlgorithmIdentifier; /** * @summary `encryptedContent`. * @public * @readonly */ readonly encryptedContent: OPTIONAL<ENCRYPTED<_Element>>; constructor( /** * @summary `contentType`. * @public * @readonly */ contentType: OBJECT_IDENTIFIER, /** * @summary `contentEncryptionAlgorithm`. * @public * @readonly */ contentEncryptionAlgorithm: ContentEncryptionAlgorithmIdentifier, /** * @summary `encryptedContent`. * @public * @readonly */ encryptedContent: OPTIONAL<ENCRYPTED<_Element>>); /** * @summary Restructures an object into a EncryptedContentInfo * @description * * This takes an `object` and converts it to a `EncryptedContentInfo`. * * @public * @static * @method * @param {Object} _o An object having all of the keys and values of a `EncryptedContentInfo`. * @returns {EncryptedContentInfo} */ static _from_object(_o: { [_K in keyof EncryptedContentInfo]: EncryptedContentInfo[_K]; }): EncryptedContentInfo; } /** * @summary The Leading Root Component Types of EncryptedContentInfo * @description * * This is an array of `ComponentSpec`s that define how to decode the leading root component type list of a SET or SEQUENCE. * * @constant */ export declare const _root_component_type_list_1_spec_for_EncryptedContentInfo: $.ComponentSpec[]; /** * @summary The Trailing Root Component Types of EncryptedContentInfo * @description * * This is an array of `ComponentSpec`s that define how to decode the trailing root component type list of a SET or SEQUENCE. * * @constant */ export declare const _root_component_type_list_2_spec_for_EncryptedContentInfo: $.ComponentSpec[]; /** * @summary The Extension Addition Component Types of EncryptedContentInfo * @description * * This is an array of `ComponentSpec`s that define how to decode the extension addition component type list of a SET or SEQUENCE. * * @constant */ export declare const _extension_additions_list_spec_for_EncryptedContentInfo: $.ComponentSpec[]; /** * @summary Decodes an ASN.1 element into a(n) EncryptedContentInfo * @function * @param {_Element} el The element being decoded. * @returns {EncryptedContentInfo} The decoded data structure. */ export declare function _decode_EncryptedContentInfo(el: _Element): EncryptedContentInfo; /** * @summary Encodes a(n) EncryptedContentInfo into an ASN.1 Element. * @function * @param {value} el The element being decoded. * @param elGetter A function that can be used to get new ASN.1 elements. * @returns {_Element} The EncryptedContentInfo, encoded as an ASN.1 Element. */ export declare function _encode_EncryptedContentInfo(value: EncryptedContentInfo, elGetter: $.ASN1Encoder<EncryptedContentInfo>): _Element;