removed debug output in IMC bind functions
[strongswan.git] / src / libcharon / plugins / tnc_imv / tnc_imv_bind_function.c
1 /*
2 * Copyright (C) 2006 Mike McCauley
3 * Copyright (C) 2010 Andreas Steffen, 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 #include "tnc_imv.h"
17
18 #include <debug.h>
19 #include <daemon.h>
20
21 /**
22 * Called by the IMV to inform a TNCS about the set of message types the IMV
23 * is able to receive
24 */
25 TNC_Result TNC_TNCS_ReportMessageTypes(TNC_IMVID imv_id,
26 TNC_MessageTypeList supported_types,
27 TNC_UInt32 type_count)
28 {
29 return charon->imvs->set_message_types(charon->imvs, imv_id,
30 supported_types, type_count);
31 }
32
33 /**
34 * Called by the IMV to ask a TNCS to retry an Integrity Check Handshake
35 */
36 TNC_Result TNC_TNCS_RequestHandshakeRetry(TNC_IMVID imv_id,
37 TNC_ConnectionID connection_id,
38 TNC_RetryReason reason)
39 {
40 DBG2(DBG_TNC,"TNCS_RequestHandshakeRetry not supported yet");
41 return TNC_RESULT_CANT_RESPOND;
42 }
43
44 /**
45 * Called by the IMV when an IMV-IMC message is to be sent
46 */
47 TNC_Result TNC_TNCS_SendMessage(TNC_IMVID imv_id,
48 TNC_ConnectionID connection_id,
49 TNC_BufferReference message,
50 TNC_UInt32 message_len,
51 TNC_MessageType message_type)
52 {
53 return charon->tnccs->send_message(charon->tnccs, connection_id, message,
54 message_len, message_type);
55 }
56
57 /**
58 * Called by the IMV to deliver its IMV Action Recommendation and IMV Evaluation
59 * Result to the TNCS
60 */
61 TNC_Result TNC_TNCS_ProvideRecommendation(TNC_IMVID imv_id,
62 TNC_ConnectionID connection_id,
63 TNC_IMV_Action_Recommendation recommendation,
64 TNC_IMV_Evaluation_Result evaluation)
65 {
66 return charon->tnccs->provide_recommendation(charon->tnccs, imv_id,
67 connection_id, recommendation, evaluation);
68 }
69
70 /**
71 * Called by the IMV when it needs a function pointer
72 */
73 TNC_Result TNC_TNCS_BindFunction(TNC_IMVID id,
74 char *function_name,
75 void **function_pointer)
76 {
77 if (streq(function_name, "TNC_TNCS_ReportMessageTypes"))
78 {
79 *function_pointer = (void*)TNC_TNCS_ReportMessageTypes;
80 }
81 else if (streq(function_name, "TNC_TNCS_RequestHandshakeRetry"))
82 {
83 *function_pointer = (void*)TNC_TNCS_RequestHandshakeRetry;
84 }
85 else if (streq(function_name, "TNC_TNCS_SendMessage"))
86 {
87 *function_pointer = (void*)TNC_TNCS_SendMessage;
88 }
89 else if (streq(function_name, "TNC_TNCS_ProvideRecommendation"))
90 {
91 *function_pointer = (void*)TNC_TNCS_ProvideRecommendation;
92 }
93 else
94 {
95 return TNC_RESULT_INVALID_PARAMETER;
96 }
97 return TNC_RESULT_SUCCESS;
98 }