diff options
| author | Dmitry Kozlov <xeb@mail.ru> | 2017-04-18 20:47:53 +0300 |
|---|---|---|
| committer | Dmitry Kozlov <xeb@mail.ru> | 2017-04-18 20:47:53 +0300 |
| commit | 6750e90cc6a33bd8e30a68732bd5006206eec714 (patch) | |
| tree | d18dc7b32ab056d848e3b8b150df54046f75b05f /accel-pppd/ctrl/ipoe | |
| parent | e6012bc4db068b4d575005d69c7bbd8899623d2b (diff) | |
| download | accel-ppp-6750e90cc6a33bd8e30a68732bd5006206eec714.tar.gz accel-ppp-6750e90cc6a33bd8e30a68732bd5006206eec714.zip | |
implemented session count limiting
new config option:
[common]
max-sessions=N
If set then accel-pppd stops reply to new connection requests if total number of sessions (active and starting) is reached specified limit.
Diffstat (limited to 'accel-pppd/ctrl/ipoe')
| -rw-r--r-- | accel-pppd/ctrl/ipoe/ipoe.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/accel-pppd/ctrl/ipoe/ipoe.c b/accel-pppd/ctrl/ipoe/ipoe.c index b8aba6c9..46b6defb 100644 --- a/accel-pppd/ctrl/ipoe/ipoe.c +++ b/accel-pppd/ctrl/ipoe/ipoe.c @@ -1241,6 +1241,12 @@ static struct ipoe_session *ipoe_session_create_dhcpv4(struct ipoe_serv *serv, s int dlen = 0; uint8_t *ptr = NULL; + if (ap_shutdown) + return NULL; + + if (conf_max_sessions && ap_session_stat.active + ap_session_stat.starting > conf_max_sessions) + return NULL; + ses = ipoe_session_alloc(serv->ifname); if (!ses) return NULL; @@ -1884,6 +1890,9 @@ static struct ipoe_session *ipoe_session_create_up(struct ipoe_serv *serv, struc if (ap_shutdown) return NULL; + if (conf_max_sessions && ap_session_stat.active + ap_session_stat.starting > conf_max_sessions) + return NULL; + if (l4_redirect_list_check(saddr)) return NULL; |
