Blame crypto/cms/cms_cd.c

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