1e1051a39Sopenharmony_ci/*
2e1051a39Sopenharmony_ci * Copyright 2008-2021 The OpenSSL Project Authors. All Rights Reserved.
3e1051a39Sopenharmony_ci *
4e1051a39Sopenharmony_ci * Licensed under the Apache License 2.0 (the "License").  You may not use
5e1051a39Sopenharmony_ci * this file except in compliance with the License.  You can obtain a copy
6e1051a39Sopenharmony_ci * in the file LICENSE in the source distribution or at
7e1051a39Sopenharmony_ci * https://www.openssl.org/source/license.html
8e1051a39Sopenharmony_ci */
9e1051a39Sopenharmony_ci
10e1051a39Sopenharmony_ci#include "internal/cryptlib.h"
11e1051a39Sopenharmony_ci#include <openssl/asn1t.h>
12e1051a39Sopenharmony_ci#include <openssl/pem.h>
13e1051a39Sopenharmony_ci#include <openssl/x509v3.h>
14e1051a39Sopenharmony_ci#include <openssl/err.h>
15e1051a39Sopenharmony_ci#include <openssl/cms.h>
16e1051a39Sopenharmony_ci#include <openssl/bio.h>
17e1051a39Sopenharmony_ci#include <openssl/comp.h>
18e1051a39Sopenharmony_ci#include "cms_local.h"
19e1051a39Sopenharmony_ci
20e1051a39Sopenharmony_ci#ifdef ZLIB
21e1051a39Sopenharmony_ci
22e1051a39Sopenharmony_ci/* CMS CompressedData Utilities */
23e1051a39Sopenharmony_ci
24e1051a39Sopenharmony_ciCMS_ContentInfo *ossl_cms_CompressedData_create(int comp_nid,
25e1051a39Sopenharmony_ci                                                OSSL_LIB_CTX *libctx,
26e1051a39Sopenharmony_ci                                                const char *propq)
27e1051a39Sopenharmony_ci{
28e1051a39Sopenharmony_ci    CMS_ContentInfo *cms;
29e1051a39Sopenharmony_ci    CMS_CompressedData *cd;
30e1051a39Sopenharmony_ci
31e1051a39Sopenharmony_ci    /*
32e1051a39Sopenharmony_ci     * Will need something cleverer if there is ever more than one
33e1051a39Sopenharmony_ci     * compression algorithm or parameters have some meaning...
34e1051a39Sopenharmony_ci     */
35e1051a39Sopenharmony_ci    if (comp_nid != NID_zlib_compression) {
36e1051a39Sopenharmony_ci        ERR_raise(ERR_LIB_CMS, CMS_R_UNSUPPORTED_COMPRESSION_ALGORITHM);
37e1051a39Sopenharmony_ci        return NULL;
38e1051a39Sopenharmony_ci    }
39e1051a39Sopenharmony_ci    cms = CMS_ContentInfo_new_ex(libctx, propq);
40e1051a39Sopenharmony_ci    if (cms == NULL)
41e1051a39Sopenharmony_ci        return NULL;
42e1051a39Sopenharmony_ci
43e1051a39Sopenharmony_ci    cd = M_ASN1_new_of(CMS_CompressedData);
44e1051a39Sopenharmony_ci
45e1051a39Sopenharmony_ci    if (cd == NULL)
46e1051a39Sopenharmony_ci        goto err;
47e1051a39Sopenharmony_ci
48e1051a39Sopenharmony_ci    cms->contentType = OBJ_nid2obj(NID_id_smime_ct_compressedData);
49e1051a39Sopenharmony_ci    cms->d.compressedData = cd;
50e1051a39Sopenharmony_ci
51e1051a39Sopenharmony_ci    cd->version = 0;
52e1051a39Sopenharmony_ci
53e1051a39Sopenharmony_ci    X509_ALGOR_set0(cd->compressionAlgorithm,
54e1051a39Sopenharmony_ci                    OBJ_nid2obj(NID_zlib_compression), V_ASN1_UNDEF, NULL);
55e1051a39Sopenharmony_ci
56e1051a39Sopenharmony_ci    cd->encapContentInfo->eContentType = OBJ_nid2obj(NID_pkcs7_data);
57e1051a39Sopenharmony_ci
58e1051a39Sopenharmony_ci    return cms;
59e1051a39Sopenharmony_ci
60e1051a39Sopenharmony_ci err:
61e1051a39Sopenharmony_ci    CMS_ContentInfo_free(cms);
62e1051a39Sopenharmony_ci    return NULL;
63e1051a39Sopenharmony_ci}
64e1051a39Sopenharmony_ci
65e1051a39Sopenharmony_ciBIO *ossl_cms_CompressedData_init_bio(const CMS_ContentInfo *cms)
66e1051a39Sopenharmony_ci{
67e1051a39Sopenharmony_ci    CMS_CompressedData *cd;
68e1051a39Sopenharmony_ci    const ASN1_OBJECT *compoid;
69e1051a39Sopenharmony_ci
70e1051a39Sopenharmony_ci    if (OBJ_obj2nid(cms->contentType) != NID_id_smime_ct_compressedData) {
71e1051a39Sopenharmony_ci        ERR_raise(ERR_LIB_CMS, CMS_R_CONTENT_TYPE_NOT_COMPRESSED_DATA);
72e1051a39Sopenharmony_ci        return NULL;
73e1051a39Sopenharmony_ci    }
74e1051a39Sopenharmony_ci    cd = cms->d.compressedData;
75e1051a39Sopenharmony_ci    X509_ALGOR_get0(&compoid, NULL, NULL, cd->compressionAlgorithm);
76e1051a39Sopenharmony_ci    if (OBJ_obj2nid(compoid) != NID_zlib_compression) {
77e1051a39Sopenharmony_ci        ERR_raise(ERR_LIB_CMS, CMS_R_UNSUPPORTED_COMPRESSION_ALGORITHM);
78e1051a39Sopenharmony_ci        return NULL;
79e1051a39Sopenharmony_ci    }
80e1051a39Sopenharmony_ci    return BIO_new(BIO_f_zlib());
81e1051a39Sopenharmony_ci}
82e1051a39Sopenharmony_ci
83e1051a39Sopenharmony_ci#endif
84