projects
/
l2tpns.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add sessionctl
[l2tpns.git]
/
l2tpns.c
diff --git
a/l2tpns.c
b/l2tpns.c
index
8f86f1d
..
72c856f
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.
98 2005-05-07 11:57:53
bodea Exp $";
+char const *cvs_id_l2tpns = "$Id: l2tpns.c,v 1.
100 2005-05-09 20:48:00
bodea Exp $";
#include <arpa/inet.h>
#include <assert.h>
#include <arpa/inet.h>
#include <assert.h>
@@
-2186,7
+2186,7
@@
void processudp(uint8_t * buf, int len, struct sockaddr_in *addr)
{
uint16_t atype = ntohs(*(uint16_t *)b);
LOG(4, s, t, " Proxy Auth Type %d (%s)\n", atype, auth_type(atype));
{
uint16_t atype = ntohs(*(uint16_t *)b);
LOG(4, s, t, " Proxy Auth Type %d (%s)\n", atype, auth_type(atype));
- if (atype = 2)
+ if (atype =
=
2)
authtype = AUTHCHAP;
else if (atype == 3)
authtype = AUTHPAP;
authtype = AUTHCHAP;
else if (atype == 3)
authtype = AUTHPAP;
@@
-2357,7
+2357,7
@@
void processudp(uint8_t * buf, int len, struct sockaddr_in *addr)
controlnull(t); // ack
// proxy authentication type is not supported
if (authtype && !(config->radius_authtypes & authtype))
controlnull(t); // ack
// proxy authentication type is not supported
if (authtype && !(config->radius_authtypes & authtype))
-
initlcp(t, s
);
+
sendlcp(t, s, config->radius_authprefer
);
break;
case 14: // CDN
controlnull(t); // ack
break;
case 14: // CDN
controlnull(t); // ack
@@
-3988,7
+3988,7
@@
static void update_config()
// test twice, In case someone works with
// a secondary radius server without defining
// a primary one, this will work even then.
// test twice, In case someone works with
// a secondary radius server without defining
// a primary one, this will work even then.
- if (i
>
0 && !config->radiusport[i])
+ if (i
>
0 && !config->radiusport[i])
config->radiusport[i] = config->radiusport[i-1];
if (!config->radiusport[i])
config->radiusport[i] = RADPORT;
config->radiusport[i] = config->radiusport[i-1];
if (!config->radiusport[i])
config->radiusport[i] = RADPORT;
@@
-4002,7
+4002,7
@@
static void update_config()
// parse radius_authtypes_s
config->radius_authtypes = config->radius_authprefer = 0;
p = config->radius_authtypes_s;
// parse radius_authtypes_s
config->radius_authtypes = config->radius_authprefer = 0;
p = config->radius_authtypes_s;
- while (*p)
+ while (
p &&
*p)
{
char *s = strpbrk(p, " \t,");
int type = 0;
{
char *s = strpbrk(p, " \t,");
int type = 0;
@@
-4027,6
+4027,8
@@
static void update_config()
config->radius_authtypes |= type;
if (!config->radius_authprefer)
config->radius_authprefer = type;
config->radius_authtypes |= type;
if (!config->radius_authprefer)
config->radius_authprefer = type;
+
+ p = s;
}
if (!config->radius_authtypes)
}
if (!config->radius_authtypes)