aboutsummaryrefslogtreecommitdiffstats
path: root/src/charon/sa/states/ike_auth_requested.h
blob: a8eef014cd7642b271b9cf8d96d16acee869c856 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/**
 * @file ike_auth_requested.h
 * 
 * @brief Interface of ike_auth_requested_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 IKE_AUTH_REQUESTED_H_
#define IKE_AUTH_REQUESTED_H_

#include <sa/states/state.h>
#include <sa/ike_sa.h>


typedef struct ike_auth_requested_t ike_auth_requested_t;

/**
 * @brief This class represents an IKE_SA, which has requested an IKE_AUTH.
 * 
 * The state accpets IKE_AUTH responses. It proves the authenticity
 * and sets up the first child sa. After that, it changes IKE_SA state to 
 * IKE_SA_ESTABLISHED.
 * 
 * @ Constructors:
 *  - ike_auth_requested_create()
 * 
 * @todo handle certificate payloads
 * 
 * @ingroup states
 */
struct ike_auth_requested_t {
	/**
	 * The state_t interface.
	 */
	state_t state_interface;

};

/**
 * Constructor of class ike_auth_requested_t
 * 
 * @param ike_sa					assigned ike_sa object
 * @param sent_nonce				Sent nonce value in IKE_SA_INIT request
 * @param received_nonce			Received nonce value in IKE_SA_INIT response
 * @param ike_sa_init_reply_data	binary representation of IKE_SA_INIT reply 
 * @param child_sa					opened but not completed child_sa
 * @return							created ike_auth_requested_t object
 * 
 * @ingroup states
 */
ike_auth_requested_t *ike_auth_requested_create(protected_ike_sa_t *ike_sa,
												chunk_t sent_nonce,
												chunk_t received_nonce,
												chunk_t ike_sa_init_reply_data,
												child_sa_t *child_sa);

#endif /*IKE_AUTH_REQUESTED_H_*/