]> git.ipfire.org Git - thirdparty/strongswan.git/blob - src/libcharon/plugins/eap_tnc/eap_tnc.h
Update copyright headers after acquisition by secunet
[thirdparty/strongswan.git] / src / libcharon / plugins / eap_tnc / eap_tnc.h
1 /*
2 * Copyright (C) 2010-2012 Andreas Steffen
3 *
4 * Copyright (C) secunet Security Networks AG
5 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2 of the License, or (at your
9 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
10 *
11 * This program is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 * for more details.
15 */
16
17 /**
18 * @defgroup eap_tnc_i eap_tnc
19 * @{ @ingroup eap_tnc
20 */
21
22 #ifndef EAP_TNC_H_
23 #define EAP_TNC_H_
24
25 typedef struct eap_tnc_t eap_tnc_t;
26
27 #include <sa/eap/eap_inner_method.h>
28
29 /**
30 * Implementation of the eap_method_t interface using EAP-TNC or PT-EAP.
31 */
32 struct eap_tnc_t {
33
34 /**
35 * Implemented eap_inner_method_t interface.
36 */
37 eap_inner_method_t eap_inner_method;
38 };
39
40 /**
41 * Creates the EAP method EAP-TNC acting as server.
42 *
43 * @param server ID of the EAP server
44 * @param peer ID of the EAP client
45 * @return eap_tnc_t object
46 */
47 eap_tnc_t *eap_tnc_create_server(identification_t *server,
48 identification_t *peer);
49
50 /**
51 * Creates the EAP method EAP-TNC acting as peer.
52 *
53 * @param server ID of the EAP server
54 * @param peer ID of the EAP client
55 * @return eap_tnc_t object
56 */
57 eap_tnc_t *eap_tnc_create_peer(identification_t *server,
58 identification_t *peer);
59
60 /**
61 * Creates the EAP method PT-EAP acting as server.
62 *
63 * @param server ID of the EAP server
64 * @param peer ID of the EAP client
65 * @return eap_tnc_t object
66 */
67 eap_tnc_t *eap_tnc_pt_create_server(identification_t *server,
68 identification_t *peer);
69
70 /**
71 * Creates the EAP method PT-EAP acting as peer.
72 *
73 * @param server ID of the EAP server
74 * @param peer ID of the EAP client
75 * @return eap_tnc_t object
76 */
77 eap_tnc_t *eap_tnc_pt_create_peer(identification_t *server,
78 identification_t *peer);
79
80 #endif /** EAP_TNC_H_ @}*/