Leancrypto 1.6.0
Post-Quantum Cryptographic Library
Loading...
Searching...
No Matches
lc_pkcs7_generator.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2024 - 2025, Stephan Mueller <smueller@chronox.de>
3 *
4 * License: see LICENSE file in root directory
5 *
6 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
7 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
8 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ALL OF
9 * WHICH ARE HEREBY DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
10 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
11 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
12 * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
13 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
14 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
15 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
16 * USE OF THIS SOFTWARE, EVEN IF NOT ADVISED OF THE POSSIBILITY OF SUCH
17 * DAMAGE.
18 */
19
20#ifndef LC_PKCS7_GENERATOR_H
21#define LC_PKCS7_GENERATOR_H
22
23#include "lc_pkcs7_common.h"
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
53
74int lc_pkcs7_encode(const struct lc_pkcs7_message *pkcs7, uint8_t *data,
75 size_t *avail_datalen);
76
96int lc_pkcs7_set_certificate(struct lc_pkcs7_message *pkcs7,
97 struct lc_x509_certificate *x509);
98
136int lc_pkcs7_set_signer(struct lc_pkcs7_message *pkcs7,
137 struct lc_x509_certificate *x509_with_sk,
138 const struct lc_hash *signing_hash,
139 unsigned long auth_attribute);
140
147
162int lc_pkcs7_set_data(struct lc_pkcs7_message *pkcs7, const uint8_t *data,
163 size_t data_len, enum lc_pkcs7_set_data_flags flags);
164
165#ifdef __cplusplus
166}
167#endif
168
169#endif /* LC_PKCS7_GENERATOR_H */
int lc_hash(const struct lc_hash *hash, const uint8_t *in, size_t inlen, uint8_t *digest)
Calculate message digest - one-shot.
int lc_pkcs7_set_signer(struct lc_pkcs7_message *pkcs7, struct lc_x509_certificate *x509_with_sk, const struct lc_hash *signing_hash, unsigned long auth_attribute)
Set an PKCS#7 certificate as signer for a PKCS#7 message.
int lc_pkcs7_set_certificate(struct lc_pkcs7_message *pkcs7, struct lc_x509_certificate *x509)
Set an PKCS#7 certificate to be added to a PKCS#7 message.
int lc_pkcs7_set_data(struct lc_pkcs7_message *pkcs7, const uint8_t *data, size_t data_len, enum lc_pkcs7_set_data_flags flags)
Set the data to be signed with PKCS#7.
int lc_pkcs7_encode(const struct lc_pkcs7_message *pkcs7, uint8_t *data, size_t *avail_datalen)
Encode a PKCS#7 message.
lc_pkcs7_set_data_flags
@ lc_pkcs7_set_data_embed
@ lc_pkcs7_set_data_noflag