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;
