blob: 8323e3e571311b4c32794809eb8b2569c0e80b77 [file] [log] [blame]
David Howells2e3fadb2014-07-01 16:40:19 +01001/* PKCS#7 crypto data parser
2 *
3 * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved.
4 * Written by David Howells (dhowells@redhat.com)
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public Licence
8 * as published by the Free Software Foundation; either version
9 * 2 of the Licence, or (at your option) any later version.
10 */
11
David Howells99db4432015-08-05 15:22:27 +010012#ifndef _CRYPTO_PKCS7_H
13#define _CRYPTO_PKCS7_H
14
David Howellse68503b2016-04-06 16:14:24 +010015#include <linux/verification.h>
David Howells99db4432015-08-05 15:22:27 +010016#include <crypto/public_key.h>
17
David Howells08815b62014-07-01 16:40:20 +010018struct key;
David Howells2e3fadb2014-07-01 16:40:19 +010019struct pkcs7_message;
20
21/*
22 * pkcs7_parser.c
23 */
24extern struct pkcs7_message *pkcs7_parse_message(const void *data,
25 size_t datalen);
26extern void pkcs7_free_message(struct pkcs7_message *pkcs7);
27
28extern int pkcs7_get_content_data(const struct pkcs7_message *pkcs7,
29 const void **_data, size_t *_datalen,
David Howellse68503b2016-04-06 16:14:24 +010030 size_t *_headerlen);
David Howellsa4730352014-07-01 16:40:19 +010031
32/*
David Howells08815b62014-07-01 16:40:20 +010033 * pkcs7_trust.c
34 */
35extern int pkcs7_validate_trust(struct pkcs7_message *pkcs7,
36 struct key *trust_keyring,
37 bool *_trusted);
38
39/*
David Howellsa4730352014-07-01 16:40:19 +010040 * pkcs7_verify.c
41 */
David Howells99db4432015-08-05 15:22:27 +010042extern int pkcs7_verify(struct pkcs7_message *pkcs7,
43 enum key_being_used_for usage);
David Howells4ebdb76f2015-07-20 21:16:26 +010044
45extern int pkcs7_supply_detached_data(struct pkcs7_message *pkcs7,
46 const void *data, size_t datalen);
David Howells99db4432015-08-05 15:22:27 +010047
48#endif /* _CRYPTO_PKCS7_H */