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
|
#include <string.h>
#include <assert.h>
#include <freeradius/libradius.h>
#include "libradsec.h"
#include "libradsec-impl.h"
#if defined DEBUG
#include "debug.h"
#endif
int
_packet_create (struct rs_connection *conn, struct rs_packet **pkt_out,
int code)
{
struct rs_packet *p;
RADIUS_PACKET *rpkt;
*pkt_out = NULL;
rpkt = rad_alloc (1);
if (!rpkt)
return rs_conn_err_push (conn, RSE_NOMEM, __func__);
rpkt->id = -1;
rpkt->code = code;
p = (struct rs_packet *) malloc (sizeof (struct rs_packet));
if (!p)
{
rad_free (&rpkt);
return rs_conn_err_push (conn, RSE_NOMEM, __func__);
}
memset (p, 0, sizeof (struct rs_packet));
p->rpkt = rpkt;
*pkt_out = p;
return RSE_OK;
}
int
rs_packet_create_acc_request (struct rs_connection *conn,
struct rs_packet **pkt_out,
const char *user_name, const char *user_pw)
{
struct rs_packet *pkt;
struct rs_attr *attr;
if (_packet_create (conn, pkt_out, PW_AUTHENTICATION_REQUEST))
return -1;
pkt = *pkt_out;
if (rs_attr_create (conn, &attr, "User-Name", user_name))
return -1;
rs_packet_add_attr (pkt, attr);
if (rs_attr_create (conn, &attr, "User-Password", user_pw))
return -1;
/* FIXME: need this too? rad_pwencode(user_pw, &pwlen, SECRET, reqauth) */
rs_packet_add_attr (pkt, attr);
return RSE_OK;
}
int
rs_packet_send (struct rs_connection *conn, const struct rs_packet *pkt,
void *user_data)
{
assert (pkt->rpkt);
if (!conn->active_peer)
{
int err = rs_conn_open (conn);
if (err)
return err;
}
rad_encode (pkt->rpkt, NULL, conn->active_peer->secret);
#if defined (DEBUG)
fprintf (stderr, "%s: about to send this to %s:\n", __func__, "<fixme>");
rs_dump_packet (pkt);
#endif
return rs_conn_err_push_fl (conn, RSE_NOSYS, __FILE__, __LINE__,
"%s: NYI", __func__);
}
int rs_packet_receive(struct rs_connection *conn, struct rs_packet **pkt)
{
return rs_conn_err_push_fl (conn, RSE_NOSYS, __FILE__, __LINE__,
"%s: NYI", __func__);
}
void
rs_packet_add_attr(struct rs_packet *pkt, struct rs_attr *attr)
{
pairadd (&pkt->rpkt->vps, attr->vp);
attr->pkt = pkt;
}
|