4 * @brief Interface state_t.
9 * Copyright (C) 2005 Jan Hutter, Martin Willi
10 * Hochschule fuer Technik Rapperswil
12 * This program is free software; you can redistribute it and/or modify it
13 * under the terms of the GNU General Public License as published by the
14 * Free Software Foundation; either version 2 of the License, or (at your
15 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
19 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
26 #include <definitions.h>
28 #include <encoding/message.h>
30 typedef enum ike_sa_state_t ike_sa_state_t
;
33 * States in which a IKE_SA can be.
35 * @todo Support of more states (CHILD_SA_REQUESTED, etc...)
42 * @brief IKE_SA is in initial state as initiator and is going to initiate a new connection.
44 * Next state following this state is IKE_SA_INIT_REQUESTED.
46 * Implemented in class initiator_init_t.
51 * @brief IKE_SA is in initial state as responder and is going to respond to a initiated connection.
53 * Next state following this state is IKE_SA_INIT_RESPONDED.
55 * Implemented in class responder_init_t.
60 * @brief A IKE_SA_INIT request was sent. In this state a reply of type IKE_SA_INIT is expected.
62 * Two states are possible as next states:
63 * - IKE_AUTH_REQUESTED if IKE_SA_INIT reply could successfully processed and IKE_AUTH request could be sent.
64 * - INITIATOR_INIT if selected DH group was not the one selected by other peer.
66 * Implemented in class ike_sa_init_requested_t.
68 IKE_SA_INIT_REQUESTED
= 3,
71 * @brief A IKE_SA_INIT response was sent. In this state a request of type IKE_AUTH is expected.
73 * Next state following this state is IKE_SA_ESTABLISHED.
75 * Implemented in class ike_sa_init_responded_t.
77 IKE_SA_INIT_RESPONDED
= 4,
80 * @brief An IKE_AUTH request was sent after a successful IKE_SA_INIT-exchange.
82 * Next state following this state is IKE_SA_ESTABLISHED.
84 * Implemented in class ike_auth_requested_t.
86 IKE_AUTH_REQUESTED
= 5,
89 * @brief An IKE_AUTH exchange was successfuly handled either as initiator or responder.
91 * In this state, all the informations for an IKE_SA and one CHILD_SA are known.
93 * Implemented in class ike_sa_established_t.
95 IKE_SA_ESTABLISHED
= 6
100 * String mappings for ike_sa_state_t.
102 extern mapping_t ike_sa_state_m
[];
105 typedef struct state_t state_t
;
108 * @brief This interface represents an IKE_SA state.
110 * A state_t object is responsible to handle incoming messages.
112 * It's the responsibility of the state_t object to parse the body of the message and to process each
115 * Needed Configurations and transform objects can be retrieved over an internal stored protected_ike_sa_t object
116 * which is passed to a state_t object when creating it (see different constructors).
118 * The following states are supported and implemented:
119 * - INITIATOR_INIT: implemented in initiator_init_t
120 * - RESPONDER_INIT: implemented in responder_init_t
121 * - IKE_SA_INIT_REQUESTED: implemented in ike_sa_init_requested_t
122 * - IKE_SA_INIT_RESPONDED: implemented in ike_sa_init_responded_t
123 * - IKE_AUTH_REQUESTED: implemented in ike_auth_requested_t
124 * - IKE_SA_ESTABLISHED: implemented in ike_sa_established_t
127 * - initiator_init_create()
128 * - responder_init_create()
129 * - ike_sa_init_requested_create()
130 * - ike_sa_init_responded_create()
131 * - ike_auth_requested_create()
132 * - ike_sa_established_create()
139 * @brief Processes a incoming IKEv2-Message of type message_t.
141 * @param this calling object
142 * @param[in] message message_t object to process
146 * - DELETE_ME if belonging IKE_SA should be deleted
148 status_t (*process_message
) (state_t
*this,message_t
*message
);
151 * @brief Get the current state representing by this state_t object.
153 * @param this calling object
156 ike_sa_state_t (*get_state
) (state_t
*this);
159 * @brief Destroys a state_t object.
161 * @param this calling object
163 void (*destroy
) (state_t
*this);