projects
/
l2tpns.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
344fe61
)
always send LCP ConfigReq after we get ICCN
author
Brendan O'Dea
<bod@optus.net>
Fri, 13 May 2005 01:29:40 +0000
(
01:29
+0000)
committer
Brendan O'Dea
<bod@optus.net>
Fri, 13 May 2005 01:29:40 +0000
(
01:29
+0000)
l2tpns.c
patch
|
blob
|
history
diff --git
a/l2tpns.c
b/l2tpns.c
index
f2000f5
..
a3da175
100644
(file)
--- a/
l2tpns.c
+++ b/
l2tpns.c
@@
-4,7
+4,7
@@
// Copyright (c) 2002 FireBrick (Andrews & Arnold Ltd / Watchfront Ltd) - GPL licenced
// vim: sw=8 ts=8
// Copyright (c) 2002 FireBrick (Andrews & Arnold Ltd / Watchfront Ltd) - GPL licenced
// vim: sw=8 ts=8
-char const *cvs_id_l2tpns = "$Id: l2tpns.c,v 1.10
2 2005-05-12 04:08:45
bodea Exp $";
+char const *cvs_id_l2tpns = "$Id: l2tpns.c,v 1.10
3 2005-05-13 01:29:40
bodea Exp $";
#include <arpa/inet.h>
#include <assert.h>
#include <arpa/inet.h>
#include <assert.h>
@@
-2305,8
+2305,6
@@
void processudp(uint8_t * buf, int len, struct sockaddr_in *addr)
// TBA
break;
case 10: // ICRQ
// TBA
break;
case 10: // ICRQ
- controlt *c;
-
if (sessionfree)
{
uint16_t r;
if (sessionfree)
{
uint16_t r;
@@
-2321,7
+2319,7
@@
void processudp(uint8_t * buf, int len, struct sockaddr_in *addr)
// make a RADIUS session
if ((r = radiusnew(s)))
{
// make a RADIUS session
if ((r = radiusnew(s)))
{
- c = controlnew(11); // sending ICRP
+ c
ontrolt *c
= controlnew(11); // sending ICRP
session[s].opened = time_now;
session[s].tunnel = t;
session[s].far = asession;
session[s].opened = time_now;
session[s].tunnel = t;
session[s].far = asession;
@@
-2347,9
+2345,11
@@
void processudp(uint8_t * buf, int len, struct sockaddr_in *addr)
LOG(1, 0, t, "No free sessions\n");
}
LOG(1, 0, t, "No free sessions\n");
}
- c = controlnew(14); // CDN
- control16(c, 1, 4, 1); // temporary lack of resources
- controladd(c, session[s].tunnel, asession); // send the message
+ {
+ controlt *c = controlnew(14); // CDN
+ control16(c, 1, 4, 1); // temporary lack of resources
+ controladd(c, session[s].tunnel, asession); // send the message
+ }
return;
case 11: // ICRP
// TBA
return;
case 11: // ICRP
// TBA
@@
-2361,8
+2361,11
@@
void processudp(uint8_t * buf, int len, struct sockaddr_in *addr)
LOG(3, s, t, "Magic %X Flags %X\n", amagic, aflags);
controlnull(t); // ack
// proxy authentication type is not supported
LOG(3, s, t, "Magic %X Flags %X\n", amagic, aflags);
controlnull(t); // ack
// proxy authentication type is not supported
- if (authtype && !(config->radius_authtypes & authtype))
- sendlcp(t, s, config->radius_authprefer);
+ if (!(config->radius_authtypes & authtype))
+ authtype = config->radius_authprefer;
+
+ // start LCP
+ sendlcp(t, s, authtype);
break;
case 14: // CDN
controlnull(t); // ack
break;
case 14: // CDN
controlnull(t); // ack