Blame crypto/cms/cms_cd.c

Packit c4476c
/*
Packit c4476c
 * Copyright 2008-2016 The OpenSSL Project Authors. All Rights Reserved.
Packit c4476c
 *
Packit c4476c
 * Licensed under the OpenSSL license (the "License").  You may not use
Packit c4476c
 * this file except in compliance with the License.  You can obtain a copy
Packit c4476c
 * in the file LICENSE in the source distribution or at
Packit c4476c
 * https://www.openssl.org/source/license.html
Packit c4476c
 */
Packit c4476c
Packit c4476c
#include "internal/cryptlib.h"
Packit c4476c
#include <openssl/asn1t.h>
Packit c4476c
#include <openssl/pem.h>
Packit c4476c
#include <openssl/x509v3.h>
Packit c4476c
#include <openssl/err.h>
Packit c4476c
#include <openssl/cms.h>
Packit c4476c
#include <openssl/bio.h>
Packit c4476c
#include <openssl/comp.h>
Packit c4476c
#include "cms_local.h"
Packit c4476c
Packit c4476c
#ifdef ZLIB
Packit c4476c
Packit c4476c
/* CMS CompressedData Utilities */
Packit c4476c
Packit c4476c
CMS_ContentInfo *cms_CompressedData_create(int comp_nid)
Packit c4476c
{
Packit c4476c
    CMS_ContentInfo *cms;
Packit c4476c
    CMS_CompressedData *cd;
Packit c4476c
    /*
Packit c4476c
     * Will need something cleverer if there is ever more than one
Packit c4476c
     * compression algorithm or parameters have some meaning...
Packit c4476c
     */
Packit c4476c
    if (comp_nid != NID_zlib_compression) {
Packit c4476c
        CMSerr(CMS_F_CMS_COMPRESSEDDATA_CREATE,
Packit c4476c
               CMS_R_UNSUPPORTED_COMPRESSION_ALGORITHM);
Packit c4476c
        return NULL;
Packit c4476c
    }
Packit c4476c
    cms = CMS_ContentInfo_new();
Packit c4476c
    if (cms == NULL)
Packit c4476c
        return NULL;
Packit c4476c
Packit c4476c
    cd = M_ASN1_new_of(CMS_CompressedData);
Packit c4476c
Packit c4476c
    if (cd == NULL)
Packit c4476c
        goto err;
Packit c4476c
Packit c4476c
    cms->contentType = OBJ_nid2obj(NID_id_smime_ct_compressedData);
Packit c4476c
    cms->d.compressedData = cd;
Packit c4476c
Packit c4476c
    cd->version = 0;
Packit c4476c
Packit c4476c
    X509_ALGOR_set0(cd->compressionAlgorithm,
Packit c4476c
                    OBJ_nid2obj(NID_zlib_compression), V_ASN1_UNDEF, NULL);
Packit c4476c
Packit c4476c
    cd->encapContentInfo->eContentType = OBJ_nid2obj(NID_pkcs7_data);
Packit c4476c
Packit c4476c
    return cms;
Packit c4476c
Packit c4476c
 err:
Packit c4476c
    CMS_ContentInfo_free(cms);
Packit c4476c
    return NULL;
Packit c4476c
}
Packit c4476c
Packit c4476c
BIO *cms_CompressedData_init_bio(CMS_ContentInfo *cms)
Packit c4476c
{
Packit c4476c
    CMS_CompressedData *cd;
Packit c4476c
    const ASN1_OBJECT *compoid;
Packit c4476c
    if (OBJ_obj2nid(cms->contentType) != NID_id_smime_ct_compressedData) {
Packit c4476c
        CMSerr(CMS_F_CMS_COMPRESSEDDATA_INIT_BIO,
Packit c4476c
               CMS_R_CONTENT_TYPE_NOT_COMPRESSED_DATA);
Packit c4476c
        return NULL;
Packit c4476c
    }
Packit c4476c
    cd = cms->d.compressedData;
Packit c4476c
    X509_ALGOR_get0(&compoid, NULL, NULL, cd->compressionAlgorithm);
Packit c4476c
    if (OBJ_obj2nid(compoid) != NID_zlib_compression) {
Packit c4476c
        CMSerr(CMS_F_CMS_COMPRESSEDDATA_INIT_BIO,
Packit c4476c
               CMS_R_UNSUPPORTED_COMPRESSION_ALGORITHM);
Packit c4476c
        return NULL;
Packit c4476c
    }
Packit c4476c
    return BIO_new(BIO_f_zlib());
Packit c4476c
}
Packit c4476c
Packit c4476c
#endif