From: Brendan O'Dea Date: Tue, 10 May 2005 09:57:19 +0000 (+0000) Subject: sendchap on ConfigAck X-Git-Tag: 2.2.1-2fdn3.1~19^2^2~1^2~194 X-Git-Url: http://git.sameswireless.fr/l2tpns.git/commitdiff_plain/d908e3348f2f824e798e43a90fb89b2dfe981e2b?ds=sidebyside;hp=2267fbe504476b75d30270fb39a0f01481087676 sendchap on ConfigAck --- diff --git a/ppp.c b/ppp.c index 6888328..6cdeb35 100644 --- a/ppp.c +++ b/ppp.c @@ -1,6 +1,6 @@ // L2TPNS PPP Stuff -char const *cvs_id_ppp = "$Id: ppp.c,v 1.56 2005-05-10 09:47:23 bodea Exp $"; +char const *cvs_id_ppp = "$Id: ppp.c,v 1.57 2005-05-10 09:57:19 bodea Exp $"; #include #include @@ -355,7 +355,34 @@ void processlcp(tunnelidt t, sessionidt s, uint8_t *p, uint16_t l) if (*p == ConfigAck) { - LOG(3, s, t, "LCP: Discarding ConfigAck\n"); + int x = l - 4; + uint8_t *o = (p + 4); + int authtype = 0; + + LOG(3, s, t, "LCP: ConfigAck (%d bytes)...\n", l); + if (config->debug > 3) dumplcp(p, l); + + while (x > 2) + { + int type = o[0]; + int length = o[1]; + + if (length == 0 || type == 0 || x < length) break; + switch (type) + { + case 3: // Authentication-Protocol + { + int proto = ntohs(*(uint16_t *)(o + 2)); + if (proto == PPPCHAP && *(o + 4) == 5) + sendchap(t, s); + } + + break; + } + x -= length; + o += length; + } + session[s].flags |= SF_LCP_ACKED; } else if (*p == ConfigReq)