Implemented PT-EAP protocol (RFC 7171)
[strongswan.git] / src / libcharon / plugins / eap_tnc / eap_tnc.h
1 /*
2 * Copyright (C) 2010-2012 Andreas Steffen
3 * 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 eap_tnc_i eap_tnc
18 * @{ @ingroup eap_tnc
19 */
20
21 #ifndef EAP_TNC_H_
22 #define EAP_TNC_H_
23
24 typedef struct eap_tnc_t eap_tnc_t;
25
26 #include <sa/eap/eap_inner_method.h>
27
28 /**
29 * Implementation of the eap_method_t interface using EAP-TNC or PT-EAP.
30 */
31 struct eap_tnc_t {
32
33 /**
34 * Implemented eap_inner_method_t interface.
35 */
36 eap_inner_method_t eap_inner_method;
37 };
38
39 /**
40 * Creates the EAP method EAP-TNC acting as server.
41 *
42 * @param server ID of the EAP server
43 * @param peer ID of the EAP client
44 * @return eap_tnc_t object
45 */
46 eap_tnc_t *eap_tnc_create_server(identification_t *server,
47 identification_t *peer);
48
49 /**
50 * Creates the EAP method EAP-TNC acting as peer.
51 *
52 * @param server ID of the EAP server
53 * @param peer ID of the EAP client
54 * @return eap_tnc_t object
55 */
56 eap_tnc_t *eap_tnc_create_peer(identification_t *server,
57 identification_t *peer);
58
59 /**
60 * Creates the EAP method PT-EAP acting as server.
61 *
62 * @param server ID of the EAP server
63 * @param peer ID of the EAP client
64 * @return eap_tnc_t object
65 */
66 eap_tnc_t *eap_tnc_pt_create_server(identification_t *server,
67 identification_t *peer);
68
69 /**
70 * Creates the EAP method PT-EAP acting as peer.
71 *
72 * @param server ID of the EAP server
73 * @param peer ID of the EAP client
74 * @return eap_tnc_t object
75 */
76 eap_tnc_t *eap_tnc_pt_create_peer(identification_t *server,
77 identification_t *peer);
78
79 #endif /** EAP_TNC_H_ @}*/