osmux: Introduce osmux peer-behind-nat (on|off) and rework conn activation
Change-Id: I7654ddf51d197a4107e55f4e406053b2e4a02f83
diff --git a/src/libosmo-mgcp/mgcp_vty.c b/src/libosmo-mgcp/mgcp_vty.c
index a3af94a..faa6479 100644
--- a/src/libosmo-mgcp/mgcp_vty.c
+++ b/src/libosmo-mgcp/mgcp_vty.c
@@ -156,6 +156,8 @@
g_cfg->osmux_port, VTY_NEWLINE);
vty_out(vty, " osmux dummy %s%s",
g_cfg->osmux_dummy ? "on" : "off", VTY_NEWLINE);
+ vty_out(vty, " osmux peer-behind-nat %s%s",
+ g_cfg->osmux_peer_behind_nat ? "on" : "off", VTY_NEWLINE);
}
if (g_cfg->conn_timeout)
@@ -1646,6 +1648,21 @@
return CMD_SUCCESS;
}
+DEFUN(cfg_mgcp_osmux_peer_behind_nat,
+ cfg_mgcp_osmux_peer_behind_nat_cmd,
+ "osmux peer-behind-nat (on|off)",
+ OSMUX_STR "Define whether peer is behind NAT\n"
+ "Peer is behind NAT\n"
+ "Peer is NOT behind NAT\n")
+{
+ if (strcmp(argv[0], "on") == 0)
+ g_cfg->osmux_peer_behind_nat = true;
+ else if (strcmp(argv[0], "off") == 0)
+ g_cfg->osmux_peer_behind_nat = false;
+
+ return CMD_SUCCESS;
+}
+
DEFUN(cfg_mgcp_domain,
cfg_mgcp_domain_cmd,
"domain NAME",
@@ -1736,6 +1753,7 @@
install_element(MGCP_NODE, &cfg_mgcp_osmux_batch_size_cmd);
install_element(MGCP_NODE, &cfg_mgcp_osmux_port_cmd);
install_element(MGCP_NODE, &cfg_mgcp_osmux_dummy_cmd);
+ install_element(MGCP_NODE, &cfg_mgcp_osmux_peer_behind_nat_cmd);
install_element(MGCP_NODE, &cfg_mgcp_allow_transcoding_cmd);
install_element(MGCP_NODE, &cfg_mgcp_no_allow_transcoding_cmd);
install_element(MGCP_NODE, &cfg_mgcp_domain_cmd);