2 * Copyright (C) 2012 Adrian-Ken Rueegsegger
3 * Hochschule fuer Technik Rapperswil
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>.
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
17 * @defgroup nonce_gen nonce_gen
24 typedef struct nonce_gen_t nonce_gen_t
;
29 * Generic interface for nonce generators.
34 * Generates a nonce and writes it into the buffer.
36 * @param size size of nonce in bytes
37 * @param buffer pointer where the generated nonce will be written
38 * @return TRUE if nonce allocation was succesful, FALSE otherwise
40 __attribute__((warn_unused_result
))
41 bool (*get_nonce
) (nonce_gen_t
*this, size_t size
, u_int8_t
*buffer
);
44 * Generates a nonce and allocates space for it.
46 * @param size size of nonce in bytes
47 * @param chunk chunk which will hold the generated nonce
48 * @return TRUE if nonce allocation was succesful, FALSE otherwise
50 __attribute__((warn_unused_result
))
51 bool (*allocate_nonce
) (nonce_gen_t
*this, size_t size
, chunk_t
*chunk
);
54 * Destroys a nonce generator object.
56 void (*destroy
) (nonce_gen_t
*this);
59 #endif /** NONCE_GEN_H_ @}*/