aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/kernel/kernel_handler.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2010-07-06 12:34:15 +0200
committerTobias Brunner <tobias@strongswan.org>2010-09-02 19:01:24 +0200
commit01563352e8f95c24d50cb7e987aa9afed639dd44 (patch)
tree983610fded5edfb52812aac4960a7220cb5bf5f5 /src/libcharon/kernel/kernel_handler.c
parenta22853b302f6b15c03f647fcf4c9e9498314dcd7 (diff)
downloadstrongswan-01563352e8f95c24d50cb7e987aa9afed639dd44.tar.bz2
strongswan-01563352e8f95c24d50cb7e987aa9afed639dd44.tar.xz
Moved update SA job creation to kernel event handler.
Diffstat (limited to 'src/libcharon/kernel/kernel_handler.c')
-rw-r--r--src/libcharon/kernel/kernel_handler.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c
index 64907b77d..b4fe1efed 100644
--- a/src/libcharon/kernel/kernel_handler.c
+++ b/src/libcharon/kernel/kernel_handler.c
@@ -20,6 +20,7 @@
#include <processing/jobs/acquire_job.h>
#include <processing/jobs/rekey_child_sa_job.h>
#include <processing/jobs/delete_child_sa_job.h>
+#include <processing/jobs/update_sa_job.h>
typedef struct private_kernel_handler_t private_kernel_handler_t;
@@ -74,6 +75,18 @@ METHOD(kernel_listener_t, expire, bool,
return TRUE;
}
+METHOD(kernel_listener_t, mapping, bool,
+ private_kernel_handler_t *this, u_int32_t reqid, u_int32_t spi,
+ host_t *remote)
+{
+ job_t *job;
+ DBG1(DBG_KNL, "NAT mappings of ESP CHILD_SA with SPI %.8x and "
+ "reqid {%u} changed, queuing update job", ntohl(spi), reqid);
+ job = (job_t*)update_sa_job_create(reqid, remote);
+ hydra->processor->queue_job(hydra->processor, job);
+ return TRUE;
+}
+
METHOD(kernel_handler_t, destroy, void,
private_kernel_handler_t *this)
{
@@ -91,6 +104,7 @@ kernel_handler_t *kernel_handler_create()
.listener = {
.acquire = _acquire,
.expire = _expire,
+ .mapping = _mapping,
},
.destroy = _destroy,
},