summaryrefslogtreecommitdiff
path: root/src/charon/sa/authenticators/eap/eap_identity.c
blob: 12a8bf7cc28bb6eb2962e12b3d5daaf340d0f15d (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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/**
 * @file eap_identity.c
 *
 * @brief Implementation of eap_identity_t.
 *
 */

/*
 * Copyright (C) 2007 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.
 */

#include "eap_identity.h"

#include <daemon.h>
#include <library.h>

typedef struct private_eap_identity_t private_eap_identity_t;

/**
 * Private data of an eap_identity_t object.
 */
struct private_eap_identity_t {
	
	/**
	 * Public authenticator_t interface.
	 */
	eap_identity_t public;
	
	/**
	 * ID of the peer
	 */
	identification_t *peer;
};

/**
 * Implementation of eap_method_t.process for the peer
 */
static status_t process(private_eap_identity_t *this,
						eap_payload_t *in, eap_payload_t **out)
{
	chunk_t id, hdr;
	
	hdr = chunk_alloca(5);
	id = this->peer->get_encoding(this->peer);
	
	*(hdr.ptr + 0) = EAP_RESPONSE;
	*(hdr.ptr + 1) = in->get_identifier(in);
	*(u_int16_t*)(hdr.ptr + 2) = htons(hdr.len + id.len);
	*(hdr.ptr + 4) = EAP_IDENTITY;
	
	*out = eap_payload_create_data(chunk_cata("cc", hdr, id));
	return SUCCESS;
	
}

/**
 * Implementation of eap_method_t.initiate for the peer
 */
static status_t initiate(private_eap_identity_t *this, eap_payload_t **out)
{
	/* peer never initiates */
	return FAILED;
}

/**
 * Implementation of eap_method_t.get_type.
 */
static eap_type_t get_type(private_eap_identity_t *this)
{
	return EAP_IDENTITY;
}

/**
 * Implementation of eap_method_t.get_msk.
 */
static status_t get_msk(private_eap_identity_t *this, chunk_t *msk)
{
	return FAILED;
}

/**
 * Implementation of eap_method_t.is_mutual.
 */
static bool is_mutual(private_eap_identity_t *this)
{
	return FALSE;
}

/**
 * Implementation of eap_method_t.destroy.
 */
static void destroy(private_eap_identity_t *this)
{
	free(this);
}

/*
 * Described in header.
 */
eap_identity_t *eap_create(eap_role_t role,
					  	   identification_t *server, identification_t *peer)
{
	private_eap_identity_t *this;
	
	if (role != EAP_PEER)
	{
		return NULL;
	}
	
	this = malloc_thing(private_eap_identity_t);
	
	/* public functions */
	this->public.eap_method_interface.initiate = (status_t(*)(eap_method_t*,eap_payload_t**))initiate;
	this->public.eap_method_interface.process = (status_t(*)(eap_method_t*,eap_payload_t*,eap_payload_t**))process;
	this->public.eap_method_interface.get_type = (eap_type_t(*)(eap_method_t*))get_type;
	this->public.eap_method_interface.is_mutual = (bool(*)(eap_method_t*))is_mutual;
	this->public.eap_method_interface.get_msk = (status_t(*)(eap_method_t*,chunk_t*))get_msk;
	this->public.eap_method_interface.destroy = (void(*)(eap_method_t*))destroy;
	
	/* private data */
	this->peer = peer;
	
	return &this->public;
}