192 lines
5.3 KiB
C
192 lines
5.3 KiB
C
/**
|
|
* @file policy.h
|
|
*
|
|
* @brief Interface of policy_t.
|
|
*
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2005 Jan Hutter, Martin Willi
|
|
* Hochschule fuer Technik Rapperswil
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; either version 2 of the License, or (at your
|
|
* option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*/
|
|
|
|
#ifndef POLICY_H_
|
|
#define POLICY_H_
|
|
|
|
#include <types.h>
|
|
#include <utils/identification.h>
|
|
#include <config/traffic_selector.h>
|
|
#include <config/proposal.h>
|
|
#include <encoding/payloads/auth_payload.h>
|
|
|
|
|
|
typedef struct policy_t policy_t;
|
|
|
|
/**
|
|
* @brief A policy_t defines the policies to apply to CHILD_SAs.
|
|
*
|
|
* The given two IDs identify a policy. These rules define how
|
|
* child SAs may be set up and which traffic may be IPsec'ed.
|
|
*
|
|
* @b Constructors:
|
|
* - policy_create()
|
|
*
|
|
* @ingroup config
|
|
*/
|
|
struct policy_t {
|
|
|
|
/**
|
|
* @brief Get own id to use for identification.
|
|
*
|
|
* Returned object is not getting cloned.
|
|
*
|
|
* @param this calling object
|
|
* @return own id
|
|
*/
|
|
identification_t *(*get_my_id) (policy_t *this);
|
|
|
|
/**
|
|
* @brief Get id of communication partner.
|
|
*
|
|
* Returned object is not getting cloned.
|
|
*
|
|
* @param this calling object
|
|
* @return other id
|
|
*/
|
|
identification_t *(*get_other_id) (policy_t *this);
|
|
|
|
/**
|
|
* @brief Get configured traffic selectors for our site.
|
|
*
|
|
* Returns a list with all traffic selectors for the local
|
|
* site. List and items MUST NOT be freed nor modified.
|
|
*
|
|
* @param this calling object
|
|
* @return list with traffic selectors
|
|
*/
|
|
linked_list_t *(*get_my_traffic_selectors) (policy_t *this);
|
|
|
|
/**
|
|
* @brief Get configured traffic selectors for others site.
|
|
*
|
|
* Returns a list with all traffic selectors for the remote
|
|
* site. List and items MUST NOT be freed nor modified.
|
|
*
|
|
* @param this calling object
|
|
* @return list with traffic selectors
|
|
*/
|
|
linked_list_t *(*get_other_traffic_selectors) (policy_t *this);
|
|
|
|
/**
|
|
* @brief Select traffic selectors from a supplied list for local site.
|
|
*
|
|
* Resulted list and traffic selectors must be destroyed after usage.
|
|
*
|
|
* @param this calling object
|
|
* @param supplied linked list with traffic selectors
|
|
* @return list containing the selected traffic selectors
|
|
*/
|
|
linked_list_t *(*select_my_traffic_selectors) (policy_t *this, linked_list_t *supplied);
|
|
|
|
/**
|
|
* @brief Select traffic selectors from a supplied list for remote site.
|
|
*
|
|
* Resulted list and traffic selectors must be destroyed after usage.
|
|
*
|
|
* @param this calling object
|
|
* @param supplied linked list with traffic selectors
|
|
* @return list containing the selected traffic selectors
|
|
*/
|
|
linked_list_t *(*select_other_traffic_selectors) (policy_t *this, linked_list_t *supplied);
|
|
|
|
/**
|
|
* @brief Get the list of internally stored proposals.
|
|
*
|
|
* Rembember: policy_t does store proposals for AH/ESP,
|
|
* IKE proposals are in the connection_t
|
|
*
|
|
* @warning List and Items are still owned by policy and MUST NOT
|
|
* be manipulated or freed!
|
|
*
|
|
* @param this calling object
|
|
* @return lists with proposals
|
|
*/
|
|
linked_list_t *(*get_proposals) (policy_t *this);
|
|
|
|
/**
|
|
* @brief Select a proposal from a supplied list.
|
|
*
|
|
* @param this calling object
|
|
* @param proposals list from from wich proposals are selected
|
|
* @return selected proposal, or NULL if nothing matches
|
|
*/
|
|
proposal_t *(*select_proposal) (policy_t *this, linked_list_t *proposals);
|
|
|
|
/**
|
|
* @brief Add a traffic selector to the list for local site.
|
|
*
|
|
* After add, proposal is owned by policy.
|
|
*
|
|
* @warning Do not add while other threads are reading.
|
|
*
|
|
* @param this calling object
|
|
* @param traffic_selector traffic_selector to add
|
|
*/
|
|
void (*add_my_traffic_selector) (policy_t *this, traffic_selector_t *traffic_selector);
|
|
|
|
/**
|
|
* @brief Add a traffic selector to the list for remote site.
|
|
*
|
|
* After add, proposal is owned by policy.
|
|
*
|
|
* @warning Do not add while other threads are reading.
|
|
*
|
|
* @param this calling object
|
|
* @param traffic_selector traffic_selector to add
|
|
*/
|
|
void (*add_other_traffic_selector) (policy_t *this, traffic_selector_t *traffic_selector);
|
|
|
|
/**
|
|
* @brief Add a proposal to the list.
|
|
*
|
|
* The proposals are stored by priority, first added
|
|
* is the most prefered.
|
|
*
|
|
* @warning Do not add while other threads are reading.
|
|
*
|
|
* @param this calling object
|
|
* @param proposal proposal to add
|
|
*/
|
|
void (*add_proposal) (policy_t *this, proposal_t *proposal);
|
|
|
|
/**
|
|
* @brief Destroys the config object
|
|
*
|
|
* @param this calling object
|
|
*/
|
|
void (*destroy) (policy_t *this);
|
|
};
|
|
|
|
/**
|
|
* @brief Create a configuration object for IKE_AUTH and later.
|
|
*
|
|
* @param my_id identification_t for ourselves
|
|
* @param other_id identification_t for the remote guy
|
|
* @return policy_t object
|
|
*
|
|
* @ingroup config
|
|
*/
|
|
policy_t *policy_create(identification_t *my_id, identification_t *other_id);
|
|
|
|
#endif /* POLICY_H_ */
|