diff options
author | Dmitry Kozlov <xeb@mail.ru> | 2013-10-10 22:41:13 +0400 |
---|---|---|
committer | Dmitry Kozlov <xeb@mail.ru> | 2013-10-10 22:41:13 +0400 |
commit | dc7f00931df32a905f7fa5aa72a028cf6e807c3a (patch) | |
tree | 89ff8658c4b794debd62cc2105b2fd7dfbd84b22 /accel-pppd/ctrl | |
parent | 272dbf39f83240451d6a0c122ccdbe28eb892ad7 (diff) | |
parent | 8c608ea9a5b6b73520c11e3974bb8cad3b7da914 (diff) | |
download | accel-ppp-dc7f00931df32a905f7fa5aa72a028cf6e807c3a.tar.gz accel-ppp-dc7f00931df32a905f7fa5aa72a028cf6e807c3a.zip |
Merge branch 'master' of ssh://git.code.sf.net/p/accel-ppp/code
Diffstat (limited to 'accel-pppd/ctrl')
-rw-r--r-- | accel-pppd/ctrl/ipoe/ipoe.c | 62 | ||||
-rw-r--r-- | accel-pppd/ctrl/l2tp/l2tp.c | 6 | ||||
-rw-r--r-- | accel-pppd/ctrl/pppoe/pppoe.c | 6 | ||||
-rw-r--r-- | accel-pppd/ctrl/pptp/pptp.c | 6 |
4 files changed, 35 insertions, 45 deletions
diff --git a/accel-pppd/ctrl/ipoe/ipoe.c b/accel-pppd/ctrl/ipoe/ipoe.c index 4914be22..58e881f1 100644 --- a/accel-pppd/ctrl/ipoe/ipoe.c +++ b/accel-pppd/ctrl/ipoe/ipoe.c @@ -98,7 +98,7 @@ static int conf_ifcfg = 1; static int conf_nat = 0; static int conf_arp = 0; static uint32_t conf_src; - +static const char *conf_ip_pool; //static int conf_dhcpv6; static int conf_username; static const char *conf_password; @@ -974,18 +974,11 @@ static struct ipoe_session *ipoe_session_create_dhcpv4(struct ipoe_serv *serv, s int dlen = 0; uint8_t *ptr = NULL; - ses = mempool_alloc(ses_pool); - if (!ses) { - log_emerg("out of memery\n"); + ses = ipoe_session_alloc(); + if (!ses) return NULL; - } - - memset(ses, 0, sizeof(*ses)); - - ap_session_init(&ses->ses); ses->serv = serv; - ses->ifindex = -1; ses->dhcpv4_request = pack; ses->xid = pack->hdr->xid; @@ -1027,14 +1020,6 @@ static struct ipoe_session *ipoe_session_create_dhcpv4(struct ipoe_serv *serv, s ses->relay_agent = NULL; } - ses->ctx.before_switch = log_switch; - ses->ctx.close = ipoe_session_close; - ses->ctrl.ctx = &ses->ctx; - ses->ctrl.started = ipoe_session_started; - ses->ctrl.finished = ipoe_session_finished; - ses->ctrl.terminate = ipoe_session_terminate; - ses->ctrl.type = CTRL_TYPE_IPOE; - ses->ctrl.name = "ipoe"; ses->ctrl.dont_ifcfg = 1; ses->ctrl.calling_station_id = _malloc(19); @@ -1047,6 +1032,9 @@ static struct ipoe_session *ipoe_session_create_dhcpv4(struct ipoe_serv *serv, s ses->ses.ctrl = &ses->ctrl; ses->ses.chan_name = ses->ctrl.calling_station_id; + if (conf_ip_pool) + ses->ses.ipv4_pool_name = _strdup(conf_ip_pool); + triton_context_register(&ses->ctx, &ses->ses); triton_context_wakeup(&ses->ctx); @@ -1497,44 +1485,27 @@ static struct ipoe_session *ipoe_session_create_up(struct ipoe_serv *serv, struc if (l4_redirect_list_check(iph->saddr)) return NULL; - ses = mempool_alloc(ses_pool); - if (!ses) { - log_emerg("out of memery\n"); + ses = ipoe_session_alloc(); + if (!ses) return NULL; - } - - memset(ses, 0, sizeof(*ses)); - - ap_session_init(&ses->ses); ses->serv = serv; - ses->ifindex = -1; - memcpy(ses->hwaddr, eth->h_source, 6); - - ses->ctx.before_switch = log_switch; - ses->ctx.close = ipoe_session_close; - ses->ctrl.ctx = &ses->ctx; - ses->ctrl.started = ipoe_session_started; - ses->ctrl.finished = ipoe_session_finished; - ses->ctrl.terminate = ipoe_session_terminate; - ses->ctrl.type = CTRL_TYPE_IPOE; - ses->ctrl.name = "ipoe"; - ses->yiaddr = iph->saddr; ses->ctrl.calling_station_id = _malloc(17); - ses->ctrl.called_station_id = _malloc(17); + ses->ctrl.called_station_id = _strdup(serv->ifname); u_inet_ntoa(iph->saddr, ses->ctrl.calling_station_id); - u_inet_ntoa(iph->daddr, ses->ctrl.called_station_id); + + ses->ses.chan_name = ses->ctrl.calling_station_id; if (conf_username == USERNAME_UNSET) ses->ses.username = _strdup(ses->ctrl.calling_station_id); - ses->ses.ctrl = &ses->ctrl; - ses->ses.chan_name = ses->ctrl.calling_station_id; - + if (conf_ip_pool) + ses->ses.ipv4_pool_name = _strdup(conf_ip_pool); + triton_context_register(&ses->ctx, &ses->ses); triton_context_wakeup(&ses->ctx); @@ -1577,8 +1548,7 @@ struct ipoe_session *ipoe_session_alloc(void) ses->ctrl.name = "ipoe"; ses->ses.ctrl = &ses->ctrl; - ses->ses.chan_name = ses->ctrl.calling_station_id; - + return ses; } @@ -2858,6 +2828,8 @@ static void load_config(void) else conf_offer_timeout = 10; + conf_ip_pool = conf_get_opt("ipoe", "ip-pool"); + #ifdef RADIUS if (triton_module_loaded("radius")) load_radius_attrs(); diff --git a/accel-pppd/ctrl/l2tp/l2tp.c b/accel-pppd/ctrl/l2tp/l2tp.c index e6fae4de..e14bab85 100644 --- a/accel-pppd/ctrl/l2tp/l2tp.c +++ b/accel-pppd/ctrl/l2tp/l2tp.c @@ -67,6 +67,7 @@ static size_t conf_secret_len = 0; static int conf_mppe = MPPE_UNSET; static int conf_dataseq = L2TP_DATASEQ_ALLOW; static int conf_reorder_timeout = 0; +static const char *conf_ip_pool; static unsigned int stat_active; static unsigned int stat_starting; @@ -905,6 +906,9 @@ static struct l2tp_sess_t *l2tp_tunnel_alloc_session(struct l2tp_conn_t *conn) sess->ppp.ses.ctrl = &sess->ctrl; sess->ppp.fd = -1; + if (conf_ip_pool) + sess->ppp.ses.ipv4_pool_name = _strdup(conf_ip_pool); + return sess; } @@ -3963,6 +3967,8 @@ static void load_config(void) else if (strcmp(opt, "require") == 0) conf_mppe = MPPE_REQUIRE; } + + conf_ip_pool = conf_get_opt("l2tp", "ip-pool"); } static void l2tp_init(void) diff --git a/accel-pppd/ctrl/pppoe/pppoe.c b/accel-pppd/ctrl/pppoe/pppoe.c index 21051ed3..c254c7aa 100644 --- a/accel-pppd/ctrl/pppoe/pppoe.c +++ b/accel-pppd/ctrl/pppoe/pppoe.c @@ -89,6 +89,7 @@ char *conf_pado_delay; int conf_tr101 = 1; int conf_padi_limit = 0; int conf_mppe = MPPE_UNSET; +static const char *conf_ip_pool; static mempool_t conn_pool; static mempool_t pado_pool; @@ -299,6 +300,9 @@ static struct pppoe_conn_t *allocate_channel(struct pppoe_serv_t *serv, const ui conn->ppp.ses.ctrl = &conn->ctrl; conn->ppp.ses.chan_name = conn->ctrl.calling_station_id; + + if (conf_ip_pool) + conn->ppp.ses.ipv4_pool_name = _strdup(conf_ip_pool); triton_context_register(&conn->ctx, &conn->ppp.ses); triton_context_wakeup(&conn->ctx); @@ -1489,6 +1493,8 @@ static void load_config(void) else if (strcmp(opt, "require") == 0) conf_mppe = MPPE_REQUIRE; } + + conf_ip_pool = conf_get_opt("pppoe", "ip-pool"); } static void pppoe_init(void) diff --git a/accel-pppd/ctrl/pptp/pptp.c b/accel-pppd/ctrl/pptp/pptp.c index d5b96c1e..31ffd007 100644 --- a/accel-pppd/ctrl/pptp/pptp.c +++ b/accel-pppd/ctrl/pptp/pptp.c @@ -60,6 +60,7 @@ static int conf_echo_interval = 0; static int conf_echo_failure = 3; static int conf_verbose = 0; static int conf_mppe = MPPE_UNSET; +static const char *conf_ip_pool; static mempool_t conn_pool; @@ -685,6 +686,9 @@ static int pptp_connect(struct triton_md_handler_t *h) ppp_init(&conn->ppp); conn->ppp.ses.ctrl = &conn->ctrl; + if (conf_ip_pool) + conn->ppp.ses.ipv4_pool_name = _strdup(conf_ip_pool); + triton_context_register(&conn->ctx, &conn->ppp.ses); triton_md_register_handler(&conn->ctx, &conn->hnd); triton_md_enable_handler(&conn->hnd,MD_MODE_READ); @@ -759,6 +763,8 @@ static void load_config(void) else if (strcmp(opt, "require") == 0) conf_mppe = MPPE_REQUIRE; } + + conf_ip_pool = conf_get_opt("pptp", "ip-pool"); } static void pptp_init(void) |