Created framework for BLISS post-quantum signature algorithm
[strongswan.git] / src / libstrongswan / plugins / bliss / bliss_private_key.h
1 /*
2 * Copyright (C) 2014 Andreas Steffen
3 * HSR Hochschule fuer Technik Rapperswil
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13 * for more details.
14 */
15
16 /**
17 * @defgroup bliss_private_key bliss_private_key
18 * @{ @ingroup gmp_p
19 */
20
21 #ifndef BLISS_PRIVATE_KEY_H_
22 #define BLISS_PRIVATE_KEY_H_
23
24 #include <credentials/builder.h>
25 #include <credentials/keys/private_key.h>
26
27 typedef struct bliss_private_key_t bliss_private_key_t;
28
29 /**
30 * Private_key_t implementation of BLISS signature algorithm.
31 */
32 struct bliss_private_key_t {
33
34 /**
35 * Implements private_key_t interface
36 */
37 private_key_t key;
38 };
39
40 /**
41 * Generate a BLISS private key.
42 *
43 * Accepts the BUILD_KEY_SIZE argument.
44 *
45 * @param type type of the key, must be KEY_BLISS
46 * @param args builder_part_t argument list
47 * @return generated key, NULL on failure
48 */
49 bliss_private_key_t *bliss_private_key_gen(key_type_t type, va_list args);
50
51 /**
52 * Load a BLISS private key.
53 *
54 * Accepts BUILD_BLISS_* components.
55 *
56 * @param type type of the key, must be KEY_BLISS
57 * @param args builder_part_t argument list
58 * @return loaded key, NULL on failure
59 */
60 bliss_private_key_t *bliss_private_key_load(key_type_t type, va_list args);
61
62 #endif /** BLISS_PRIVATE_KEY_H_ @}*/