aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2012-04-20 10:38:31 +0200
committerTobias Brunner <tobias@strongswan.org>2012-08-08 15:12:25 +0200
commita7babe25ee22e1de91ace2549b122fee58de6911 (patch)
tree3dc0d20e817fbb940e0e37501d21000240a92ba3 /src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c
parent56d07af3bed3a104a6c57a779e84fb41c1b143e4 (diff)
downloadstrongswan-a7babe25ee22e1de91ace2549b122fee58de6911.tar.bz2
strongswan-a7babe25ee22e1de91ace2549b122fee58de6911.tar.xz
Added get_port() method to socket_t to learn the listening port.
Diffstat (limited to 'src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c')
-rw-r--r--src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c b/src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c
index 3c3b17bf3..e0e0af6b6 100644
--- a/src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c
+++ b/src/libcharon/plugins/socket_dynamic/socket_dynamic_socket.c
@@ -467,6 +467,7 @@ METHOD(socket_t, sender, status_t,
dst = packet->get_destination(packet);
family = src->get_family(src);
port = src->get_port(src);
+ port = port ?: CHARON_UDP_PORT;
skt = find_socket(this, family, port);
if (!skt)
{
@@ -534,6 +535,14 @@ METHOD(socket_t, sender, status_t,
return SUCCESS;
}
+METHOD(socket_t, get_port, u_int16_t,
+ private_socket_dynamic_socket_t *this, bool nat_t)
+{
+ /* we return 0 here for users that have no explicit port configured, the
+ * sender will default to the default port in this case */
+ return 0;
+}
+
METHOD(socket_t, destroy, void,
private_socket_dynamic_socket_t *this)
{
@@ -567,6 +576,7 @@ socket_dynamic_socket_t *socket_dynamic_socket_create()
.socket = {
.send = _sender,
.receive = _receiver,
+ .get_port = _get_port,
.destroy = _destroy,
},
},