nat: report correct EI per-user session limit

Type: fix

When enabling the endpoint independent NAT44 plugin, user_sessions
determines the maximum number of translations that can be active for
a single inside address. If 0 is passed in, a default value is used
but 0 is still stored in the field that is used to populate reply
messages to nat44_ei_show_running_config,

At the time of enabling the plugin, if user_sessions is 0, update the
field which is used by nat44_ei_show_running_config to contain the
default per-user limit which gets used by the EI nodes.

Change-Id: I6b060d85bcd42d91db879b95a8b07c6844bcd2a5
Signed-off-by: Matthew Smith <mgsmith@netgate.com>
This commit is contained in:
Matthew Smith
2021-05-13 11:11:33 -05:00
parent 06274811e4
commit 01930f568a
3 changed files with 11 additions and 3 deletions

View File

@@ -13,7 +13,7 @@
* limitations under the License.
*/
option version = "1.1.0";
option version = "1.1.1";
import "vnet/ip/ip_types.api";
import "vnet/interface_types.api";
import "plugins/nat/lib/nat_types.api";

View File

@@ -428,6 +428,9 @@ nat44_ei_plugin_enable (nat44_ei_config_t c)
if (!c.sessions)
c.sessions = 10 * 1024;
if (!c.user_sessions)
c.user_sessions = c.sessions;
nm->rconfig = c;
if (!nm->frame_queue_nelts)
@@ -448,8 +451,7 @@ nat44_ei_plugin_enable (nat44_ei_config_t c)
nm->max_users_per_thread = c.users;
nm->max_translations_per_thread = c.sessions;
nm->max_translations_per_user =
c.user_sessions ? c.user_sessions : nm->max_translations_per_thread;
nm->max_translations_per_user = c.user_sessions;
nm->inside_vrf_id = c.inside_vrf;
nm->inside_fib_index = fib_table_find_or_create_and_lock (

View File

@@ -3806,6 +3806,12 @@ class TestNAT44EI(MethodHolder):
"Invalid packet (src IP %s translated to %s, but expected %s)"
% (p_sent[IP].src, p_recvd[IP].src, a))
def test_default_user_sessions(self):
""" NAT44EI default per-user session limit is used and reported """
nat44_ei_config = self.vapi.nat44_ei_show_running_config()
# a nonzero default should be reported for user_sessions
self.assertNotEqual(nat44_ei_config.user_sessions, 0)
class TestNAT44Out2InDPO(MethodHolder):
""" NAT44EI Test Cases using out2in DPO """