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
|
#include <string.h>
#include <freeradius/libradius.h>
#include "libradsec.h"
#include "libradsec-impl.h"
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;
if (rs_packet_add_attr (pkt, attr))
return -1;
if (rs_attr_create (conn, &attr, "User-Password", user_name))
return -1;
if (rs_packet_add_attr (pkt, attr))
return -1;
return RSE_OK;
}
int
rs_packet_send (struct rs_conn *conn, const struct rs_packet *pkt,
void *user_data)
{
rad_encode (pkt->rpkt, NULL, pkt->conn->secret);
#if defined (DEBUG)
fprintf (stderr, "%s: about to send this to %"
print_hex (pkt);
#endif
return RSE_NOSYS;
}
int rs_packet_receive(struct rs_conn *conn, struct rs_packet **pkt)
{
return RSE_NOSYS;
}
|