Annotation of embedaddon/strongswan/src/libtnccs/tnc/imv/imv_recommendations.h, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * Copyright (C) 2010 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 imv_recommendations imv_recommendations
                     18:  * @{ @ingroup imv
                     19:  */
                     20: 
                     21: #ifndef IMV_RECOMMENDATIONS_H_
                     22: #define IMV_RECOMMENDATIONS_H_
                     23: 
                     24: #include <tncifimv.h>
                     25: #include <library.h>
                     26: 
                     27: typedef enum recommendation_policy_t recommendation_policy_t;
                     28: 
                     29: enum recommendation_policy_t {
                     30:        RECOMMENDATION_POLICY_DEFAULT,
                     31:        RECOMMENDATION_POLICY_ANY,
                     32:        RECOMMENDATION_POLICY_ALL
                     33: };
                     34: 
                     35: extern enum_name_t *recommendation_policy_names;
                     36: 
                     37: 
                     38: typedef struct recommendations_t recommendations_t;
                     39: 
                     40: /**
                     41:  * Collection of all IMV action recommendations and evaluation results
                     42:  */
                     43: struct recommendations_t {
                     44: 
                     45:        /**
                     46:         * Deliver an IMV action recommendation and IMV evaluation result to the TNCS
                     47:         *
                     48:         * @param imv_id                ID of the IMV providing the recommendation
                     49:         * @param rec                   action recommendation
                     50:         * @param eval                  evaluation result
                     51:         * @return                              return code
                     52:         */
                     53:        TNC_Result (*provide_recommendation)(recommendations_t *this,
                     54:                                                                                 TNC_IMVID imv_id,
                     55:                                                                                 TNC_IMV_Action_Recommendation rec,
                     56:                                                                                 TNC_IMV_Evaluation_Result eval);
                     57: 
                     58:        /**
                     59:         * If all IMVs provided a recommendation, derive a consolidated action
                     60:         * recommendation and evaluation result based on a configured policy
                     61:         *
                     62:         * @param rec                   action recommendation
                     63:         * @param eval                  evaluation result
                     64:         * @return                              TRUE if all IMVs provided a recommendation
                     65:         */
                     66:        bool (*have_recommendation)(recommendations_t *this,
                     67:                                                                TNC_IMV_Action_Recommendation *rec,
                     68:                                                                TNC_IMV_Evaluation_Result *eval);
                     69: 
                     70:        /**
                     71:         * Clear all recommendation information
                     72:         */
                     73:        void (*clear_recommendation)(recommendations_t *this);
                     74: 
                     75:        /**
                     76:         * Get the preferred language for remediation messages
                     77:         *
                     78:         * @return                              preferred language
                     79:         */
                     80:        chunk_t (*get_preferred_language)(recommendations_t *this);
                     81: 
                     82:        /**
                     83:         * Set the preferred language for remediation messages
                     84:         *
                     85:         * @param pref_lang             preferred language
                     86:         */
                     87:        void (*set_preferred_language)(recommendations_t *this, chunk_t pref_lang);
                     88: 
                     89:        /**
                     90:         * Set the reason string
                     91:         *
                     92:         * @param id                    ID of IMV setting the reason string
                     93:         * @param reason                reason string
                     94:         * @result                              return code
                     95:         */
                     96:        TNC_Result (*set_reason_string)(recommendations_t *this, TNC_IMVID id,
                     97:                                                                        chunk_t reason);
                     98: 
                     99:        /**
                    100:         * Set the language for reason strings
                    101:         *
                    102:         * @param id                    ID of IMV setting the reason language
                    103:         * @param reason_lang   reason language
                    104:         * @result                              return code
                    105:         */
                    106:        TNC_Result (*set_reason_language)(recommendations_t *this, TNC_IMVID id,
                    107:                                                                          chunk_t reason_lang);
                    108: 
                    109:        /**
                    110:         * Enumerates over all IMVs sending a reason string.
                    111:         * Format:  TNC_IMVID *id, chunk_t *reason, chunk_t *reason_language
                    112:         *
                    113:         * @return                              enumerator
                    114:         */
                    115:        enumerator_t* (*create_reason_enumerator)(recommendations_t *this);
                    116: 
                    117:        /**
                    118:         * Destroys an imv_t object.
                    119:         */
                    120:        void (*destroy)(recommendations_t *this);
                    121: };
                    122: 
                    123: #endif /** IMV_RECOMMENDATIONS_H_ @}*/

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>